Python console and text output from Ping including \\n\\r [duplicate]

匿名 (未验证) 提交于 2019-12-03 01:34:02

问题:

This question already has an answer here:

I dont know what is happening, but when I am printing to the console or to a text file, the newline (\n) is not functioning but rather showing in the string. Any idea how to avoid this in both the console and the text file?

My code:

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() 

Output:

b'Pinging 192.168.0.1 with 32 bytes of data:\r\nRequest timed out.\r\nRequest ti med out.\r\nRequest timed out.\r\n\r\nPing statistics for 192.168.0.1:\r\n    Pa ckets: Sent = 3, Received = 0, Lost = 3 (100% loss),' b'' b'Pinging 192.168.0.2 with 32 bytes of data:\r\nRequest timed out.\r\nRequest ti med out.\r\nRequest timed out.\r\n\r\nPing statistics for 192.168.0.2:\r\n    Pa ckets: Sent = 3, Received = 0, Lost = 3 (100% loss),' b'' b'Pinging 192.168.0.3 with 32 bytes of data:\r\nRequest timed out.\r\nRequest ti med out.\r\nRequest timed out.\r\n\r\nPing statistics for 192.168.0.3:\r\n    Pa ckets: Sent = 3, Received = 0, Lost = 3 (100% loss),' b'' b'Pinging 192.168.0.4 with 32 bytes of data:\r\nRequest timed out.\r\nRequest ti med out.\r\nRequest timed out.\r\n\r\nPing statistics for 192.168.0.4:\r\n    Pa ckets: Sent = 3, Received = 0, Lost = 3 (100% loss),' b'' b'Pinging 192.168.0.5 with 32 bytes of data:\r\nRequest timed out.\r\nRequest ti med out.\r\nReply from 3.112.3.214: Destination host unreachable.\r\n\r\nPing st atistics for 192.168.0.5:\r\n    Packets: Sent = 3, Received = 1, Lost = 2 (66% loss),' b'' 

Hosts File:

192.168.0.1 192.168.0.2 192.168.0.3 192.168.0.4 192.168.0.5 

回答1:

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() 

Gives me:

[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 


回答2:

The problem is that you're trying to print out a Python 3 bytes object, which Python cannot automatically convert to a str object, because it can't be certain what the character encoding is.

You'll have to convert it to a string, telling Python what the encoding is, using the bytes object's decode() method...

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.decode('utf-8'))     print(error.decode('utf-8')) hosts_file.close() 


标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!