我有一个数据,让我们说
data = [
['header_1', 'header_2'],
['row_1_!', 'row_1_2'],
['row_2_1', 'row_2_2'],
]
我需要将该数据作为.csv文件附件发送到电子邮件中。 我无法将其保存为.csv,然后附加现有的csv - 应用程序正在Googpe App Engine沙箱环境中工作。所以没有文件可以保存。
据我所知,电子邮件附件包含文件名和编码为base64的文件。
我尝试用以下方式制作附件体:
import csv
if sys.version_info >= (3, 0):
from io import StringIO
else:
from StringIO import StringIO
in_memory_data = StringIO()
csv.writer(inmemory_data).writerows(data)
encoded = base64.b64encode(inmemory_data.getvalue())
但结果我通过电子邮件收到了无效的文件2列和3行,但文件中只有一个字符串(参见图片)。 csv_screen
我做错了什么?
答案 0 :(得分:0)
我发现了这个错误。我应该将其转换为 bytearray 而不是编码为 base64 :
encoded = bytearray(inmemory_data.getvalue(), "utf-8")
这样做得很好。