【发布时间】:2012-03-31 19:19:22
【问题描述】:
在python中将子网与ip地址匹配的简单方法是什么,以便如果ip地址在子网中我可以选择它?
提前致谢。
【问题讨论】:
-
真的不清楚你在问什么。你选择什么,IP还是子网?问题是“我如何判断 IP 地址是否在特定子网中?”还是什么?
在python中将子网与ip地址匹配的简单方法是什么,以便如果ip地址在子网中我可以选择它?
提前致谢。
【问题讨论】:
在 Python 3.3+ 中,您可以使用ipaddress 模块:
>>> import ipaddress
>>> ipaddress.ip_address('192.0.43.10') in ipaddress.ip_network('192.0.0.0/16')
True
如果您的 Python 安装版本早于 3.3,您可以使用 this backport。
如果您想以这种方式评估 很多 个 IP 地址,您可能需要预先计算网络掩码,例如
n = ipaddress.ip_network('192.0.0.0/16')
netw = int(n.network_address)
mask = int(n.netmask)
然后,对于每个地址,用其中之一计算二进制表示
a = int(ipaddress.ip_address('192.0.43.10'))
a = struct.unpack('!I', socket.inet_pton(socket.AF_INET, '192.0.43.10'))[0]
a = struct.unpack('!I', socket.inet_aton('192.0.43.10'))[0] # IPv4 only
最后,你可以简单地检查一下:
in_network = (a & mask) == netw
【讨论】:
in_network 是False。我正在使用模块的端口到 2.6 和 2.7。使用 ipaddr (code.google.com/p/ipaddr-py) 是一样的:为上面的例子产生一个 False。请注意,我直接导入了py 模块文件,而没有运行setup.py,我认为这不是问题。
如果对于给定的 IP,您想从一长串前缀中找到一个前缀,那么您可以实现 longest prefix match。您首先从您的前缀列表中构建一个prefix tree,然后,您遍历树寻找与您的前缀匹配的最远叶子。
听起来很吓人,但也没那么糟糕:)
【讨论】: