Django 导出CSV文件产生中文乱码解决方案
初始导出代码
response = HttpResponse(content_type='text/csv') # 定义一个HttpResponse,类型是csv
response['Content-Disposition'] = "attachment;filename=summary.csv" # 定义返回的信息,以附件方式下载及文件名称;
import csv
list_head = ['路径', '摘要']
wr = csv.writer(response)
wr.writerow(list_head)
分析
上述代码导出csv文件为utf-8格式,在window端使用txt或其他文本编辑器打开正常显示,但是使用默认Excel打开该CSV文件则产生中文乱码问题。出现这种乱码原因是常规情况下,windows为拥有BOM的utf-8编码,而使用上述代码导出的csv文件则是不带BOM的utf-8编码,此时会因为BOM问题导致Excel不识别形成乱码。
解决方法
设置response对象为带BOM的utf-8编码格式即可。
response = HttpResponse(content_type='text/csv') # 定义一个HttpResponse,类型是csv
response.charset = 'utf-8-sig' if "Windows" in request.headers.get('User-Agent') else 'utf-8'
response['Content-Disposition'] = "attachment;filename=summary.csv" # 定义返回的信息,以附件方式下载及文件名称;
import csv
list_head = ['路径', '摘要']
wr = csv.writer(response)
wr.writerow(list_head)
|