为Sendgrid的电子邮件API编码CSV文件

时间:2017-07-05 18:45:10

标签: python email sendgrid

我正在尝试使用R / Python和Sendgrid的电子邮件API构建客户端报告引擎。我可以发送电子邮件,但我需要做的最后一件事就是附上客户的CSV报告。

我尝试过多种方法,包括base64编码文件并将字符串从R写入到python,但不是运气。也就是说,我似乎陷入了这个错误:

  

TypeError:类型'字节'的对象不是JSON可序列化的

我的代码是:

with open('raw/test-report.csv', 'rb') as fd:
     b64data = base64.b64encode(fd.read())
attachment = Attachment()
attachment.content = b64data
attachment.filename = "your-lead-report.csv"
mail.add_attachment(attachment)

令人困惑的是,如果我只是用行

替换b64data
attachment.content = 'TG9yZW0gaXBzdW0gZG9sb3Igc2l0IGFtZXQsIGNvbnNlY3RldHVyIGFkaXBpc2NpbmcgZWxpdC4gQ3JhcyBwdW12'

发送带附件的电子邮件。

作为参考,我一直在使用:

https://github.com/sendgrid/sendgrid-python

kitchen sink tutorial

并且在我的项目的最后一步之前没有任何问题。

任何帮助将不胜感激。值得注意的是,我的力量在R,但我通常可以在互联网的帮助下在python中一起破解事物。

1 个答案:

答案 0 :(得分:2)

在将b64data分配给attachment.content之前,您需要将attachment.content转换为常规字符串。 Sendgrid构建了一个JSON有效负载,它在请求中发送,因此它不知道如何序列化分配给bytestring的值,在这种情况下是str(b64data,'utf-8')

typedef string char*;

string hash_guess = "A";

参考文献: