Python 获取本机 IP/MAC(多网卡)

jingleisi 2019-11-03

基本方法

Python获取本机IP地址的一般方法为

import socket

IP = socket.gethostbyname(socket.gethostname())

通过gethostname获取主机名,再用gethostbyname将主机名转换为IP地址。
  那么,问题来了。如果主机有多个网卡/IP,怎样获取某个指定的IP地址呢?
  一个方法是通过 socket.gethostbyname_ex 获取主机IP地址列表,然后遍历列表取得自己需要的IP。

import socket

def GetLocalIPByPrefix(prefix):
    r""" 多网卡情况下,根据前缀获取IP(Windows 下适用) """
    localIP = ''
    for ip in socket.gethostbyname_ex(socket.gethostname())[2]:
        if ip.startswith(prefix):
            localIP = ip
    
    return localIP
    
print(GetLocalIPByPrefix('192.168'))

更简单的方法(不用修改代码,还是用 socket.gethostname 函数),是通过配置 hosts 文件改变IP优先级。
  上面的方法只支持 IPv4,如果要获取 IPv6 信息,参考 socket.getaddrinfo

获取 MAC 地址

  • 用系统库获取单机 mac 地址。
import uuid

def GetMAC():
    r""" 针对单网卡 """
    addr = hex(uuid.getnode())[2:].upper()
    
    return '-'.join(addr[i:i+2] for i in range(0, len(addr), 2))
  • 用第三方库 psutil 打印网络适配器信息。
import psutil

def PrintNetIfAddr():
    r""" 打印多网卡 mac 和 ip 信息 """
    dic = psutil.net_if_addrs()
    for adapter in dic:
        snicList = dic[adapter]
        mac = '无 mac 地址'
        ipv4 = '无 ipv4 地址'
        ipv6 = '无 ipv6 地址'
        for snic in snicList:
            if snic.family.name in {'AF_LINK', 'AF_PACKET'}:
                mac = snic.address
            elif snic.family.name == 'AF_INET':
                ipv4 = snic.address
            elif snic.family.name == 'AF_INET6':
                ipv6 = snic.address
        print('%s, %s, %s, %s' % (adapter, mac, ipv4, ipv6))

跨平台的根据前缀获取 ip 的方法

import psutil

def GetLocalIPByPrefix(prefix):
    r"""
    多网卡情况下,根据前缀获取IP
    测试可用:Windows、Linux,Python 3.6.x,psutil 5.4.x
    ipv4/ipv6 地址均适用
    注意如果有多个相同前缀的 ip,只随机返回一个
    """
    localIP = ''
    dic = psutil.net_if_addrs()
    for adapter in dic:
        snicList = dic[adapter]
        for snic in snicList:
            if not snic.family.name.startswith('AF_INET'):
                continue                
            ip = snic.address
            if ip.startswith(prefix):
                localIP = ip
     
    return localIP     
     
print(GetLocalIPByPrefix('192.168'))
本文出自 walker snapshot

相关推荐

爱文学更爱编程 / 0评论 2020-08-01