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

基本方法

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

import socket

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

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

import socket

# 查看当前主机名
print('当前主机名称为 : ' + socket.gethostname())

# 根据主机名称获取当前IP
print('当前主机的IP为: ' + socket.gethostbyname(socket.gethostname()))

# Mac下上述方法均返回127.0.0.1
# 通过使用socket中的getaddrinfo中的函数获取真真的IP

# 下方代码为获取当前主机IPV4 和IPV6的所有IP地址(所有系统均通用)
addrs = socket.getaddrinfo(socket.gethostname(),None)

for item in addrs:
  print(item)

# 仅获取当前IPV4地址
print('当前主机IPV4地址为:' + [item[4][0] for item in addrs if ':' not in item[4][0]][0])

# 同上仅获取当前IPV4地址
for item in addrs:
  if ':' not in item[4][0]:
    print('当前主机IPV4地址为:' + item[4][0])
    break

更简单的方法(不用修改代码,还是用 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'))

给TA买糖
共{{data.count}}人
人已赞赏
宝塔

反代破解宝塔?!

2020-9-19 15:10:03

网络

阿里云云解析:DNSSEC设置方法

2021-4-15 11:18:25

0 条回复 A文章作者 M管理员
    暂无讨论,说说你的看法吧
个人中心
购物车
优惠劵
今日签到
搜索