Python 生成短8位唯一id實(shí)戰(zhàn)教程
Win10
Python 3.5.4
實(shí)現(xiàn)思路利用62個(gè)可打印字符,通過隨機(jī)生成32位UUID,由于UUID都為十六進(jìn)制,所以將UUID分成8組,每4個(gè)為一組,然后通過模62(字符0-9,a-z,A-Z總數(shù)量62個(gè)字符)操作,結(jié)果作為索引取出字符,這樣重復(fù)率大大降低,實(shí)踐測(cè)試,運(yùn)行20000000次,僅出現(xiàn)2個(gè)重復(fù)id(僅測(cè)試過一次)。
當(dāng)然,這樣還達(dá)不到唯一id,因?yàn)檫€是有重復(fù)的。解決方法呢,可以考慮結(jié)合數(shù)據(jù)庫(kù)、或者其它存儲(chǔ)來實(shí)現(xiàn),以結(jié)合數(shù)據(jù)庫(kù)為例,我們可以新建一張數(shù)據(jù)庫(kù)表,并給表設(shè)置一個(gè)id字段,并且設(shè)置為主鍵、或者增加唯一約束,每次獲取8 id后,往表里插入一條數(shù)據(jù),如果可以成功插入,說明不重復(fù),否則說明是重復(fù)id,再次嘗試獲取。
核心代碼#!/usr/bin/env python# -*- coding:utf-8 -*- ’’’@CreateTime: 2020/07/14 11:04@Author : shouke’’’ import uuidarray = [ '0', '1', '2', '3', '4', '5','6', '7', '8', '9', 'a', 'b', 'c', 'd', 'e', 'f','g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's','t', 'u', 'v', 'w', 'x', 'y', 'z', 'A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I','J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V','W', 'X', 'Y', 'Z' ] def get_short_id(): id = str(uuid.uuid4()).replace('-', ’’) # 注意這里需要用uuid4 buffer = [] for i in range(0, 8): start = i * 4 end = i * 4 + 4 val = int(id[start:end], 16) buffer.append(array[val % 62]) return ''.join(buffer)測(cè)試驗(yàn)證
id_set = set() # 用于存放生成的唯一idcount = 0 # 用于統(tǒng)計(jì)出現(xiàn)重復(fù)的次數(shù)index = [] # 記錄第幾次調(diào)用生成8位id出現(xiàn)重復(fù)for i in range(0, 20000000): id = get_short_id() if id in id_set: count += 1 index.append(str(i+1)) else: id_set.add(id) print(’id:%s, 運(yùn)行第 %s 次, 重復(fù)數(shù):%s , 重復(fù)率:%s, 出現(xiàn)重復(fù)次序 %s’ % (id, i+1, count, count/(i+1)*100, ’,’.join(index)))
補(bǔ)充:用python隨機(jī)生成以2019開頭的10個(gè)8位數(shù)的學(xué)號(hào)
import random意思是引入內(nèi)置模塊random,j代表著
行數(shù),range()是一個(gè)隨機(jī)生成數(shù)字的函數(shù),i控制著
每行的個(gè)數(shù),str()表示是轉(zhuǎn)化為字符串的類型
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章:
1. IE6/IE7/IE8/IE9中tbody的innerHTML不能賦值的完美解決方案2. 利用CSS3新特性創(chuàng)建透明邊框三角3. 解析原生JS getComputedStyle4. 通過CSS數(shù)學(xué)函數(shù)實(shí)現(xiàn)動(dòng)畫特效5. CSS3中Transition屬性詳解以及示例分享6. XML入門的常見問題(一)7. 低版本IE正常運(yùn)行HTML5+CSS3網(wǎng)站的3種解決方案8. XML入門的常見問題(二)9. 阿里前端開發(fā)中的規(guī)范要求10. CSS3實(shí)例分享之多重背景的實(shí)現(xiàn)(Multiple backgrounds)
