在输出之前打印 pexpect 是带有 \r\n 而不是实际 CR/LF 输出的单行

printing pexpect before output is a single line with \r\n instead of actual CR/LF output

我会提前道歉,我是 Python3 的新手,并且坚持理解实际输出而不是我期望收到的输出。

这是我的代码:

    import pexpect
    ping = pexpect.spawn('ping -c 5 8.8.8.8')
    result = ping.expect([pexpect.EOF, pexpect.TIMEOUT])
    print(ping.before)

实际输出是以 "b" 开头并添加了 \r\n 的单行,而不是实际换行。

我希望这样:

    PING 8.8.8.8 (8.8.8.8) 56(84) bytes of data.
    64 bytes from 8.8.8.8: icmp_seq=1 ttl=128 time=78.1 ms
    64 bytes from 8.8.8.8: icmp_seq=2 ttl=128 time=76.5 ms
    64 bytes from 8.8.8.8: icmp_seq=3 ttl=128 time=76.2 ms
    64 bytes from 8.8.8.8: icmp_seq=4 ttl=128 time=76.8 ms
    64 bytes from 8.8.8.8: icmp_seq=5 ttl=128 time=77.0 ms

但是我的输出是一大行:

    b'PING 8.8.8.8 (8.8.8.8) 56(84) bytes of data.\r\n64 bytes from 8.8.8.8: icmp_seq=1 ttl=128 time=78.1 ms\r\n64 bytes from 8.8.8.8: icmp_seq=2 ttl=128 time=76.5 ms\r\n64 bytes from 8.8.8.8: icmp_seq=3 ttl=128 time=76.2 ms\r\n64 bytes from 8.8.8.8: icmp_seq=4 ttl=128 time=76.8 ms\r\n64 bytes from 8.8.8.8: icmp_seq=5 ttl=128 time=77.0 ms\r\n\r\n--- 8.8.8.8 ping statistics ---\r\n5 packets transmitted, 5 received, 0% packet loss, time 4004ms\r\nrtt min/avg/max/mdev = 76.214/76.951/78.149/0.683 ms\r\n'

有人知道吗?

这里的问题是您的输出是字节串的形式——在 Python 中也称为 bytes 类型。在与源自应用程序外部的 data/content 进行交互时,经常会遇到此数据类型。本质上,Python 并不确定在尝试解释缓冲区中的数据时使用什么编码标准。 Python 不会尝试猜测它,而是让开发人员决定如何解释字节字符串中包含的原始数据。这允许与每个字符使用多个字节的字符编码系统兼容(例如,UTF-16UTF-32)。然而,这也意味着开发人员必须先将数据从 bytes 转换为 str,然后才能在其应用程序中与此类数据进行交互。

对于您的情况,您应该将数据解释为 UTF-8。为此,您需要将当前的打印行替换为:

print(ping.before.decode('utf-8', 'ignore'))

为了阐明该命令,我们正在与 bytes 对象交互以调用 decode(...) 方法,我们首先提供解码方法和字符编码编解码器我们希望数据被解释为,其次是我们想要使用的错误处理方法的名称。解码的错误处理方法有很多可能的值,但两种常见的方法是 ignorestrict,其中 strict 是默认处理程序。

ignore 处理程序本质上告诉解码方法,如果它遇到一个它不能 interpret/decode 的值,它应该默默地丢弃该值并继续解码剩余的值值。

另一方面,strict 告诉解码方法它应该停止所有处理并引发错误(特别是 UnicodeError) .

您可以在 Codec Error Handling 的 Python 文档页面上阅读有关 encode/decode 错误处理选项的更多信息。