python 脚本之 IP地址探测

本文介绍两种批量检测网络连通性的方法,一种是通过fping命令扫描IP地址段,另一种是利用Scapy库发送ARP请求探测局域网内活跃设备。文章详细展示了如何用Python实现这两种方法,并提供了完整的代码示例。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

#第一种方法
#!/usr/bin/env python #_*_ coding:utf8 _*_ #### 该脚本需要使用fping命令 如果没有安装需要提前安装fping #### yum install fping import os ip = "10.10.0.1/24" ips = ["10.10.0.1/24", "192.16.17.27/24"] # 需要查询的IP的地址段状态的输入列表 iplist = 'iplist' # 存储IP的文件名 path = os.path.dirname(os.path.abspath(__file__)) #得到当前文件夹路径 sh_path = os.path.join(path, iplist) #组合文件名和路径 iplists = [] #存储IP的临时文件的列表 ip_dic = {} #存储ip和ip状态的字典 例如:'10.101.0.185': 'unreachable' '10.101.0.50': 'alive' #执行fping命令来获取,一个段的所有IP的分配情况 for i in range(len(ips)): list_name = sh_path + str(i) #得到当前存储IP的文件名 os.system('> %s;fping -g %s >> %s' % (list_name, ips[i], list_name)) iplists.append(list_name) with open(list_name) as f: for data in f.readlines(): temp = data.strip('\n') ip_dic[temp.split(" ")[0]] = temp.split(" ")[2]
#第二种方法
#!/usr/bin/env python2.7
# -*- coding: utf-8 -*-
   
 
from scapy.all import srp, Ether, ARP, conf   #要提前安装 pip install scapy包
lan = '10.10.10.0/24'   #给出想要查询的IP地址段
ans, unans = srp(Ether(dst="FF:FF:FF:FF:FF:FF")/ARP(pdst=lan), timeout=2)
for snd, rcv in ans:  #打印出MAC和IP
    cur_mac = rcv.sprintf("%Ether.src%")
    cur_ip  = rcv.sprintf("%ARP.psrc%")
    print cur_mac + ' - ' +cur_ip

  

转载于:https://www.cnblogs.com/kuku0223/p/9043465.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值