今天应领导要求,要对学院获取到的IPv6地址段进行规划,拿到的地址前缀是/48的,打算拿接下来的16位来作为子网地址,于是开始规划子网。16位子网地址,能划分出2^16=65536这么多个子网,要是手工一个一个地列出来,估计我得先预约医院的床位。第一个想到的是用Excel来完成。可是对Excel函数和VBA不熟悉,尝试了半个多小时无果而终,还是自己写个Python脚本吧。
第1版是这样的:
创新互联公司专业为企业提供下花园网站建设、下花园做网站、下花园网站设计、下花园网站制作等企业网站建设、网页设计与制作、下花园企业网站模板建站服务,十多年下花园做网站经验,不只是建网站,更提供有价值的思路和整体网络服务。
i = 0
while i < 65536:
#s存放对应的二进制数的str并去掉前导的'0b'
s = bin( i ).lstrip( '0b' )
#如果s的长度不够16位就在前面补0
while len( s ) < 16:
s = '0' + s
#将s的每4位转换成一个大写的十六进制
h2 = hex( int( s[:4], 2 )).lstrip( '0x' ).upper()
h3 = hex( int( s[4:8], 2 )).lstrip( '0x' ).upper()
h4 = hex( int( s[8:12], 2 )).lstrip( '0x' ).upper()
h5 = hex( int( s[12:16], 2 )).lstrip( '0x' ).upper()
h = h2 + h3 + h4 + h5
print( h )
i += 1
运行的结果不太对:
……
FFEF
FFF
FFF1
……
‘0’去哪了?应该是“FFF0”这个样子才对!哪里出问题了呢?于是开始调试。第一个循环就发现问题了:i=0,bin(i)得到的是‘0b0’,执行完lstrip('0b')之后s变成空了!赶紧查文档找原因。在文档中发现了这么一句话:lstrip( [ chars ] )……The chars argument is not a prefix; rather, all combinations of its values are stripped,百度翻译的结果是“chars参数不是前缀;相反,它的值的所有组合都被剥离”。好吧,我一不小心掉进这个坑了!还是用切片吧,远离lstrip这家伙!
于是改成了第2版:
i = 0
while i < 65536:
#s存放对应的二进制数的str并去掉前导的'0b'
#s = bin( i ).lstrip( '0b' ),千万不要用lstrip,它会去掉0
#应该用切片[2:]来提取‘0b’后面的字符串
s = bin ( i )[2:]
#如果s的长度不够16位就在前面补0
while len( s ) < 16:
s = '0' + s
#将s的每4位转换成一个大写的十六进制
h2 = hex( int( s[:4], 2 ))[2:].upper()
h3 = hex( int( s[4:8], 2 ))[2:].upper()
h4 = hex( int( s[8:12], 2 ))[2:].upper()
h5 = hex( int( s[12:16], 2 ))[2:].upper()
h = h2 + h3 + h4 + h5
print( h )
i += 1
试运行一下,挺好,结果看起来顺眼多了!
(后记:后来知道有相应的管理工具:SolarWinds要钱,PHPIPAM、NIPAP免费功能也很强大。)
当前题目:使用Python3生成IPv6地址格式时遇到的lstrip()与切片的问题
标题来源:http://lswzjz.com/article/geeisd.html