파이썬에서 GUID / UUID를 만드는 방법


686

플랫폼 독립적 인 파이썬에서 GUID를 어떻게 만들 수 있습니까? Windows에서 ActivePython을 사용하는 방법이 있지만 COM을 사용하기 때문에 Windows입니다. 일반 파이썬을 사용하는 방법이 있습니까?



34
신성한 모든 것을 사랑하기 위해 UUID-Universal Unique ID en.wikipedia.org/wiki/Universally_unique_identifier- 불행히도 MS는 GUID를 선호했습니다.
david.barkhuizen

5
여기 하나의 라이너가 있습니다 :python -c 'import uuid; print(uuid.uuid4())'
Ctrl-C

답변:


776

Python 2.5 이상에서 uuid 모듈은 RFC 호환 UUID 생성을 제공합니다. 자세한 내용은 모듈 문서 및 RFC를 참조하십시오. [ 출처 ]

문서 :

예 (2와 3에서 작업) :

>>> import uuid
>>> uuid.uuid4()
UUID('bd65600d-8669-4903-8a14-af88203add38')
>>> str(uuid.uuid4())
'f50ec0b7-f960-400d-91f0-c42a6d44e3d0'
>>> uuid.uuid4().hex
'9fe2c4e93f654fdbb24c02b15259716c'

20
또한 shortuuid더 짧고 읽을 수있는 UUID를 생성 할 수 있도록 작성한 모듈을 살펴보십시오 . github.com/stochastic-technologies/shortuuid
Stavros Korokithakis

2
@StavrosKorokithakis : 파이썬 3.x 용 shortuuid 모듈을 우연히 작성 했습니까?
Jay Patel

2
@JayPatel shortuuid가 Python 3에서 작동하지 않습니까? 그렇지 않은 경우 버그를 제기하십시오.
Stavros Korokithakis

1
차이 무엇 uuid4().hexstr(uuid4())?
Kevin

6
글쎄, 당신은 위의 볼 수 있듯이, str(uuid4())대시 포함과 함께 UUID의 문자열 표현을 반환하면서 uuid4().hex돌아갑니다 "32 자의 16 진수 문자열로 UUID"
stuartd

324

Python 2.5 이상을 사용하는 경우 uuid 모듈 은 이미 Python 표준 배포판에 포함되어 있습니다.

전의:

>>> import uuid
>>> uuid.uuid4()
UUID('5361a11b-615c-42bf-9bdb-e2c3790ada14')

116

복사 : https://docs.python.org/2/library/uuid.html (게시 된 링크가 활성화되지 않고 계속 업데이트되므로)

>>> 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')

28

데이터베이스 유형 작업을 위해 GUID를 임의의 키로 사용합니다.

대시와 추가 문자가있는 16 진수 형식은 필연적으로 길어 보입니다. 그러나 16 진수를 나타내는 문자열은 '+', '='등과 같은 일부 상황에서 문제를 일으킬 수있는 문자가 포함되어 있지 않기 때문에 매우 안전합니다.

16 진수 대신 url-safe base64 문자열을 사용합니다. 다음은 UUID / GUID 사양을 준수하지 않습니다 (필요한 임의의 양을 제외하고).

import base64
import uuid

# get a UUID - URL safe, Base64
def get_a_uuid():
    r_uuid = base64.urlsafe_b64encode(uuid.uuid4().bytes)
    return r_uuid.replace('=', '')

2
UUID 컨텍스트에서 사용하지 않아도되는 경우 random.getrandbits(128).to_bytes(16, 'little')또는 (암호화 임의성)을 사용 os.urandom(16)하고 128 비트의 임의의 무작위를 얻을 수 있습니다 (UUIDv4는 버전 정보에서 6-7 비트를 사용합니다). 또는 15 바이트 만 사용하고 (임의의 1-2 비트 임의의 UUIDv4 손실) =3 바이트의 배수로 인코딩되므로 인코딩 된 크기를 20 바이트 (24에서 22로 줄임)로 줄이면서 부호 를 잘라낼 필요가 없습니다. #bytes / 3 * 4채울 필요없이 base64 문자 까지
ShadowRanger

@ShadowRanger 그래 기본적으로 아이디어입니다. URL이 안전하면서도 128 개의 임의 비트가 가능한 한 편리하게 짧습니다. 이상적으로는 대문자와 소문자, 숫자 만 사용합니다. 그래서 나는 기본 62 문자열을 추측합니다.
Chris Dutrow

함수를 사용할 때 return바이트와 ​​비슷한 객체를 기대하는 문 에서 유형 오류가 발생 합니다. 로 고정 할 수 있습니다 return str(r_uuid).replace('=','').
마크 Kortink

8

모델 또는 고유 필드의 기본 키에 대해 UUID를 전달해야하는 경우 아래 코드는 UUID 객체를 반환합니다.

 import uuid
 uuid.uuid4()

URL의 매개 변수로 UUID를 전달 해야하는 경우 아래 코드와 같이 할 수 있습니다-

import uuid
str(uuid.uuid4())

UUID의 16 진수 값을 원하면 아래 작업을 수행 할 수 있습니다-

import uuid    
uuid.uuid4().hex

0

이 기능은 완전히 구성 가능하며 지정된 형식에 따라 고유 한 uid를 생성합니다

예 :-[8, 4, 4, 4, 12], 이것은 언급 된 형식이며 다음 uuid를 생성합니다

LxoYNyXe-7hbQ-caJt-DSdU-PDAht56cMEWi

 import random as r

 def generate_uuid():
        random_string = ''
        random_str_seq = "0123456789abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUVWXYZ"
        uuid_format = [8, 4, 4, 4, 12]
        for n in uuid_format:
            for i in range(0,n):
                random_string += str(random_str_seq[r.randint(0, len(random_str_seq) - 1)])
            if n != 12:
                random_string += '-'
        return random_string

3
UUID는 표준이며 길이가 가변적이지 않습니다. 구성 가능한 방식으로 임의 문자열을 생성하는 것은 일부 상황에서는 유용하지만이 상황에서는 유용하지 않습니다. en.wikipedia.org/wiki/Universally_unique_identifier 에서 정의를 확인할 수 있습니다 .
miguelr

2
더 나은 (이 표준 GUID가 아닌)이 하나를 피하거나 당신은 호환성 문제로 실행될 수 있습니다
실뱅 GANTOIS에게

-1

2019 답변 (Windows 용) :

Windows에서 컴퓨터를 고유하게 식별하는 영구 UUID를 원한다면이 트릭을 사용할 수 있습니다 : ( https://stackoverflow.com/a/58416992/8874388의 답변에서 복사했습니다 ).

from typing import Optional
import re
import subprocess
import uuid

def get_windows_uuid() -> Optional[uuid.UUID]:
    try:
        # Ask Windows for the device's permanent UUID. Throws if command missing/fails.
        txt = subprocess.check_output("wmic csproduct get uuid").decode()

        # Attempt to extract the UUID from the command's result.
        match = re.search(r"\bUUID\b[\s\r\n]+([^\s\r\n]+)", txt)
        if match is not None:
            txt = match.group(1)
            if txt is not None:
                # Remove the surrounding whitespace (newlines, space, etc)
                # and useless dashes etc, by only keeping hex (0-9 A-F) chars.
                txt = re.sub(r"[^0-9A-Fa-f]+", "", txt)

                # Ensure we have exactly 32 characters (16 bytes).
                if len(txt) == 32:
                    return uuid.UUID(txt)
    except:
        pass # Silence subprocess exception.

    return None

print(get_windows_uuid())

Windows API를 사용하여 컴퓨터의 영구 UUID를 얻은 다음 문자열을 처리하여 유효한 UUID인지 확인한 다음 마지막으로 편리한 Python 객체 ( https://docs.python.org/3/library/uuid.html )를 반환 합니다. 데이터 사용 방법 (예 : 128 비트 정수, 16 진 문자열 등).

행운을 빕니다!

추신 : 하위 프로세스 호출은 아마도 Windows 커널 / DLL을 직접 호출하는 ctype으로 대체 될 수 있습니다. 그러나 내 목적을 위해이 기능이 필요한 전부입니다. 강력한 유효성 검사를 수행하고 올바른 결과를 생성합니다.


-1

게시물을 확인 하면 많은 도움 되었습니다. 요컨대, 나에게 가장 좋은 옵션은 다음과 같습니다.

import random 
import string 

# defining function for random 
# string id with parameter 
def ran_gen(size, chars=string.ascii_uppercase + string.digits): 
    return ''.join(random.choice(chars) for x in range(size)) 

# function call for random string 
# generation with size 8 and string  
print (ran_gen(8, "AEIOSUMA23")) 

부피가 큰 GUID 대신 4-6 개의 임의의 문자 만 필요했기 때문입니다.


이것은 UUID에 관한 질문과 완전히 관련이없는 것 같습니다.
Monica
당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.