Python实现子网掩码地址与位长的相互转换

某日,使用CentOS7,发现网络配置时,子网掩码需要手动转换;因为CentOS 7的网络配置方式为:

nmcli connection enp4s0 modify ipv4.methord manual ipv4.address "192.168.1.120/24" ipv4.gateway "192.168.1.1" ipv4.dns "223.5.5.5"

其中没有子网掩码的配置项。于是,写一函数,实现子网掩码和位长的相互转换。

一:子网掩码转化为位长:

# coding:utf-8
 
def exchange_mask(mask):
    # 计算二进制字符串中 '1' 的个数
    count_bit = lambda bin_str: len([i for i in bin_str if i=='1'])
 
    # 分割字符串格式的子网掩码为四段列表
    mask_splited = mask.split('.')
 
    # 转换各段子网掩码为二进制, 计算十进制
    mask_count = [count_bit(bin(int(i))) for i in mask_splited]
 
    return sum(mask_count)
 
if __name__ == '__main__':
    print exchange_mask('255.255.0.0')

二:位长转化为子网掩码:

#codint = utf8
 
def exchange_maskint(mask_int):
  bin_arr = ['0' for i in range(32)]
  for i in range(mask_int):
    bin_arr[i] = '1'
  tmpmask = [''.join(bin_arr[i * 8:i * 8 + 8]) for i in range(4)]
  tmpmask = [str(int(tmpstr, 2)) for tmpstr in tmpmask]
  return '.'.join(tmpmask)
 
if __name__ == '__main__':
  print exchange_maskint(24)

下面关于Python的文章您也可能喜欢,不妨参考下:

《Python核心编程 第二版》.(Wesley J. Chun ).[高清PDF中文版] 下载见

零基础如何入门Python

Ubuntu 14.04安装Python 3.3.5 

CentOS 6.5 脚本自动化装 Python2.6升级2.7 

CentOS上源码安装Python3.4 

Ubuntu 14.04下Python数据处理环境搭建 

Python Paramiko模块安装和使用 

《Python开发技术详解》.( 周伟,宗杰).[高清PDF扫描版+随书视频+代码]

在CentOS 6.5上安装Python2.7 

Ubuntu 14.04 LTS下编译安装Open Babel和Python语言绑定

Python常见数据结构整理 

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/3f9a14169853d12ea14d5e54e2a7e3a6.html