Django - csv export

说明

在访问 Django 接口时候,输出信息
信息保存成为 csv 文件
解决中文乱码问题

方法1

需求

csv 库
codes 库

代码

from django.shortcuts import HttpResponse
from django.http import HttpRequest
import csv
import codecs
import sys

reload(sys)
sys.setdefaultencoding('utf-8')

def csvexport(reqeust):
    response = HttpResponse(content_type='text/csv')
    response['Content-Disposition'] = 'attachment; filename="somefilename.csv"'
    response.write(codecs.BOM_UTF8)
    writer = csv.writer(response)
    line_title = ["user_name", "dept", "user_status"]
    writer.writerow(line_title)
    new_line=[]
    str3 = "阿斯顿发斯蒂芬"
    str1 = "您是不是要找"
    str2 = '翻译此页'
    new_line.append(str3)
    new_line.append(str1)
    new_line.append(str2)
    writer.writerow(new_line)
    return response

简单说明

HttpResponse(content_type=‘text/csv’)

定义了返回的 csv 格式

response[‘Content-Disposition’] = ‘attachment; filename=“somefilename.csv”’

定义了保存的文件名

line_title = [“user_name”, “dept”, “user_status”]

csv 写入例子
csv 默认按行进行写入
每个列就是一个 list 元素
假如需要在 csv 保留空格子, 建议定义为 ’ ’

response.write(codecs.BOM_UTF8)

支持中文的方法

writer.writerow(new_line)

new_line 需要是 list 格式
list 是有序的
writerow 写入一行的意思

return response

返回内存中的信息,浏览器会保存为一个 csv 文件

方法2

需求

unicodecsv 库

代码

from django.shortcuts import HttpResponse
from django.http import HttpRequest
import unicodecsv
import sys

reload(sys)
sys.setdefaultencoding('utf-8')

def tt(reqeust):
    response = HttpResponse(content_type='text/csv')
    response['Content-Disposition'] = 'attachment; filename="somefilename.csv"'
    writer = unicodecsv.writer(response,encoding='utf-8-sig')
    line_title = ["user_name", "dept", "user_status"]
    writer.writerow(line_title)
    new_line=[]
    str3 = "阿斯顿发斯蒂芬"
    str1 = "您是不是要找"
    str2 = '翻译此页'
    new_line.append(str3)
    new_line.append(str1)
    new_line.append(str2)
    writer.writerow(new_line)
    return response
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Terry_Tsang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值