uuid是128位的全局惟一標識符(univeral unique identifier),一般用32位的一個字符串的形式來表現,自帶了uuid模塊來進行uuid的生成和管理工做。python
python中的uuid模塊基於信息如MAC地址、時間戳、命名空間、隨機數、僞隨機數來uuid。算法
具體方法有以下幾個: 分佈式
uuid.uuid1() 基於MAC地址,時間戳,隨機數來生成惟一的uuid,能夠保證全球範圍內的惟一性。ide
uuid.uuid2() 算法與uuid1相同,不一樣的是把時間戳的前4位置換爲POSIX的UID。注意:python的uuid模塊中沒有uuid2這個方法。ui
uuid.uuid3(namespace,name) 經過計算一個命名空間和名字的md5散列值來給出一個uuid,保證命名空間中的不一樣名字具備不一樣的uuid。可是相同的名字就是相同的uuid了。spa
namespace的取值以下:3d
- uuid.NAMESPACE_DNS :當指定該命名空間時,參數 name 是一個徹底限定的(fully-qualified)域名
- uuid.NAMESPACE_URL :當指定該命名空間時,參數 name 是一個URL
- uuid.NAMESPACE_OID :當指定該命名空間時,參數 name 是一個ISO OID
- uuid.NAMESPACE_X500:當指定該命名空間時,參數 name 是一個DER格式或文本格式的X.500 DN
uuid.uuid4() 經過僞隨機數獲得uuid,是有必定機率重複的code
uuid.uuid5(namespace,name) 和uuid3基本相同,只不過採用的散列算法是sha1blog
import uuid name = 'abc' print(uuid.uuid1()) print(uuid.uuid3(uuid.NAMESPACE_DNS,name)) print(uuid.uuid3(uuid.NAMESPACE_OID,name)) print(uuid.uuid3(uuid.NAMESPACE_URL,name)) print(uuid.uuid3(uuid.NAMESPACE_X500,name)) print(uuid.uuid4()) print(uuid.uuid5(uuid.NAMESPACE_DNS,name)) print(uuid.uuid5(uuid.NAMESPACE_OID,name)) print(uuid.uuid5(uuid.NAMESPACE_URL,name)) print(uuid.uuid5(uuid.NAMESPACE_X500,name)) 返回結果: >>> ================================ RESTART ================================ >>> f6bccef8-c7d3-11e9-ac44-2cd974dd0333 5bd670ce-29c8-3369-a8a1-10ce44c7259e 5557cd36-6b67-38ac-83fe-825f5905fc15 874a8cb4-4e91-3055-a476-3d3e2ffe375f 589392cb-93e1-392c-a846-367c45ed1ecc e1197563-915a-433a-a963-f4ec35ab775c 6cb8e707-0fc5-5f55-88d4-d4fed43e64a8 7697a46f-b283-5da3-8e7c-62c11c03dd9e 68661508-f3c4-55b4-945d-ae2b4dfe5db4 53e882a6-63b1-578b-8bf1-8f0878cfa6b7
使用說明:md5
首先,Python中沒有基於DCE的,因此uuid2能夠忽略; 其次,uuid4存在機率性重複,由無映射性,最好不用; 再次,若在Global的分佈式計算環境下,最好用uuid1; 最後,如有名字的惟一性要求,最好用uuid3或uuid5。
例如:將生成的隨機字符串轉換爲大寫,並去掉'-'
import uuid order_number = str(uuid.uuid1()).upper().replace('-','')
print(order_number)
生成不重複的隨機數,還能夠利用時間戳生成(微秒級)
import time order_number = lambda : int(round(time.time()* 1000*1000))
打印order_number()方法
print(order_number())