플랫폼 독립적 인 파이썬에서 GUID를 어떻게 만들 수 있습니까? Windows에서 ActivePython을 사용하는 방법이 있지만 COM을 사용하기 때문에 Windows입니다. 일반 파이썬을 사용하는 방법이 있습니까?
python -c 'import uuid; print(uuid.uuid4())'
플랫폼 독립적 인 파이썬에서 GUID를 어떻게 만들 수 있습니까? Windows에서 ActivePython을 사용하는 방법이 있지만 COM을 사용하기 때문에 Windows입니다. 일반 파이썬을 사용하는 방법이 있습니까?
python -c 'import uuid; print(uuid.uuid4())'
답변:
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'
shortuuid
더 짧고 읽을 수있는 UUID를 생성 할 수 있도록 작성한 모듈을 살펴보십시오 . github.com/stochastic-technologies/shortuuid
uuid4().hex
과 str(uuid4())
?
str(uuid4())
대시 포함과 함께 UUID의 문자열 표현을 반환하면서 uuid4().hex
돌아갑니다 "32 자의 16 진수 문자열로 UUID"
복사 : 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')
데이터베이스 유형 작업을 위해 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('=', '')
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 문자 까지
return
바이트와 비슷한 객체를 기대하는 문 에서 유형 오류가 발생 합니다. 로 고정 할 수 있습니다 return str(r_uuid).replace('=','')
.
모델 또는 고유 필드의 기본 키에 대해 UUID를 전달해야하는 경우 아래 코드는 UUID 객체를 반환합니다.
import uuid
uuid.uuid4()
URL의 매개 변수로 UUID를 전달 해야하는 경우 아래 코드와 같이 할 수 있습니다-
import uuid
str(uuid.uuid4())
UUID의 16 진수 값을 원하면 아래 작업을 수행 할 수 있습니다-
import uuid
uuid.uuid4().hex
이 기능은 완전히 구성 가능하며 지정된 형식에 따라 고유 한 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
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으로 대체 될 수 있습니다. 그러나 내 목적을 위해이 기능이 필요한 전부입니다. 강력한 유효성 검사를 수행하고 올바른 결과를 생성합니다.
이 게시물을 확인 하면 많은 도움 이 되었습니다. 요컨대, 나에게 가장 좋은 옵션은 다음과 같습니다.
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 개의 임의의 문자 만 필요했기 때문입니다.