代码示例:
>>> import uuid
>>> print uuid.uuid1()
ff614b46-504e-11e5-9fbd-00163e003fc6
>>> print uuid.uuid1()
07d1e966-504f-11e5-9fbd-00163e003fc6
>>>
>>>
>>> print uuid.uuid3(uuid.NAMESPACE_DNS, 'testme')
7a67f5d4-50fd-36f7-bbeb-1c739ab40b8c
>>> print uuid.uuid3(uuid.NAMESPACE_DNS, 'testme')
7a67f5d4-50fd-36f7-bbeb-1c739ab40b8c
>>>
>>> uuid.uuid4()
UUID('5c8ab371-d926-4040-a5ad-05a6529a830b')
>>> str(uuid.uuid4())
'7d6c0efe-6733-4c00-85bf-fda9508f2adb'
>>> str(uuid.uuid4())
'63dfd870-ce92-4509-88e0-2afd3183482f'
>>> str(uuid.uuid4())
'edb47851-7aab-433a-8432-5c4fc39b6e67'
>>> str(uuid.uuid4())
'b1b0a628-9480-43a1-ba1b-eac3c5f6a0bb'
>>> str(uuid.uuid4())
'55a77965-f768-4741-883a-6070a2cbcef5'
>>> import uuid
>>>
>>> uuid.uuid4().hex
'156d9566ac2f494e8dca62fb2295cd06'
>>> uuid.uuid4()
UUID('b5c86173-ad64-4fbc-8d1b-76b25f04beec')
>>> print uuid.uuid5(uuid.NAMESPACE_DNS, 'testme')
dac48d1f-a443-578c-8754-856842a2f98d
>>> print uuid.uuid5(uuid.NAMESPACE_DNS, 'testme')
dac48d1f-a443-578c-8754-856842a2f98d
>>> print uuid.uuid5(uuid.NAMESPACE_DNS, 'testme').hex
dac48d1fa443578c8754856842a2f98d
获取帮助:
>>> help(uuid.uuid4())
hex the UUID as a 32-character hexadecimal string
扩展阅读
Python使用UUID库生成唯一ID
http://www.cnblogs.com/dkblog/archive/2011/10/10/2205200.html
简介:
这里的评价很有用…
资料:
Python官方Doc:《20.15. uuid — UUID objects according to RFC 4122》
UUID的算法介绍:《A Universally Unique IDentifier (UUID) URN Namespace》
概述:
UUID是128位的全局唯一标识符,通常由32字节的字符串表示。
它可以保证时间和空间的唯一性,也称为GUID,全称为:
UUID —— Universally Unique IDentifier Python 中叫 UUID
GUID —— Globally Unique IDentifier C# 中叫 GUID
它通过MAC地址、时间戳、命名空间、随机数、伪随机数来保证生成ID的唯一性。
UUID主要有五个算法,也就是五种方法来实现:
1、uuid1()——基于时间戳
由MAC地址、当前时间戳、随机数生成。可以保证全球范围内的唯一性,
但MAC的使用同时带来安全性问题,局域网中可以使用IP来代替MAC。
2、uuid2()——基于分布式计算环境DCE(Python中没有这个函数)
算法与uuid1相同,不同的是把时间戳的前4位置换为POSIX的UID。
实际中很少用到该方法。
3、uuid3()——基于名字的MD5散列值
通过计算名字和命名空间的MD5散列值得到,保证了同一命名空间中不同名字的唯一性,
和不同命名空间的唯一性,但同一命名空间的同一名字生成相同的uuid。
4、uuid4()——基于随机数
由伪随机数得到,有一定的重复概率,该概率可以计算出来。
5、uuid5()——基于名字的SHA-1散列值
算法与uuid3相同,不同的是使用 Secure Hash Algorithm 1 算法
使用方面:
首先,Python中没有基于DCE的,所以uuid2可以忽略;
其次,uuid4存在概率性重复,由无映射性,最好不用;
再次,若在Global的分布式计算环境下,最好用uuid1;
最后,若有名字的唯一性要求,最好用uuid3或uuid5。
python uuid模块
http://blog.163.com/kefan_1987/blog/static/897801312011113011537390/
简介:
这个解释的最好,示例也最完整….
Python 有没有短一点的 UUID?
http://www.v2ex.com/t/156107
简介:
这里涉及到进制转换算法来缩短 uuid.