Django 导出CSV文件产生中文乱码解决方案

您所在的位置:网站首页 csv导入excel中文乱码 Django 导出CSV文件产生中文乱码解决方案

Django 导出CSV文件产生中文乱码解决方案

#Django 导出CSV文件产生中文乱码解决方案| 来源: 网络整理| 查看: 265

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)


【本文地址】


今日新闻


推荐新闻


CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3