日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python-获取UUID

發(fā)布時間:2023/12/20 python 44 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python-获取UUID 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

UUID

UUID 是 通用唯一識別碼(Universally Unique Identifier)的縮寫,是一種軟件建構(gòu)的標(biāo)準(zhǔn),亦為開放軟件基金會組織在分布式計算環(huán)境領(lǐng)域的一部分。
**UUID是由一個十六位的數(shù)字組成,表現(xiàn)出來的形式例如
**550E8400-E29B-11D4-A716-446655440000

UUID的用處

UUID在項目中文件上傳時使用
用來生成一個文件名的前綴,那么每次請求生成的前綴就會不同,從而不會讓新上傳的文件因為同名而覆蓋舊文件。

因為我工作當(dāng)中的接口需要傳uuid,所以需要封裝一個獲取uuid的方法

在python里能找到UUID的使用方法

python中的uuid模塊基于信息如MAC地址、時間戳、命名空間、隨機(jī)數(shù)、偽隨機(jī)數(shù)來uuid。
在源碼里看到具體的方法有如下幾個:

  
uuid.uuid1()  
基于MAC地址,時間戳,隨機(jī)數(shù)來生成唯一的uuid,可以保證全球范圍內(nèi)的唯一性。

uuid.uuid2()
算法與uuid1相同,不同的是把時間戳的前4位置換為POSIX的UID。不過需要注意的是python中沒有基于DCE的算法,所以python的uuid模塊中沒有uuid2這個方法。

uuid.uuid3(namespace,name)  
通過計算一個命名空間和名字的md5散列值來給出一個uuid,所以可以保證命名空間中的不同名字具有不同的uuid,但是相同的名字就是相同的uuid了。
namespace并不是一個自己手動指定的字符串或其他量,而是在uuid模塊中本身給出的一些值。比如uuid.NAMESPACE_DNS,uuid.NAMESPACE_OID,uuid.NAMESPACE_OID這些值。這些值本身也是UUID對象,根據(jù)一定的規(guī)則計算得出。

uuid.uuid4()  
通過偽隨機(jī)數(shù)得到uuid,是有一定概率重復(fù)的

uuid.uuid5(namespace,name)  
和uuid3基本相同,只不過采用的散列算法是sha1
一般而言,在對uuid的需求不是很復(fù)雜的時候,uuid1方法就已經(jīng)夠用了,使用方法如下:

import uuidclass UUID:def get_uuid(self):# name = 'test_name'# namespace = 'test_namespace'#namespace = uuid.NAMESPACE_URLreturn uuid.uuid1()

返回的UUID碼類似這種

總結(jié)

以上是生活随笔為你收集整理的python-获取UUID的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。