想在文本模式打开的文件中写入原始的字节数据
将字节数据直接写入文件的缓冲区即可
>>> import sys
>>> sys.stdout.write(b'Hello\n')
Traceback (most recent call last):
File "", line 1, in
TypeError: must be str, not bytes
>>> sys.stdout.buffer.write(b'Hello\n')
Hello
5
>>>
类似的,能够通过读取文本文件的buffer 属性来读取二进制数据
I/O 系统以层级结构的形式构建而成。文本文件是通过在一个拥有缓冲的二进制模式文件上增加一个Unicode 编码/解码层来创建。buffer 属性指向对应的底层文件。如果你直接访问它的话就会绕过文本编码/解码层。
默认情况下,sys.stdout 总是以文本模式打开的。但是如果在写一个需要打印二进制数据到标准输出的脚本的话,可以使用上面演示的技术来绕过文本编码层。
J2SE 8的输入输出--读取/写入文本文件和读取/写入二进制数据
读取/写入文本文件 // 1. 文本输入 // (1) 短小文本直接转入字符串 String string = new String(Files.readAllBytes(Paths.get(&quo ...
《python解释器源码剖析》第8章--python的字节码与pyc文件
8.0 序 我们日常会写各种各样的python脚本,在运行的时候只需要输入python xxx.py程序就执行了.那么问题就来了,一个py文件是如何被python变成一