[转]f.open用r和rb的区别

f=open(filepath,'r')

修改为

f=open(filepath,'rb')

问题得以解决!

这两个方式的区别在于对‘0x1A’和‘0x0A’的处理,下面转载:

第一,使用'r'的时候如果碰到'0x1A',就会视为文件结束,这就是EOF。使用'rb'则不存在这个问题。即,如果你用二进制写入再用文本读出的话,如果其中存在'0X1A',就只会读出文件的一部分。使用'rb'的时候会一直读到文件末尾。
第二,对于字符串x='abc def',我们可用len(x)得到它的长度为7, 我们称之为换行符,实际上是'0X0A'。当我们用'w'即文本方式写的时候,在windows平台上会自动将'0X0A'变成两个字符'0X0D','0X0A',即文件长度实际上变成8.。当用'r'文本方式读取时,又自动的转换成原来的换行符。如果换成'wb'二进制方式来写的话,则会保持一个字符不变,读取时也是原样读取。所以如果用文本方式写入,用二进制方式读取的话,就要考虑这多出的一个字节了。'0X0D'又称回车符。


linux下不会变。因为linux只使用'0X0A'来表示换行。

转:https://blog.csdn.net/wxl2578/article/details/51511401

原文地址:https://www.cnblogs.com/tlmn2008/p/10304038.html