Python 基于Python生成短8位唯一id解决方案
生活随笔
收集整理的這篇文章主要介紹了
Python 基于Python生成短8位唯一id解决方案
小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
利用62個(gè)可打印字符,通過(guò)隨機(jī)生成32位UUID,由于UUID都為十六進(jìn)制,所以將UUID分成8組,每4個(gè)為一組,然后通過(guò)模62(字符0-9,a-z,A-Z總數(shù)量62個(gè)字符)操作,結(jié)果作為索引取出字符,這樣重復(fù)率大大降低,實(shí)踐測(cè)試,運(yùn)行20000000次,僅出現(xiàn)2個(gè)重復(fù)id(僅測(cè)試過(guò)一次)。
當(dāng)然,這樣還達(dá)不到唯一id,因?yàn)檫€是有重復(fù)的。解決方法呢,可以考慮結(jié)合數(shù)據(jù)庫(kù)、或者其它存儲(chǔ)來(lái)實(shí)現(xiàn),以結(jié)合數(shù)據(jù)庫(kù)為例,我們可以新建一張數(shù)據(jù)庫(kù)表,并給表設(shè)置一個(gè)id字段,并且設(shè)置為主鍵、或者增加唯一約束,每次獲取8 id后,往表里插入一條數(shù)據(jù),如果可以成功插入,說(shuō)明不重復(fù),否則說(shuō)明是重復(fù)id,再次嘗試獲取。
核心代碼
#!/usr/bin/env python # -*- coding:utf-8 -*-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("-", '') # 注意這里需要用uuid4buffer = []for i in range(0, 8):start = i * 4end = i * 4 + 4val = int(id[start:end], 16)buffer.append(array[val % 62])return "".join(buffer)測(cè)試驗(yàn)證
''' 遇到問(wèn)題沒人解答?小編創(chuàng)建了一個(gè)Python學(xué)習(xí)交流QQ群:778463939 尋找有志同道合的小伙伴,互幫互助,群里還有不錯(cuò)的視頻學(xué)習(xí)教程和PDF電子書! ''' id_set = set() # 用于存放生成的唯一id count = 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 += 1index.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)))總結(jié)
以上是生活随笔為你收集整理的Python 基于Python生成短8位唯一id解决方案的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: python调用Linux下so文件
- 下一篇: Python 中文分词(结巴分词)