Python 生成短8位唯一id實戰(zhàn)教程
測試環(huán)境:
Win10
Python 3.5.4
實現(xiàn)思路
利用62個可打印字符,通過隨機生成32位UUID,由于UUID都為十六進制,所以將UUID分成8組,每4個為一組,然后通過模62(字符0-9,a-z,A-Z總數(shù)量62個字符)操作,結(jié)果作為索引取出字符,這樣重復(fù)率大大降低,實踐測試,運行20000000次,僅出現(xiàn)2個重復(fù)id(僅測試過一次)。
當然,這樣還達不到唯一id,因為還是有重復(fù)的。解決方法呢,可以考慮結(jié)合數(shù)據(jù)庫、或者其它存儲來實現(xiàn),以結(jié)合數(shù)據(jù)庫為例,我們可以新建一張數(shù)據(jù)庫表,并給表設(shè)置一個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 uuid array = [ "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)
測試驗證
id_set = set() # 用于存放生成的唯一id count = 0 # 用于統(tǒng)計出現(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, 運行第 %s 次, 重復(fù)數(shù):%s , 重復(fù)率:%s, 出現(xiàn)重復(fù)次序 %s' % (id, i+1, count, count/(i+1)*100, ','.join(index)))
補充:用python隨機生成以2019開頭的10個8位數(shù)的學號
import random意思是引入內(nèi)置模塊random,j代表著
行數(shù),range()是一個隨機生成數(shù)字的函數(shù),i控制著
每行的個數(shù),str()表示是轉(zhuǎn)化為字符串的類型
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。
相關(guān)文章
Python中Pandas庫的數(shù)據(jù)處理與分析
Python的Pandas庫是數(shù)據(jù)科學領(lǐng)域中非常重要的一個庫,它使數(shù)據(jù)清洗和分析工作變得更快更簡單,Pandas結(jié)合了NumPy的高性能數(shù)組計算功能以及電子表格和關(guān)系型數(shù)據(jù)庫(如SQL)的靈活數(shù)據(jù)處理能力,需要的朋友可以參考下2023-07-07Python實現(xiàn)視頻轉(zhuǎn)換為音頻的方法詳解
這篇文章主要為大家詳細Python如何將視頻轉(zhuǎn)換為音頻并將音頻文件保存到特定文件夾下,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下2025-02-02Python中模塊pymysql查詢結(jié)果后如何獲取字段列表
pymsql是Python中操作MySQL的模塊,其使用方法和MySQLdb幾乎相同。下面這篇文章主要給大家介紹了關(guān)于Python中模塊pymysql查詢結(jié)果后如何獲取字段列表的相關(guān)資料,文中介紹的非常詳細,需要的朋友可以參考借鑒,下面來看看詳細的介紹。2017-06-06