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应该可以正常工作. 总结以上是内存溢出为你收集整理的python – 电子邮件附件保存全部内容,希望文章能够帮你解决python – 电子邮件附件保存所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)