两个处理IP好用的Python库ipaddr和netaddr

本文介绍了Python中用于处理IP的两个高效库:ipaddr和netaddr。ipaddr由Google开发,提供了IPv4和IPv6的处理功能,包括IP地址与网段的验证、归属判断等。netaddr库则提供了更丰富的IP地址操作,如掩码转换、IP合并等。这两个库相比IPy具有更好的容错性和功能。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Python中关于IP处理的两个模块

这里介绍的两个处理IP好用的Python库名为:ipaddr和netaddr

顺便提一个不好用的:IPy。上面两个能完全胜任这个库的功能,但这个库容错性不好,常报错。

1.ipaddr简单介绍:

Google开发的IP处理模块,地址:http://pythonhosted.org/ipaddr/

可用pip安装:pip install ipaddr

所有包含的类和方法使用help命令查看:

help(ipaddr)

Class总共分为:BaseIP、IPv4、IPv6
ipaddr.IPv4Network() ipv4网段对象建立
ipaddr.IPv6Network() ipv6网段对象建立
ipaddr.IPAddress(address, version) 单个ipv4地址对象建立

DEMO:

1)判断一个IP地址是否在某个网段内:

>>> import ipaddr
>>> 
>>> ip = ipaddr.IPv4Address("192.168.1.1")
>>> ipNet = ipaddr.IPv4Network("192.168.1.0/23")
>>> print ip in ipNet
True

返回True没问题,若不属于包含关系返回False

2)判断一个网段是否属于另一个网段:

>>> ipNetA = ipaddr.IPv4Network("192.168.1.0/24")
>>> ipNetB = ipaddr.IPv4Network("192.168.0.0/16")
>>> print ipNetA in ipNetB
True

3)判断是否属于内网IP:

>>> ip = ipaddr.IPv4Address("1.1.1.1")
>>> print ip.is_private
False

4)判断是否属于内网网段:

>>> ipNet = ipaddr.IPv4Network("10.123.1.0/24")
>>> print ipNet.is_private
True

5)返回子网中IP个数:

>>> ipNet = ipaddr.IPv4Network("192.168.0.0/16")
>>> print ipNet.numhosts
65536

6)遍历网段中所有IP:

>>> ipNet = ipaddr.IPv4Network("192.168.0.1/32")
>>> for ip in ipNet:
            print isinstance(ip, ipaddr.IPv4Address)
            print str(ip)

True
192.168.0.1

注意,这里遍历时返回的元素是ipaddr.IPv4Address对象,不是一个IP字符串,但可以转换。

7)根据索引访问网段中的某个IP:

>>> ipNet = ipaddr.IPv4Network("192.168.0.0/24")
>>> print str(ipNet[3])
192.168.0.3

2.netaddr介绍

也使用pip安装:pip install netaddr

help命令查看所有类和方法:

help(netaddr)

文档地址:https://netaddr.readthedocs.io/en/latest/

DEMO:

1)掩码转换:

>>> import netaddr
>>> 
>>> ipNetList = netaddr.iprange_to_cidrs("192.168.1.1", "192.168.1.100")
>>> print ipNetList
[IPNetwork('192.168.1.1/32'), IPNetwork('192.168.1.2/31'), IPNetwork('192.168.1.4/30'), IPNetwork('192.168.1.8/29'), IPNetwork('192.168.1.16/28'), IPNetwork('192.168.1.32/27'), IPNetwork('192.168.1.64/27'), IPNetwork('192.168.1.96/30'), IPNetwork('192.168.1.100/32')]

2)合并IP:

>>> ipList = [netaddr.IPAddress("1.1.1.1"), netaddr.IPAddress("1.1.1.2")]
>>> print netaddr.cidr_merge(ipList)
[IPNetwork('1.1.1.1/32'), IPNetwork('1.1.1.2/32')]

3)当然也可以合并网段:

>>> ipList = [netaddr.IPNetwork("1.1.3.0/23"), netaddr.IPNetwork("1.1.0.0/22")]
>>> print netaddr.cidr_merge(ipList)
[IPNetwork('1.1.0.0/22')]

网段和单个IP混合合并也可以。

熟悉ip地址的多种表现形式,理解ip地址,子网掩码,网络地址的涵义。 熟悉不同形式之间的转换,为后续实现arp协议做准备。 第一个任务,根据ip子网掩码获得该ip的网络地址。完成函数: /*根据掩码获取ip地址对应的网络地址*/ uint32 get_netaddr(uint32 ip, uint32 mask); 第二个任务,就是做上述变换的逆变换,将unsigned int 的ip地址变为字符串的形式。完成函数: /*将数据表示的ip地址转为点10进制表示的字符串*/ char* ip2str(uint32 ip, char *ipstr) 第三个任务:完成字符串形式的ip地址,如“192.168.1.2”,转换成32位的ip地址,即转为unsigned int 符号网络字节顺序的32位无符号整数。 将地址设为无符号整数,比设为unsigned char[4]这样的数组,在进行比较操作,与掩码作运算时更方便。完成函数: /*将字符串表示的点10进制表示的ip地址转为数值表示*/ uint32 str2ip(char *ipstr) ; 相关知识 在本任务的src/data/cfg.txt配置文件展示了主机网卡的主要参数:即 ip地址是主机的标识号,mask子网掩码指定该主机属于哪个局域网,gate缺省网关,即负责本局域网主机与外网通信的所有ip包进出的转发。 同一网络的主机间可以进行广播通信,意味着它们之间的数据不需要通过第三方转交,可以直接在链路层实现直接交付。 如果主机要发达的ip包,目标ip与主机不属于同一局域网,意味着无法直接交付,需要通过第三方的路由器进行转发,对主机来说,这个缺省的路由器ip地址就是主机配置参数“缺省网关”指定的值。缺省网关与主机同属于一个局域网,它的任务就是向其他网络转发此网内主机收发的ip包。 编程要求 注意,为便于代码阅读,以及书写简洁。 unsigned char 类型重命名为byte; unsigned short 类型重命名为uint16; unsigned int 类型重命名为uint32. 上述类型通过typedef 定义在datalink_arp.h文件当中。 同时为了便于平台的字节顺序与网络字节顺序的转换,在datalink_arp.h文件中,通过宏定义了对应的函数ntohs,htons,ntohl,htonl前两个针对16位无符号整数,后两个针对32位无符号整数。 研读代码可以看出,ntohs与htons的操作是一样,不同命名也是为了方便理解代码。 上述内容代码在任务目录中可查看复制。 typedef unsigned char byte; typedef unsigned short uint16; typedef unsigned int uint32; typedef int bool; #define true 1 #define false 0 /* 网络字节顺序与本地顺序的转换,对于本地是大端模式的则不需要转换 */ #define htons(x) ((0xff & ((x)>>8)) | ((0xff & (x)) << 8)) #define htonl(x) ((((x)>>24) & 0x000000ff) | (((x)>> 8) & 0x0000ff00) | \ (((x)<<8) & 0x00ff0000) | (((x)<<24) & 0xff000000)) #define ntohs(x) ((0xff & ((x)>>8)) | ( (0xff & (x)) << 8)) #define ntohl(x) ((((x)>>24) & 0x000000ff) | (((x)>> 8) & 0x0000ff00) | \ (((x)<<8) & 0x00ff0000) | (((x)<<24) & 0xff000000)) 实训任务中给出的代码复制到windows平台编译测试时注意使用版本,如果用的是C++,则bool,false,true均为保留字,则需要删除头文件中的定义。 ####测试说明 从文件中按行读取字符串,获得本地网上配置参数,ip,mask,gate。形如: mask : 255. 255. 255. 0 ip: 192 .168. 9. 1 gate: 192. 168. 9. 254 首列以字母开始,以区分不同参数。 该过程由tools.c中的函数实现: void getconfig(char*file, char *ipstr,char *maskstr,char *gatestr) ;
03-22
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值