gpt4 book ai didi

django - 从 django 返回一个用 UTF-8 编码的 csv 和 BOM

转载 作者:行者123 更新时间:2023-12-04 18:05:18 27 4
gpt4 key购买 nike

我正在尝试输出用户可以用 excel 打开的 CSV 文件。我已经用 UTF-8 编码了所有字符串,但是当我用 excel 打开文件时,我看到了 jibrish。只有在使用 BOM 将文件转换为 UTF-8(在 Windows 上使用 notepad++)后,我才能正确显示内容。

我正在遵循 docs 中的这种模式:

def render_to_csv(self, request, qs): 
response = HttpResponse(content_type='text/csv')
response['Content-Disposition'] = 'attachment; filename="test.csv"'

writer = csv.writer(response, delimiter=',')

for row in qs.values_list(*self.fields_to_export):
writer.writerow([unicode(v).encode('utf-8') if v is not None else '' for v in row])

return response

BOM 在哪里适合所有这些?

顺便说一句,有 similar questions在 SO 上,但不幸的是没有人回答。

编辑

以@Alastair McCormack 为基础,我最终在文件开头明确添加了 BOM 字符。唯一的区别是我使用了编解码器包而不是硬编码字节。感觉很尴尬,但诀窍!
import codecs

def render_to_csv(self, request, qs):
...
response.write(codecs.BOM_UTF8)
...
return response

最佳答案

在写入数据之前,将 UTF-8 BOM 添加到响应对象:

def render_to_csv(self, request, qs): 
response = HttpResponse(content_type='text/csv')
response['Content-Disposition'] = 'attachment; filename="test.csv"'

# BOM
response.write("\xEF\xBB\xBF")

writer = csv.writer(response, delimiter=',')

关于django - 从 django 返回一个用 UTF-8 编码的 csv 和 BOM,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30288666/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com