当前位置: 首页 > 知识库问答 >
问题:

TypeError:在Python 3中写入文件时,需要类似字节的对象,而不是“str”

薄瑞
2023-03-14

我最近迁移到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

共有3个答案

楚良平
2023-03-14

就像已经提到的那样,您正在以二进制模式读取文件,然后创建一个字节列表。在接下来的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'>
郝原
2023-03-14

您可以使用对字符串进行编码。encode()

示例:

'Hello World'.encode()

正如错误描述的那样,为了将字符串写入文件,需要先将其编码为类似字节的对象,encode()将其编码为字节字符串。

应和光
2023-03-14

您以二进制模式打开了文件:

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中浏览原始文件后,看起来文件未