Python&Excel批量pingIP地址

问题:

作为一个电气工程师(PLC),当设备掉线的时候,需要用ping工具来检查网线物理层是否可靠连接,当项目体量过大时,就不能一个手动输入命令了。

解决方案一:

使用CMD命令

复制代码
for /L %d in (1,1,255) do ping 192.168.1.%d

这是一个循环,第一个"1"表示从192.168.1.1开始;

第二个"1"代表步距为1,第一次执行完之后下一个就是192.168.1.2,每次递增1;

第三个"255"代表结束地址,会把192.168.1.255ping完停止。

不足之处

如果碰到下方这种情况,会很尴尬。

解决方案二:

使用Python代码配合Excel表格

利用Python的便捷性我们可以很快编程出来功能代码!

python 复制代码
import os


def popen(address):
    """该方法会调用ping命令,并将返回的信息存储到变量file中,完成后打印。"""
    file = os.popen(f"ping {address}")
    print(file.read())


"""将Excel复制的地址粘贴到下方列表内"""
address_list = ["192.168.10.13",
                "192.168.10.23",
                "192.168.10.33",
                "192.168.10.43",
                "192.168.10.53",
                "192.168.10.63",
                "192.168.10.73",
                "192.168.10.83",
                "192.168.10.93"
                ]

for temp in address_list:
    """遍历列表内的元素,交给popen方法"""
    popen(temp)

利用Excel的快速填充功能可以省去我们手动输入地址的烦恼!(表格模板

B列蓝色单元格可以输入要ping的地址,可以利用Excel的快速填充来提高效率,地址间可以留空;

D列单元格对地址进行格式化,地址算字符串,所以要加双引号;

E2单元格为拼接号的地址,直接复制到address_list变量内即可。

运行结果

还可以通过字符串匹配 "已接收 = 4" 即网络没有问题的添加到ok_list中,将网络畅通的设备地址最后打印出来。

结尾

最后祝大家永远都用不着这个!

相关推荐
XiYang-DING17 分钟前
【Java EE】TCP—延时应答
网络·tcp/ip·java-ee
小白学大数据28 分钟前
深度探索:Python 爬虫实现豆瓣音乐全站采集
开发语言·爬虫·python·数据分析
用户67570498850228 分钟前
Celery 太重了?这可能是你一直在找的 asyncio 任务队列
后端·python·消息队列
Cloud_Shy61829 分钟前
Python 数据分析基础入门:《Excel Python:飞速搞定数据分析与处理》学习笔记系列(第十一章 Python 包跟踪器 下篇)
前端·后端·python·数据分析·excel
程序员榴莲30 分钟前
网络编程入门 Python Socket 实现一个简单的用户认证系统
服务器·网络·python
知识分享小能手39 分钟前
Flask入门学习教程,从入门到精通, 认识Flask路由 — 知识点详解 (2)
python·学习·flask
AI棒棒牛39 分钟前
YOLO26改进创新 | 全网首发!VECA弹性核心注意力重塑全局建模,线性复杂度增强检测骨干,嘎嘎创新!
python·yolo·目标检测·yolo26·主干改进
甲方大人请饶命42 分钟前
Java-网络编程和反射
网络
DFT计算杂谈42 分钟前
VASP新手入门: IVDW 色散修正参数
linux·运维·服务器·python·算法
Oll Correct1 小时前
实验二十五:从IPv4向IPv6过渡所使用的隧道技术
网络·笔记