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

歡迎訪問 生活随笔!

生活随笔

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

python

Python概念:生成唯一性序号uuid

發(fā)布時間:2025/3/21 python 30 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Python概念:生成唯一性序号uuid 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

1 uuid是什么? ? ?

????????UUID: 通用唯一標(biāo)識符 ( Universally Unique Identifier ), 對于所有的UUID它可以保證在空間和時間上的唯一性. 它是通過MAC地址, 時間戳, 命名空間, 隨機(jī)數(shù), 偽隨機(jī)數(shù)來保證生成ID的唯一性,?有著固定的大小( 128 bit ). ?它的唯一性和一致性特點(diǎn)使得可以無需注冊過程就能夠產(chǎn)生一個新的UUID.

????????UUID可以被用作多種用途, 既可以用來短時間內(nèi)標(biāo)記一個對象, 也可以可靠的辨別網(wǎng)絡(luò)中的持久性對象.?

2 uuid的函數(shù)生成方法

  1. ?uuid.uuid1([node[, clock_seq]])??: 基于時間戳

  使用主機(jī)ID, 序列號, 和當(dāng)前時間來生成UUID, 可保證全球范圍的唯一性. 但由于使用該方法生成的UUID中包含有主機(jī)的網(wǎng)絡(luò)地址, 因此可能危及隱私.?該函數(shù)有兩個參數(shù), 如果?node?參數(shù)未指定, 系統(tǒng)將會自動調(diào)用?getnode()?函數(shù)來獲取主機(jī)的硬件地址. 如果?clock_seq??參數(shù)未指定系統(tǒng)會使用一個隨機(jī)產(chǎn)生的14位序列號來代替.?

  2. ?uuid.uuid3(namespace, name)?: 基于名字的MD5散列值

  通過計算命名空間和名字的MD5散列值來生成UUID, 可以保證同一命名空間中不同名字的唯一性和不同命名空間的唯一性, 但同一命名空間的同一名字生成的UUID相同.

  3.??uuid.uuid4()?: 基于隨機(jī)數(shù)

  通過隨機(jī)數(shù)來生成UUID. 使用的是偽隨機(jī)數(shù)有一定的重復(fù)概率.?

  4.??uuid.uuid5(namespace, name)?: 基于名字的SHA-1散列值

  通過計算命名空間和名字的SHA-1散列值來生成UUID, 算法與?uuid.uuid3()?相同.

3. 通過四函數(shù)生成uuid字節(jié)(128位)

>>> import uuid>>> # make a UUID based on the host ID and current time >>> uuid.uuid1() UUID('a8098c1a-f86e-11da-bd1a-00112444be1e')>>> # make a UUID using an MD5 hash of a namespace UUID and a name >>> uuid.uuid3(uuid.NAMESPACE_DNS, 'python.org') UUID('6fa459ea-ee8a-3ca4-894e-db77e160355e')>>> # make a random UUID >>> uuid.uuid4() UUID('16fd2706-8baf-433b-82eb-8c7fada847da')>>> # make a UUID using a SHA-1 hash of a namespace UUID and a name >>> uuid.uuid5(uuid.NAMESPACE_DNS, 'python.org') UUID('886313e1-3b8a-5372-9b90-0c9aee199e5d')>>> # make a UUID from a string of hex digits (braces and hyphens ignored) >>> x = uuid.UUID('{00010203-0405-0607-0809-0a0b0c0d0e0f}')>>> # convert a UUID to a string of hex digits in standard form >>> str(x) '00010203-0405-0607-0809-0a0b0c0d0e0f'>>> # get the raw 16 bytes of the UUID >>> x.bytes '\x00\x01\x02\x03\x04\x05\x06\x07\x08\t\n\x0b\x0c\r\x0e\x0f'>>> # make a UUID from a 16-byte string >>> uuid.UUID(bytes=x.bytes) UUID('00010203-0405-0607-0809-0a0b0c0d0e0f')

4 字節(jié)串和字符串關(guān)系

【1】字節(jié)串(bytes)和字符串(string)的對比:

  • 字符串由若干個字符組成,以字符為單位進(jìn)行操作;字節(jié)串由若干個字節(jié)組成,以字節(jié)為單位進(jìn)行操作。
  • 字節(jié)串和字符串除了操作的數(shù)據(jù)單元不同之外,它們支持的所有方法都基本相同。
  • 字節(jié)串和字符串都是不可變序列,不能隨意增加和刪除數(shù)據(jù)。

【2】字符串和 bytes 存在著千絲萬縷的聯(lián)系,我們可以通過字符串來創(chuàng)建 bytes 對象,或者說將字符串轉(zhuǎn)換成 bytes 對象。有以下三種方法可以達(dá)到這個目的:

  • 如果字符串的內(nèi)容都是 ASCII 字符,那么直接在字符串前面添加b前綴就可以轉(zhuǎn)換成 bytes。
  • bytes 是一個類,調(diào)用它的構(gòu)造方法,也就是?bytes(),可以將字符串按照指定的字符集轉(zhuǎn)換成 bytes;如果不指定字符集,那么默認(rèn)采用 UTF-8。
  • 字符串本身有一個?encode() 方法,該方法專門用來將字符串按照指定的字符集轉(zhuǎn)換成對應(yīng)的字節(jié)串;如果不指定字符集,那么默認(rèn)采用?UTF-8。
  • bytes 類也有一個 decode() 方法,通過該方法可以將 bytes 對象轉(zhuǎn)換為字符串。緊接上面的程序,添加以下代碼:

【3】#通過 decode() 方法將 bytes 轉(zhuǎn)換成字符串

  • str1 = b5.decode('UTF-8')
  • print("str1: ", str1)

【4】#通過 encode() 方法將字符串轉(zhuǎn)換成 bytes

  • b5 = "C語言中文網(wǎng)8歲了".encode('UTF-8')
  • print("b5: ", b5)

5 通過字節(jié)串生成uuid

import uuid # ss = uuid.uuid1() fs = uuid.UUID(int=uuid.getnode()) ss = uuid.UUID('{12345678-1234-5678-1234-567812345678}') rre = uuid.UUID('12345678123456781234567812345678') rrs = uuid.UUID('urn:uuid:12345678-1234-5678-1234-567812345678') mr = uuid.UUID(int=0x12345678123456781234567812345678) rr = uuid.UUID( bytes= b'\x12\x34\x56\x78'*4 ) rr = uuid.UUID(bytes_le=b'\x78\x56\x34\x12\x34\x12\x78\x56\x12\x34\x56\x78\x12\x34\x56\x78' ) rr=uuid.UUID(fields=(0x12345678, 0x1234, 0x5678, 0x12, 0x34, 0x567812345678)) rr=uuid.UUID(int=0x12345678123456781234567812345678)

總結(jié)

以上是生活随笔為你收集整理的Python概念:生成唯一性序号uuid的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

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