加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程开发 > Python > 正文

python – 电子邮件附件保存

发布时间:2020-12-20 13:08:14 所属栏目:Python 来源:网络整理
导读:我试着用附加的pdf文件解析电子邮件 def get_files(poruka): pdfs = [] if poruka.is_multipart(): for part in poruka.get_payload(): if part.get_content_type() == 'application/pdf': data = part.get_payload() temppdf = tempfile.NamedTemporaryFile
我试着用附加的pdf文件解析电子邮件

def get_files(poruka):
    pdfs = []
    if poruka.is_multipart():
        for part in poruka.get_payload():
            if part.get_content_type() == 'application/pdf':
                data = part.get_payload()
                temppdf = tempfile.NamedTemporaryFile('w+b',-1)
                temppdf.write(base64.b64decode(data))
                pdfs.append(temppdf)

    return pdfs

它工作,但在pdfs我有文件实例.我尝试做的是将原始名称的文件保存在名为storage的文件夹中.

当我尝试打开(temppdf,’wb’).write(temppdf.get_payload(decode = True))我得到错误TypeError:强制转换为Unicode:需要字符串或缓冲区,找到实例.

另外如何获取pdfs [0]文件名?

解决方法

第一个问题是您尝试打开文件对象而不是文件名.您可以尝试打开(temppdf.name),但这可能不起作用(不保证跨所有平台).从Python 2.6开始,您可以在 NamedTemporaryFile调用上指定delete = False,然后打开temppdf.name应该可以正常工作.

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读