uuid是128比特的全局唯一标识符(univeral unique identifier),通常用32位十六进制的字符串1(大小写无关)的形式来表现,标准的UUID格式为:
xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx (8-4-4-4-12)
UUID用来识别属性类型,在所有空间和时间上被视为唯一的标识。一般来说,可以保证这个值是真正唯一的任何地方产生的任意一个UUID都不会有相同的值。使用UUID的一个好处是可以为新的服务创建新的标识符。这样一来,客户端在查找一个服务时,只需要在它的服务查找请求中指出与某类服务(或某个特定服务)有关的UUID,如果服务的提供者能将可用的服务与这个UUID相匹配,就返回一个响应。最广泛应用的UUID,是微软公司的全局唯一标识符(GUID)2
python中自带了uuid模块来进行uuid的生成和管理工作3。
uuid.uuid1()
基于MAC地址,时间戳(以100纳秒为1),随机数来生成唯一的uuid,可以保证全球范围内的唯一性。uuid.uuid2()
算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。不过需要注意的是python中没有基于DCE的算法,所以python的uuid模块中没有uuid2这个方法。uuid.uuid3(namespace,name)
通过计算一个命名空间和名字的md5散列值来给出一个uuid,所以可以保证命名空间中的不同名字具有不同的uuid,但是相同的名字就是相同的uuid了。uuid.uuid4()
通过伪随机数得到uuid,是有一定概率重复的uuid.uuid5(namespace,name)
和uuid3基本相同,只不过采用的散列算法是sha1
其中,namespace命名空间是您喜欢的任何UUID。 它可以是uuid预定义( uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_URL,uuid.NAMESPACE_X500
)中的一个,或者你可以自己组成串4
一般而言,在对uuid的需求不是很复杂的时候,uuid1方法就已经够用了,使用方法如下:
#coding=utf-8
import uuid
print(uuid.uuid1())
print(uuid.uuid4())
print(uuid.uuid1())
print(uuid.uuid4())
name = 'test_uuid'
# 使用预定义的uuid,一般有如下几种
# uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_URL,uuid.NAMESPACE_X500
namespace_pre = uuid.NAMESPACE_URL
# 使用自定义的UUID
namespace_self = uuid.uuid1()
print(uuid.uuid3(namespace_pre,name))
print(uuid.uuid3(namespace_pre,name))
print(uuid.uuid3(namespace_self,name))
print(uuid.uuid3(namespace_self,name))
print(uuid.uuid5(namespace_pre,name))
print(uuid.uuid5(namespace_pre,name))
print(uuid.uuid5(namespace_self,name))
print(uuid.uuid5(namespace_self,name))