使用标准 python 包,如果我们提供任何 IPv6 网络地址作为输入,我如何获得接下来的几个 IPv6 网络地址。基本上我想迭代给定的网络地址,并且在每次迭代时它应该递增并获得下一个网络
例如,如果我的起始网络地址是 4001:1::/32,那么在每次迭代时,我希望得到下一个网络地址为 4001:2::/32、4001:3::/32、4001:4: :/32 等等。
>>> inet = iterate_on('4001:1::/32')
>>> next(inet)
4001:2::/32
>>> next(inet)
4001:3::/32
注意:这是我之前关于获取 IPv4 网络的问题。
库ipcalc具有使 IP 地址的数学计算相当容易的例程。但是如果最好不要安装 ipcalc,可以构造一个继承自 ipaddress.IPv6Network 的类。
import ipaddress
class BetterIPv6Network(ipaddress.IPv6Network):
def __add__(self, offset):
"""Add numeric offset to the IP."""
new_base_addr = int(self.network_address) + offset
return self.__class__((new_base_addr, self.prefixlen))
def size(self):
"""Return network size."""
return 1 << (self.max_prefixlen - self.prefixlen)
import itertools as it
network = BetterIPv6Network(u'4001:1::/32')
network_addrs = (network + i * network.size() for i in it.count())
print(next(network_addrs))
print(next(network_addrs))
print(next(network_addrs))
4001:1::/32
4001:2::/32
4001:3::/32
Python 3.4 不接受元组来初始化 ipaddress.IPv6Network。这段代码将解决这个问题。
import ipaddress
class BetterIPv6Network(ipaddress.IPv6Network):
def __add__(self, offset):
"""Add numeric offset to the IP."""
new_base_addr = int(self.network_address) + offset
new_base_addr_str = str(self.__class__(new_base_addr)).split('/')[0]
return self.__class__(
new_base_addr_str + '/' + str(self).split('/')[1])
def size(self):
"""Return network size."""
return 1 << (self.max_prefixlen - self.prefixlen)
本文收集自互联网,转载请注明来源。
如有侵权,请联系[email protected] 删除。
我来说两句