Python 生成短8位唯一id實戰教程
測試環境:
Win10
Python 3.5.4
實現思路
利用62個可打印字符,通過隨機生成32位UUID,由於UUID都為十六進制,所以將UUID分成8組,每4個為一組,然後通過模62(字符0-9,a-z,A-Z總數量62個字符)操作,結果作為索引取出字符,這樣重復率大大降低,實踐測試,運行20000000次,僅出現2個重復id(僅測試過一次)。
當然,這樣還達不到唯一id,因為還是有重復的。解決方法呢,可以考慮結合數據庫、或者其它存儲來實現,以結合數據庫為例,我們可以新建一張數據庫表,並給表設置一個id字段,並且設置為主鍵、或者增加唯一約束,每次獲取8 id後,往表裡插入一條數據,如果可以成功插入,說明不重復,否則說明是重復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 # 用於統計出現重復的次數 index = [] # 記錄第幾次調用生成8位id出現重復 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 次, 重復數:%s , 重復率:%s, 出現重復次序 %s' % (id, i+1, count, count/(i+1)*100, ','.join(index)))
補充:用python隨機生成以2019開頭的10個8位數的學號
import random意思是引入內置模塊random,j代表著
行數,range()是一個隨機生成數字的函數,i控制著
每行的個數,str()表示是轉化為字符串的類型
以上為個人經驗,希望能給大傢一個參考,也希望大傢多多支持WalkonNet。如有錯誤或未考慮完全的地方,望不吝賜教。
推薦閱讀:
- python process模塊的使用簡介
- python中進程間通信詳細介紹
- python數學建模是加深Numpy和Pandas學習
- Python中的多線程實例(簡單易懂)
- 7個關於Python的經典基礎案例