D-django自定义导出csv文件

import csv
from datetime import timedelta

def download_csv(commend=None):
    response = HttpResponse(content_type='text/csv')
    response['Content-Disposition'] = 'attachment;filename=download.csv'
    response.write('\xEF\xBB\xBF')
    
    writer = csv.writer(response)
    headers = [u"姓名",u"年龄",u"性别"]
    headers = [item.encode('utf8') for item in headers]
    writer.writerow(headers)
  list_user = User.object.filter(**commend).order_by("-datetime_created")
  queryset = list_user.values_list("user__username","age","sex")
  for idx,row in enumerate(queryset):
    values = []
    cnt = 0
    for field in row:
        cnt += 1
        value = ''
      if cnt == 2:
        if int(field) == 0:
          value = u''
        elif int(field) == 1:
          value = u''
      elif field:
          if type(field) is datetime.datetime or type(field) is datetime.date:
              field = field + timedelta(hours=8)
              value = field.strftime("%Y-%m-%d")
          else:
              value = field 
       values.append(unicode(value).encode('utf-8'))
    writer.writerow(values)
  return response

 

转载于:https://www.cnblogs.com/bk770466199/p/7909790.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值