这是我的代码:


import imaplib
from email.parser import HeaderParser

conn = imaplib.IMAP4_SSL('imap.gmail.com')
conn.login('example@gmail.com', 'password')
conn.select()
conn.search(None, 'ALL')
data = conn.fetch('1', '(BODY[HEADER])')
header_data = data[1][0][1].decode('utf-8')

在这一点上,我得到错误消息:

AttributeError: 'str'对象没有'decode'属性

Python 3不再有str.decode(),所以我如何解决这个问题?


当前回答

它已经在Python3中解码,直接尝试它应该工作。

其他回答

您正在尝试解码一个已经解码的对象。你有一个str,就不再需要从UTF-8解码了。

只需删除.decode('utf-8')部分:

header_data = data[1][0][1]

从Python 3开始,所有字符串都是unicode对象。

  a = 'Happy New Year' # Python 3
  b = unicode('Happy New Year') # Python 2

上面的说明是一样的。所以我认为你应该删除.decode('utf-8')部分,因为你已经有了一个unicode对象。

使用codecs模块的open()读取文件:

import codecs
with codecs.open(file_name, 'r', encoding='utf-8', errors='ignore') as fdata:

其他答案在某种程度上暗示了这一点,但问题可能出现在期望一个字节对象。在Python 3中,decode在具有bytes类的对象时有效。在解码之前运行encode可能会“修复”问题,但这是一对无用的操作,向上游提示问题。

我的情况可能有点罕见,但我正在使用django和我的项目在本地运行,但当我部署它时,似乎我得到了多个依赖错误,因为我正在做:pip冻结> requirements.txt这样做修复了这个问题:

pip3 freeze > requirements.txt