uuid是128位的全局唯一标识符(univeral unique identifier),通常用一个32位的字符串的形式来表现。有时也称guid(global unique identifier)。python中自带了uuid模块来进行uuid的生成和管理工作。(python 2.7和3.4+版本都支持uuid)
python中的uuid模块基于信息如MAC地址、时间戳、命名空间、随机数、伪随机数来uuid。具体方法有如下几个:
1、uuid.uuid1() 基于MAC地址,时间戳,随机数来生成唯一的uuid,可以保证全球范围内的唯一性。当然,这个是根据当前的时间戳和MAC地址生成的,最后的12个字符408d5c985711对应的就是MAC地址,因为是MAC地址,唯一性应该不用说了。但是生成后暴露了MAC地址这就很不好了。
2、uuid.uuid2() 算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。不过,需要注意的是python中没有基于DCE的算法,所以python的uuid模块中没有uuid2这个方法。
3、uuid.uuid3(namespace,name) 通过计算一个命名空间和名字的md5散列值来给出一个uuid,所以可以保证命名空间中的不同名字具有不同的uuid,但是相同的名字就是相同的uuid了。
【感谢评论区大佬指出】namespace并不是一个自己手动指定的字符串或其他量,而是在uuid模块中本身给出的一些值。比如uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_OID这些值。这些值本身也是UUID对象,根据一定的规则计算得出。
4、uuid.uuid4() 通过伪随机数得到uuid,是有一定概率重复的。既然是随机就有可能真的遇到相同的,但这就像中奖似的,几率超小,因为是随机而且使用还方便,所以使用这个的也是比较多的。
5、uuid.uuid5(namespace,name) 和uuid3基本相同,只不过采用的散列算法是sha1
一般而言,在对uuid的需求不是很复杂的时候,uuid1方法就已经够用了,使用方法如下:
#coding=utf-8
import uuid
name = 'test_name'
# namespace = 'test_namespace'
namespace = uuid.NAMESPACE_URL
print(uuid.uuid1())
print(uuid.uuid3(namespace,name))
print(uuid.uuid4())
print(uuid.uuid5(namespace,name))
UUID中间的'-'是个比较奇怪的字符,可以去掉它,具体方法超简单:
import uuid
uid = uuid.uuid1()
suid = ''.join(str(uid).split('-'))
print(uid)
print(suid)
另一种解决方法:
import uuid
uid = uuid.uuid1()urnuid = uid.urn
suid = ''.join(urnuid.lstrip('urn:uuid').split('-'))
print(uid)
print(urnuid)
print(suid)