Ping是一种常用的网络诊断工具,它可以测试两台盘算机之间的连通性;
如果您必要监测某个IP地址的连通环境,可以使用Python编写一个Ping监测步调;
本文将先容如何使用Python编写Ping监测步调
首先,必要导入os、sys、time和subprocess模块。此中os和sys模块用于处理文件路径,time模块用于获取当前时间,subprocess模块用于运行Ping下令
- import os
- import sys
- import time
- import subprocess
复制代码 接着,必要设置监测的IP地址和Log文件存储路径
- cur_path = os.path.join(os.path.expanduser('~'), 'Desktop')
- hostname = '192.168.10.1' # IP address
- log_path = cur_path + "\\%s_ping_log.txt" % hostname
复制代码 接着定义一个名为pyping的函数,用于运行Ping下令并返回Ping效果。该函数使用subprocess模块运行ping下令并捕获下令输出。然后,提取Ping效果中的有用信息,并将当前时间添加到效果中。最后,该函数返回一个Ping效果字符串
- def pyping(ipaddress):
- cur_time = time.strftime('%Y_%m_%d-%H:%M:%S', time.localtime(time.time()))
- proc = subprocess.Popen(
- ['ping', '-n', '1', ipaddress],
- stdout=subprocess.PIPE)
- stdout, stderr = proc.communicate()
- ping_ret = '%s, PC:%s' % (cur_time, stdout.decode("gbk").split("\n")[2])
- print(ping_ret)
- return ping_ret
复制代码 接着使用一个无限循环来执行Ping监测,在每次循环中,调用pyping函数来运行Ping下令并获取效果,将效果写入Log文件,并使用time模块耽误一秒钟;
- with open(log_path, "a") as logfile:
- try:
- while True:
- ret_ping = pyping(hostname)
- logfile.write(ret_ping + '\r\n')
- logfile.flush()
- time.sleep(1)
- except KeyboardInterrupt:
- print("程序已停止")
复制代码 最后,将以上三部门代码段组合在一起即可编写一个Ping监测步调;
- # 导入必要的模块
- ```c
- import os # 操作系统模块
- import sys # 系统模块
- import time # 时间模块
- import subprocess # 子进程模块
- # 获取当前用户桌面路径
- cur_path = os.path.join(os.path.expanduser('~'), 'Desktop')
- # IP地址
- hostname = '192.168.10.1'
- # 日志文件路径
- log_path = cur_path + "\\%s_ping_log.txt" % hostname
- # 定义函数,输入IP地址,返回ping测试结果
- def pyping(ipaddress):
- # 获取当前时间
- cur_time = time.strftime('%Y_%m_%d-%H:%M:%S', time.localtime(time.time()))
- # 执行ping指令并获取结果
- proc = subprocess.Popen(
- ['ping', '-n', '1', ipaddress],
- stdout=subprocess.PIPE)
- stdout, stderr = proc.communicate()
- # 解析结果并返回字符串
- ping_ret = '%s, PC:%s' % (cur_time, stdout.decode("gbk").split("\n")[2])
- print(ping_ret)
- return ping_ret
- # 打开日志文件并开始循环ping测试
- with open(log_path, "a") as logfile:
- try:
- while True:
- # 进行ping测试
- ret_ping = pyping(hostname)
- # 将结果写入日志文件
- logfile.write(ret_ping + '\r\n')
- logfile.flush()
- # 等待1秒
- time.sleep(1)
- except KeyboardInterrupt:
- print("程序已停止")
复制代码 免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。 |