Python获取本机所有网卡ip,掩码和广播地址实例代码
Python  /  管理员 发布于 7年前   175
本文主要研究的是使用Python获取本机所有网卡ip,掩码和广播地址,分享了相关的实例代码,具体介绍如下。
搜了一天,竟然没找到一段合适的代码来获取机器中所有网卡的ip,掩码和广播地址,大部分都是用socket,但是socket通常返回的要不就是内网地址,要不就是公网地址,不能够找到所有地址,真的太忧桑了,决定自己通过ifconfig或ipconfig的返回信息,一步步地过滤了。这次的代码主要用到了正则表达式和subprocess模块,而且为了兼容所有平台(win,linux和mac),也用到了platform来判断系统类型,不说太多,代码如下:
import subprocessimport reimport platformdef find_all_ip(platform): ipstr = '([0-9]{1,3}\.){3}[0-9]{1,3}' if platform == "Darwin" or platform == "Linux": ipconfig_process = subprocess.Popen("ifconfig", stdout=subprocess.PIPE) output = ipconfig_process.stdout.read() ip_pattern = re.compile('(inet %s)' % ipstr) if platform == "Linux": ip_pattern = re.compile('(inet addr:%s)' % ipstr) pattern = re.compile(ipstr) iplist = [] for ipaddr in re.finditer(ip_pattern, str(output)): ip = pattern.search(ipaddr.group()) if ip.group() != "127.0.0.1": iplist.append(ip.group()) return iplist elif platform == "Windows": ipconfig_process = subprocess.Popen("ipconfig", stdout=subprocess.PIPE) output = ipconfig_process.stdout.read() ip_pattern = re.compile("IPv4 Address(\. )*: %s" % ipstr) pattern = re.compile(ipstr) iplist = [] for ipaddr in re.finditer(ip_pattern, str(output)): ip = pattern.search(ipaddr.group()) if ip.group() != "127.0.0.1": iplist.append(ip.group()) return iplistdef find_all_mask(platform): ipstr = '([0-9]{1,3}\.){3}[0-9]{1,3}' maskstr = '0x([0-9a-f]{8})' if platform == "Darwin" or platform == "Linux": ipconfig_process = subprocess.Popen("ifconfig", stdout=subprocess.PIPE) output = ipconfig_process.stdout.read() mask_pattern = re.compile('(netmask %s)' % maskstr) pattern = re.compile(maskstr) if platform == "Linux": mask_pattern = re.compile(r'Mask:%s' % ipstr) pattern = re.compile(ipstr) masklist = [] for maskaddr in mask_pattern.finditer(str(output)): mask = pattern.search(maskaddr.group()) if mask.group() != '0xff000000' and mask.group() != '255.0.0.0': masklist.append(mask.group()) return masklist elif platform == "Windows": ipconfig_process = subprocess.Popen("ipconfig", stdout=subprocess.PIPE) output = ipconfig_process.stdout.read() mask_pattern = re.compile(r"Subnet Mask (\. )*: %s" % ipstr) pattern = re.compile(ipstr) masklist = [] for maskaddr in mask_pattern.finditer(str(output)): mask = pattern.search(maskaddr.group()) if mask.group() != '255.0.0.0': masklist.append(mask.group()) return masklistdef get_broad_addr(ipstr, maskstr): iptokens = map(int, ipstr.split(".")) masktokens = map(int, maskstr.split(".")) broadlist = [] for i in range(len(iptokens)): ip = iptokens[i] mask = masktokens[i] broad = ip & mask | (~mask & 255) broadlist.append(broad) return '.'.join(map(str, broadlist))def find_all_broad(platform): ipstr = '([0-9]{1,3}\.){3}[0-9]{1,3}' if platform == "Darwin" or platform == "Linux": ipconfig_process = subprocess.Popen("ifconfig", stdout=subprocess.PIPE) output = (ipconfig_process.stdout.read()) broad_pattern = re.compile('(broadcast %s)' % ipstr) if platform == "Linux": broad_pattern = re.compile(r'Bcast:%s' % ipstr) pattern = re.compile(ipstr) broadlist = [] for broadaddr in broad_pattern.finditer(str(output)): broad = pattern.search(broadaddr.group()) broadlist.append(broad.group()) return broadlist elif platform == "Windows": iplist = find_all_ip(platform) masklist = find_all_mask(platform) broadlist = [] for i in range(len(iplist)): broadlist.append(get_broad_addr(iplist[i], masklist[i])) return broadlistsystem = platform.system()print(find_all_ip(system))print(find_all_mask(system))print(find_all_broad(system))
总结
以上就是本文关于Python获取本机所有网卡ip,掩码和广播地址实例代码的全部内容,希望对大家有所帮助。感兴趣的朋友可以继续参阅本站其他相关专题,如有不足之处,欢迎留言指出。感谢朋友们对本站的支持!
122 在
学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..123 在
Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..原梓番博客 在
在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..博主 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..1111 在
佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
Copyright·© 2019 侯体宗版权所有·
粤ICP备20027696号