Python 获取 Windows 设备信息笔记

1. 基础实现(常用但有局限)

在 Python 中,我们通常使用 uuidsocket 库来快速获取设备网络标识。

python 复制代码
import uuid
import socket

# 获取 MAC 地址 (基于 getnode)
mac = uuid.UUID(int=uuid.getnode()).hex[-12:].upper()

# 获取主机名与 IP
hostname = socket.getfqdn(socket.gethostname())
ip_addr = socket.gethostbyname(hostname)

print(f"MAC: {mac}")
print(f"Host: {hostname}")
print(f"IP: {ip_addr}")

2. 核心问题:为什么 MAC 地址会变化?

在安装了 VMware 或 VirtualBox 等虚拟机软件后,原本稳定的脚本可能会输出不同的 MAC 地址。原因如下:

A. 虚拟网卡的干扰

uuid.getnode() 的原理是获取硬件地址。安装虚拟机后,系统会增加多个虚拟网卡(如 VMnet1, VMnet8)。

  • 多网卡竞争:脚本可能会随机抓取到虚拟网卡的 MAC 地址,而非物理网卡(WiFi/以太网)的地址。
  • 优先级变动:当物理网卡断开(如拔掉网线)时,系统可能会将虚拟网卡作为默认接口返回。

B. 随机地址回退机制

根据 RFC 4122 协议,如果 uuid.getnode() 无法获取到真实硬件地址,它会随机生成一个 48 位的值。

  • 识别方法:检查 MAC 地址的第一个字节。如果其最低有效位为 1(即第二个字符为 1, 3, 5, 7, 9, B, D, F 之一),说明这是一个随机地址。

3. 更稳定的替代方案:硬件 UUID

如果目的是为了唯一识别设备(如软件授权、指纹识别),建议获取 Windows 主板的 UUID,这不会受网卡变动或虚拟机的影响。

推荐方案 (Python 调用 WMIC)

python 复制代码
import subprocess

def get_windows_uuid():
    try:
        # 执行 wmic 命令获取主板唯一标识
        cmd = 'wmic path win32_computersystemproduct get uuid'
        uuid_str = subprocess.check_output(cmd, shell=True).decode().split('\n')[1].strip()
        return uuid_str
    except Exception as e:
        return f"Error: {e}"

print(f"设备硬件 UUID: {get_windows_uuid()}")

4. 总结与建议

标识符 稳定性 适用场景 风险
MAC 地址 一般 网络通信、局域网识别 易受虚拟机、多网卡、随机化影响
主机名 内部网络标识 用户可随时更改
硬件 UUID 极高 软件授权、设备指纹 需系统权限(通常 cmd 即可)

💡 笔记提示:

  • 在 Windows 上运行 Python 脚本时,确保已将 Python 添加至系统变量 PATH
  • 如果必须获取物理网卡的 MAC,建议使用 psutil 库遍历所有网卡并过滤掉包含 "VMware" 或 "Virtual" 字样的接口。

需要我帮你补充如何用 psutil 过滤虚拟网卡的具体代码吗?

相关推荐
微刻时光1 小时前
影刀RPA:For循环与ForEach循环深度解析与实战指南
人工智能·python·低代码·自动化·rpa·影刀实战
KIHU快狐2 小时前
快狐KIHU|110寸壁挂触控一体机G+G电容屏安卓系统汽车展厅查询展示
android·python·汽车
斯维赤2 小时前
每天学习一个小算法:快速排序
java·python·学习·算法·排序算法
xiaoshuaishuai82 小时前
C# Submodule 避坑指南
服务器·数据库·windows·c#
2501_914245932 小时前
C#怎么使用属性Property C#自动属性和完整属性的区别get set怎么用【基础】
jvm·数据库·python
deephub2 小时前
LLM 幻觉的架构级修复:推理参数、RAG、受约束解码与生成后验证
人工智能·python·大语言模型·ai幻觉
山半仙xs2 小时前
基于卡尔曼滤波的人脸跟踪
人工智能·python·算法·计算机视觉
kronos.荒3 小时前
动态规划——零钱兑换(python)
python·动态规划
2401_837163893 小时前
CSS如何实现网页打印样式优化_利用@media print重写布局
jvm·数据库·python