我最近迁移到Python 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:需要类似字节的对象,而不是'str'
错误在最后一行(模式搜索代码)。
我试过使用。decode()
函数,并尝试:
if tmp.find('some-pattern') != -1: continue
-没用。
我能够解决几乎所有的Python
就像已经提到的那样,您正在以二进制模式读取文件,然后创建一个字节列表。在接下来的for循环中,您将字符串与字节进行比较,这就是代码失败的地方。
在将字节添加到列表时解码字节应该可以工作。更改后的代码应如下所示:
with open(fname, 'rb') as f:
lines = [x.decode('utf8').strip() for x in f.readlines()]
字节类型是在Python3中引入的,这就是代码在Python2中工作的原因。在Python 2中,字节没有数据类型:
>>> s=bytes('hello')
>>> type(s)
<type 'str'>
您可以使用对字符串进行编码。encode()
示例:
'Hello World'.encode()
正如错误描述的那样,为了将字符串写入文件,需要先将其编码为类似字节的对象,encode()
将其编码为字节字符串。
您以二进制模式打开了文件:
with open(fname, 'rb') as f:
这意味着从文件读取的所有数据都将作为字节
对象返回,而不是str
。然后不能在包含测试中使用字符串:
if 'some-pattern' in tmp: continue
您必须使用bytes
对象来测试tmp
:
if b'some-pattern' in tmp: continue
或者将'rb'
模式替换为'r'
以文本文件的形式打开文件。
问题内容: 我最近已经迁移到Py 3.5。这段代码在Python 2.7中正常工作: 升级到3.5后,我得到了: 最后一行错误(模式搜索代码)。 我试过使用语句两侧的函数,也尝试过: -无济于事。 我能够很快解决几乎所有的问题,但是这个小小的声明困扰着我。 问题答案: 你以二进制模式打开文件: 这意味着从文件读取的所有数据都作为bytes对象而不是作为对象返回。然后,你不能在容纳测试中使用字符串:
我最近迁移到了Py3.5。这段代码在Python2.7中正常工作: 升级到3.5后,我得到了: 最后一行(模式搜索代码)出错。 我尝试在语句的两侧使用函数,也尝试了: -无济于事。 我能够很快解决几乎所有的2:3问题,但这个小小的声明困扰着我。
以下是尝试使用套接字修改用户提供的输入的代码: 当我执行它并提供输入时,会发生以下错误: 我能做些什么来解决这个问题?
我得到一个“TypeError:需要一个类似字节的对象,而不是'str'”。我在使用StringIO时遇到了一个错误“TypeError:initial_值必须是str或None,而不是bytes”,我在使用Python 3.7。 我也得到这个函数同样的错误。"返回pickle.load(打开(DATA_FILE))"
问题内容: 几年前,我正在使用一个先前提出的问题的代码,但是,我认为这已经过时了。尝试运行代码,我收到上述错误。我仍然是Python的新手,因此无法从类似的问题中得到很多澄清。有人知道为什么会这样吗? 追溯 问题答案: 默认情况下返回stdout或stderr流的对象。这意味着您还需要在针对这些对象的操作中使用对象。使用对象。使用字节文字(注意前缀): 或先解码数据(如果您知道所使用的编码)(通常
问题内容: 我正在尝试使用在Python 2中可以使用的代码在Python 3中打开一个pickle文件,但是现在却给我一个错误。这是代码: 我在其他SO答案上看到,人们在使用并切换以修复它时遇到了这个问题。如果这样做有帮助,我尝试进行试验并得到以下错误: 当我使用和打开文件时,我得到: 所以我也尝试了: 并得到与使用’rb’相同的错误: 问题答案: 在Sublime中浏览原始文件后,看起来文件未