django生成CSV文件

生成CSV和Excel文件:
有时候我们做的网站,需要将一些数据导出到文件中以方便统计,在导出文件类型中生成CSV文件或者是Excel文件是常用的方式,导出的CSV文件或者Excel文件将以附件的方式下载下来,以下将讲解如何生成CSV文件。

生成小的CSV文件:我们用Python内置的csv模块来处理csv文件,并且使用HttpResponse来将csv文件返回回去,首先来介绍一下把数据写入到CSV文件的一种方法:

  import csv

  with open(‘abc.csv‘) as fp:

    writer = csv.writer(fp)
    writer.writerow([‘name‘, ‘age‘, ‘gender‘])
    writer.writerow([‘xdm‘, 20, ‘男‘])
使用这种方法就可以把两行数据写入到abc.csv文件中,类似的,我们想要在响应中生成CSV文件,可以把HttpResponse对象类比成上面的文件句柄fp,这样在写入数据的时候,就可以把数据写入到HttpResponse对象中。

具体写法如下:

  import csv
  from django.http import HttpResponse

  def csv_view(request):
    # 设置响应的content_type,表明响应的是CSV文件
    response = HttpResponse(content_type=‘text/csv‘)

    # 设置响应头,描述生成的CSV文件
    response[‘Content-Disposition‘] = ‘attachment; filename="somefilename.csv"‘

    # 使用CSV模块,把响应体content封装到类似文件句柄内,这样写入的内容都会被写入到response.content之中
    writer = csv.writer(response)

    # 以行为单位写入数据
    writer.writerow([‘username‘, ‘age‘, ‘height‘, ‘weight‘])
    writer.writerow([‘zhiliao‘, ‘18‘, ‘180‘, ‘110‘])

    # 把响应内容返回
    return response

总结上面的代码,我们在初始化HttpResponse的时候,指定了Content-Type为text/csv,这将告诉浏览器,这是一个csv格式的文件而不是一个HTML格式的文件,如果用默认值,默认值就是html,那么浏览器将把csv格式的文件按照html格式输出,这肯定不是我们想要的。
第二个我们还在response中添加一个Content-Disposition头,这个东西是用来告诉浏览器该如何处理这个文件,我们给这个头的值设置为attachment;,那么浏览器将不会对这个文件进行显示,而是作为附件的形式下载,第二个filename="somefilename.csv"是用来指定这个csv文件的名字。第三我们使用csv模块的writer方法,将相应的数据写入到response中。

在实际使用中我们还可以将csv格式的文件定义成模板,然后使用Django内置的模板系统,并给这个模板传入一个Context对象,这样模板系统就会根据传入的Context对象,生成具体的csv文件。示例代码如下:

使用模板生成csv文件:

模板文件,在django项目的templates文件夹中定义一个模板文件,示例代码如下:
定义一个名为abc.txt的模板:
  {% for row in rows %}{{row.0}},{{row.1}},{{row.2}}
  {% endfor %}

然后编写视图函数如下:
  from django.template import loader
  from django.http import HttpResponse
  def template_csv_view(request):
    resp = HttpResponse(content_type=‘text/csv‘)
    resp[‘Content-Disposition‘] = ‘attachment;filename="abc.csv"‘
    # 加载模板
    template = loader.get_template(‘abc.csv‘)
    context = {
      ‘rows‘: [
        [‘name‘, ‘age‘, ‘gender‘],
        [‘xdm‘, 19, ‘男‘],
        ]
      }
    # 把数据渲染到模板上
    content = template.render(context)
    resp.content = content
    return resp

以上的例子是生成的一个小的csv文件,使用HttpResponse生成CSV文件,实际上服务器在生成CSV文件的时候服务器会把CSV文件完全生成之后返回。这样如果想要生成大型的csv文件,那么以上方式将有可能会发生超时的情况(服务器要生成一个大型csv文件,需要的时间可能会超过浏览器默认的超时时间)。此时如果我们要生成大型CSV文件,这时候我们可以借助另外一个类,叫做StreamingHttpResponse对象,这个对象是将响应的数据作为一个流返回给客户端,而不是作为一个整体返回。

生成大型的csv文件

  from django.http import JsonResponse, StreamingHttpResponse
  def large_csv_view(request):
    resp = StreamingHttpResponse(content_type=‘text/csv‘)
    resp[‘Content-Disposition‘] = ‘attachment;filename="large.csv"‘
    content = ("name{},age{},gender{}\n".format(row, row, row) for row in range(1000000))
    resp.streaming_content = content
    return resp

关于StreamingHttpResponse
  这个类是专门用来处理流数据的。使得在处理一些大型文件的时候,不会因为服务器处理时间过长而到时连接超时。这个类不是继承自HttpResponse,并且跟HttpResponse对比有以下几点区别:

  这个类没有属性content,相反是streaming_content。
  这个类的streaming_content必须是一个可以迭代的对象。
  这个类没有write方法,如果给这个类的对象写入数据将会报错。
注意:StreamingHttpResponse会启动一个进程来和客户端保持长连接,所以会很消耗资源。所以如果不是特殊要求,尽量少用这种方法。

原文地址:https://www.cnblogs.com/limaomao/p/9490575.html

时间: 2024-10-25 19:49:31

django生成CSV文件的相关文章

django 生成csv文件

import csv from django.http import HttpResponse # Number of unruly passengers each year 1995 - 2005. In a real application # this would likely come from a database or some other back-end data store. UNRULY_PASSENGERS = [146,184,235,200,226,251,299,27

使用commons-csv生成.csv文件

做个代码笔记,方便以后看. commons-csv-1.1.jar的源码:https://github.com/apache/commons-csv CsvFileBuilder.java类 package com.huihui.main; import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.ArrayList; import java.util.List; im

记一次java生成csv文件乱码的解决过程 (GB2312编码)

系统:win7 (格式:中文(简体,中国)) 工具:Eclipse (默认编码utf-8) 服务两个:[restful接口]  和 [服务*** server]. 场景:[服务*** server]多次调用[restful接口],每次[restful接口]会返回一个生成好的csv文件内容.[服务*** server]将每次[restful接口]返回的csv内容保存成一个csv文件.并将生成的多个csv文件打包成一个zip压缩包. [restful接口]:根据一组数据生成csv文件 1. java

POI以SAX方式解析Excel2007大文件(包含空单元格的处理) Java生成CSV文件实例详解

http://blog.csdn.net/l081307114/article/details/46009015 http://www.cnblogs.com/dreammyle/p/5458280.html . Office2007与Office Open XML 在Office 2007之前,Office一直都是以二进制位的方式存储,但这种格式不易被其它软件拿来使用,在各界的压力下,MicroSoft于2005年发布了基于XML的ooxml开放文档标准.ooxml的xml schema强调减

Java生成CSV文件实例详解

本文实例主要讲述了Java生成CSV文件的方法,具体实现步骤如下: 1.新建CSVUtils.java文件: package com.saicfc.pmpf.internal.manage.utils; import java.io.BufferedWriter; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.FileOutputS

php服务器端生成csv文件

/** * 将数组动态输出至 csv 文件[服务器端生成文件] * @param array $data 二维数组 * @param string $filename 文件名 */ function writeCsv($data, $filename = 'file.csv') { $fp = fopen($filename, 'w'); foreach ($data as $fields) { fputcsv($fp, $fields); } fclose($fp); } php服务器端生成c

PHP 生成.csv 文件并下载到浏览器

最近做了一个项目需要把订单的信息显示出来,并且能够把相关信息放到一个.csv 文件中,下载到浏览器.首先我要说明的是.csv 文件,PHP 有专门的函数去解析该类型的文件,相关函数大家可以去官网查看.注意.csv 文件内容的编码格式是gbk格式的,所以有必要对字符格式进行转码.文件的样式如下. 一.首先要定义header 头 // 输出Excel文件头,可把user.csv换成你要的文件名 header ( 'Content-Type: application/vnd.ms-excel' );

java将数据生成csv文件

1,httpRequest接口触发进程[或者可以换成其他方式触发] /** * 出入库生成CSV文件 * @param req * @param params * @return */@RequestMapping(value = "explanCsvFileToOrder")ResponseMessage explanCsvFileToOrder(HttpServletRequest req, @RequestParam Map<String, String> param

java生成CSV文件

内容简介 本文内容使用java实现数据生成CSV文件,有关CSV文件知识请参考:CSV (逗号分隔值文件格式) 实现代码(仅供参考,请根据实现情况来修改) /** * 坐标点参数实体类 */ public class PointsParamDto { /** * 坐标id(由1开始,累加1,这样的:1,2,3,4,5...) */ private String pointId; /** * X 坐标点 */ private String x; /** * X 坐标点 */ private Str