Resposta 2019 (para Windows):
Se você deseja um UUID permanente que identifique uma máquina exclusivamente no Windows, use este truque: (Copiado da minha resposta em 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())
Usa a API do Windows para obter o UUID permanente do computador, depois processa a cadeia de caracteres para garantir que seja um UUID válido e, por fim, retorna um objeto Python ( https://docs.python.org/3/library/uuid.html ), que oferece uma conveniência maneiras de usar os dados (como número inteiro de 128 bits, sequência hexadecimal etc.).
Boa sorte!
PS: A chamada de subprocesso provavelmente poderia ser substituída por ctypes chamando diretamente o kernel / DLLs do Windows. Mas, para meus propósitos, essa função é tudo que preciso. Faz validação forte e produz resultados corretos.