python 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。編碼方法: # -*- coding: utf-8 -*- import uuid name = "test_name" namespace = "test_namespace" print uuid.uuid1() # 帶參的方法參見Python Doc print uuid.uuid3(namespace, name) print uuid.uuid4() print uuid.uuid5(namespace, name)
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章