本文介绍了Ping 的 Python 控制台和文本输出,包括
的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我不知道发生了什么,但是当我打印到控制台或文本文件时,换行符 ( ) 不起作用,而是显示在字符串中.知道如何在控制台和文本文件中避免这种情况吗?
I dont know what is happening, but when I am printing to the console or to a text file, the newline ( ) is not functioning but rather showing in the string. Any idea how to avoid this in both the console and the text file?
我的代码:
import subprocess
hosts_file = open("hosts.txt","r")
lines = hosts_file.readlines()
for line in lines:
line = line.strip()
ping = subprocess.Popen(["ping", "-n", "3",line],stdout = subprocess.PIPE,stderr = subprocess.PIPE)
out, error = ping.communicate()
out = out.strip()
error = error.strip()
output = open("PingResults.txt",'a')
output.write(str(out))
output.write(str(error))
print(out)
print(error)
hosts_file.close()
输出:
b'Pinging 192.168.0.1 with 32 bytes of data:
Request timed out.
Request ti
med out.
Request timed out.
Ping statistics for 192.168.0.1:
Pa
ckets: Sent = 3, Received = 0, Lost = 3 (100% loss),'
b''
b'Pinging 192.168.0.2 with 32 bytes of data:
Request timed out.
Request ti
med out.
Request timed out.
Ping statistics for 192.168.0.2:
Pa
ckets: Sent = 3, Received = 0, Lost = 3 (100% loss),'
b''
b'Pinging 192.168.0.3 with 32 bytes of data:
Request timed out.
Request ti
med out.
Request timed out.
Ping statistics for 192.168.0.3:
Pa
ckets: Sent = 3, Received = 0, Lost = 3 (100% loss),'
b''
b'Pinging 192.168.0.4 with 32 bytes of data:
Request timed out.
Request ti
med out.
Request timed out.
Ping statistics for 192.168.0.4:
Pa
ckets: Sent = 3, Received = 0, Lost = 3 (100% loss),'
b''
b'Pinging 192.168.0.5 with 32 bytes of data:
Request timed out.
Request ti
med out.
Reply from 3.112.3.214: Destination host unreachable.
Ping st
atistics for 192.168.0.5:
Packets: Sent = 3, Received = 1, Lost = 2 (66%
loss),'
b''
主机文件:
192.168.0.1
192.168.0.2
192.168.0.3
192.168.0.4
192.168.0.5
推荐答案
import subprocess
hosts_file = open("hosts.txt","r")
lines = hosts_file.readlines()
hosts_file.close()
for line in lines:
ping = subprocess.Popen(["ping", "-n", "3",line.strip()], stdout=subprocess.PIPE, stderr=subprocess.POPEN)
with open('PingResults.txt', 'ab') as fh:
for line in ping.stdout.readlines():
fh.write(line)
ping.stdout.close()
给我:
[torxed@faparch ~]$ python test.py && cat PingResults.txt
PING 127.0.0.1 (127.0.0.1) 56(84) bytes of data.
64 bytes from 127.0.0.1: icmp_seq=1 ttl=64 time=0.016 ms
64 bytes from 127.0.0.1: icmp_seq=2 ttl=64 time=0.023 ms
64 bytes from 127.0.0.1: icmp_seq=3 ttl=64 time=0.035 ms
--- 127.0.0.1 ping statistics ---
3 packets transmitted, 3 received, 0% packet loss, time 1999ms
rtt min/avg/max/mdev = 0.016/0.024/0.035/0.009 ms
PING 192.168.0.1 (192.168.0.1) 56(84) bytes of data.
--- 192.168.0.1 ping statistics ---
3 packets transmitted, 0 received, 100% packet loss, time 2008ms
这篇关于Ping 的 Python 控制台和文本输出,包括 的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!