TypeError: 在Python3中向文件写入时,需要一个类似字节的对象,而不是'str'。
我最近迁移到了Py 3.5。 这段代码在Python 2.7中可以正常工作。
with open(fname, 'rb') as f:
lines = [x.strip() for x in f.readlines()]
for line in lines:
tmp = line.strip().lower()
if 'some-pattern' in tmp: continue
# ... code
升级到3.5后,我得到了。
TypeError: a bytes-like object is required, not 'str'
在最后一行(模式搜索代码)出现错误。
我试着在语句的两边使用.decode()
函数,也试过。
if tmp.find('some-pattern') != -1: continue
- `- 无效。
我能够迅速解决几乎所有2:3的问题,但这一小段话让我很不爽。
497
3
你是以二进制模式打开的文件。
这意味着所有从文件中读取的数据都以
bytes
对象的形式返回,而不是str
。这样你就不能在遏制测试中使用字符串。你必须使用一个
bytes
对象来测试tmp
。或者通过将
'rb'
模式替换为'r'
,将文件作为文本文件打开。就像已经提到的,你正在以二进制模式读取文件,然后创建一个字节列表。在你下面的for循环中,你正在比较字符串和字节,这就是代码失败的地方。
在添加到列表中的同时对字节进行解码应该是可行的。修改后的代码应该如下。
bytes 类型是在 Python 3 中引入的,这就是为什么你的代码在 Python 2 中可以工作。在Python 2中,没有字节的数据类型。
为这个小例子。 输入socket
前面加上"b"。 'GET http://www.py4inf.com/code/romeo.txt HTTP/1.0\n\n'。 解决了我的问题