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

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)
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值