c语言如何生成csv文件格式,生成 csv 文件「建议收藏」

c语言如何生成csv文件格式,生成 csv 文件「建议收藏」生成CSV文件:有时候我们做的网站,需要将一些数据,生成有一个CSV文件给浏览器,并且是作为附件的形式下载下来。以下将讲解如何生成CSV文件。生成小的CSV文件:这里将用一个生成小的CSV文件为例,来把生成CSV文件的技术要点讲到位。我们用Python内置的csv模块来处理csv文件,并且使用HttpResponse来将csv文件返回回去。示例代码如下:代码解释…

大家好,又见面了,我是你们的朋友全栈君。

生成CSV文件:

有时候我们做的网站,需要将一些数据,生成有一个 CSV 文件给浏览器,并且是作为附件的形式下载下来。以下将讲解如何生成 CSV 文件。

生成小的CSV文件:

这里将用一个生成小的 CSV 文件为例,来把生成 CSV 文件的技术要点讲到位。我们用 Python 内置的 csv 模块来处理 csv 文件,并且使用 HttpResponse 来将 csv 文件返回回去。示例代码如下:

c480dd2195de

代码解释:

1. 在初始化 HttpResponse 的时候,指定了 Content-Type 为 text/csv ,这将告诉浏览器,这是一个 csv 格式的文件而不是一个 HTML 格式的文件,如果用默认值,默认值就是 html ,那么浏览器将把 csv 格式的文件按照 html 格式输出,这肯定不是我们想要的。

2. 第二个我们还在 response 中添加一个 Content-Disposition 头,这个东西是用来告诉浏览器该如何处理这个文件,我们给这个头的值设置为 attachment; ,那么浏览器将不会对这个文件进行显示,而是作为附件的形式下载,第二个 filename=”somefilename.csv” 是用来指定这个 csv 文件的名字。

3. 使用 csv 模块的 writer 方法,将相应的数据写入到 response 中。

将 csv 文件定义成模板:

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

模板文件:

c480dd2195de

视图函数:

c480dd2195de

生成大的CSV文件:

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

c480dd2195de

c480dd2195de

这里我们构建了一个非常大的数据集 rows ,并且将其变成一个迭代器。然后因为 StreamingHttpResponse 的第一个参数只能是一个生成器,因此我们使用圆括号 (writer.writerow(row) for row in rows) ,并且因为我们要写的文件是 csv 格式的文件,因此需要调用 writer.writerow 将 row 变成一个 csv 格式的字符串。而调用 writer.writerow 又需要一个中间的容器,因此这里我们定义了一个非常简单的类 Echo ,这个类只实现一个 write 方法,以后在执行 csv.writer(pseudo_buffer) 的时候,就会调用 Echo.writer 方法。

注意: StreamingHttpResponse 会启动一个进程来和客户端保持长连接,所以会很消耗资源。所以如果不是特殊要求,尽量少用这种方法。

关于StreamingHttpResponse:

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

1. 这个类没有属性 content ,相反是 streaming_content 。

2. 这个类的 streaming_content 必须是一个可以迭代的对象。

3. 这个类没有 write 方法,如果给这个类的对象写入数据将会报错。注意: StreamingHttpResponse 会启动一个进程来和客户端保持长连接,所以会很消耗资源。所以. ,_2. 这个类的 streaming_content 必须是一个可以迭代的对

3. 这个类没有 write 方法,如果给这个类的对象写入数意: StreamingHttpResponse 会启动一个进程来和客户端如果不是特殊要求,尽量少用这种方法。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/162508.html原文链接:https://javaforall.net

(0)
上一篇 2022年7月20日 下午11:36
下一篇 2022年7月20日 下午11:46


相关推荐

  • linux常用的20个命令面试_linux常用命令详解pdf

    linux常用的20个命令面试_linux常用命令详解pdf什么是linux多用户,多任务,支持多线程和多CPU的操作系统linux的应用领域:免费,稳定,高效的,一般运行在大型服务器上用xshell连接虚拟机的步骤:1.setup设置虚拟机IP为10.10.10.10重启网卡:servicenetworerestart2.在Windows系统打开网络和共享中心,更改适配器设置,把vmnet1的ipv4的IP改成10.10.10.13.打开xshell,输入ssh10.10.10.10/根目录:一般根目录下只存放目录,有且只有一个根目

    2026年2月21日
    10
  • linux使用ps命令查看和控制进程_使用ps命令得到当前进程

    linux使用ps命令查看和控制进程_使用ps命令得到当前进程ps命令Linuxps(英文全拼:processstatus)命令用于显示当前进程的状态,类似于windows的任务管理器查看所有进程ps-A显示所有进程信息,连同命令行ps-

    2022年7月30日
    10
  • mybatis trim标签

    mybatis trim标签mybatis的trim标签一般用于动态sql语句中去除多余的and关键字,逗号等以下是trim标签中涉及到的属性:属性描述prefix给sql语句拼接的前缀suffix给sql语句拼接的后缀prefixOverrides去除前缀suffixOverrides去除后缀案例trim实现insert into ()values()<insert id=”insert” parameterType=”InfoStudent”> .

    2022年8月8日
    14
  • STM32移植uIP

    STM32移植uIP文件说明 这是 uIP1 0 源码文件 apps 是作者写好的应用程序 demo doc 是一些文档 lib 里面只有一个文件是内存申请与释放函数的接口 uip 是 tcp ip 的协议栈了 unix 是与外部的接口 我们移植也主要去改这些文件 说一下一眼看不出作用的文件 lc h lc addrlabels h lc switch h psock c ps

    2026年3月26日
    2
  • css3 flex布局的使用 图片文字垂直居中排列 图文混排垂直居中 display:flex「建议收藏」

    css3 flex布局的使用 图片文字垂直居中排列 图文混排垂直居中 display:flex「建议收藏」遇到的问题在实际工作的过程中经常遇到图片文字的混排,需要图片与一段文字垂直居中,这个实现方法以前一直非常复杂,而flex是解决这个问题比较好的办法;css代码display:flex;flex的是Flexible的缩写,意为弹性。可以在单行或者多行的盒状模型中提供很好的灵活性,所以它也是自适应友好的。图文混排垂直居中基本用法用flex实现文字和图片在同一行的时候的垂…

    2022年6月9日
    105
  • CFAR原理详解及其matlab代码实现

    CFAR原理详解及其matlab代码实现雷达 目标检测

    2026年3月18日
    2

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号