最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501
当前位置: 首页 - 科技 - 知识百科 - 正文

在Python的Django框架中用流响应生成CSV文件的教程

来源:懂视网 责编:小采 时间:2020-11-27 14:33:13
文档

在Python的Django框架中用流响应生成CSV文件的教程

在Python的Django框架中用流响应生成CSV文件的教程:在Django里,流式响应StreamingHttpResponse是个好东西,可以快速、节省内存地产生一个大型文件。 目前项目里用于流式响应的一个是Eventsource,用于改善跨系统通讯时用户产生的慢速的感觉。这个不细说了。 还有一个就是生成一个大的csv文件。 当Djan
推荐度:
导读在Python的Django框架中用流响应生成CSV文件的教程:在Django里,流式响应StreamingHttpResponse是个好东西,可以快速、节省内存地产生一个大型文件。 目前项目里用于流式响应的一个是Eventsource,用于改善跨系统通讯时用户产生的慢速的感觉。这个不细说了。 还有一个就是生成一个大的csv文件。 当Djan

在Django里,流式响应StreamingHttpResponse是个好东西,可以快速、节省内存地产生一个大型文件。

目前项目里用于流式响应的一个是Eventsource,用于改善跨系统通讯时用户产生的慢速的感觉。这个不细说了。

还有一个就是生成一个大的csv文件。

当Django进程处于gunicorn或者uwsgi等web容器中时,如果响应超过一定时间没有返回,就会被web容器终止掉,虽然我们可以通过加长web容器的超时时间来绕过这个问题,但是毕竟还是治标不治本。要根本上解决这个问题,Python的生成器、Django框架提供的StreamingHttpResponse这个流式响应很有帮助

而在csv中,中文的处理也至关重要,要保证用excel打开csv不乱码什么的。为了节约空间,我就把所有代码贴到一起了。实际使用按照项目的规划放置哈

上代码:

from __future__ import absolute_import
import csv
import codecs
import cStringIO


class Echo(object):

 def write(self, value):
 return value

class UnicodeWriter:

 """
 A CSV writer which will write rows to CSV file "f",
 which is encoded in the given encoding.
 """

 def __init__(self, f, dialect=csv.excel, encoding="utf-8", **kwds):
 # Redirect output to a queue
 self.queue = cStringIO.StringIO()
 self.writer = csv.writer(self.queue, dialect=dialect, **kwds)
 self.stream = f
 self.encoder = codecs.getincrementalencoder(encoding)()

 def writerow(self, row):
 self.writer.writerow([handle_column(s) for s in row])
 # Fetch UTF-8 output from the queue ...
 data = self.queue.getvalue()
 data = data.decode("utf-8")
 # ... and reencode it into the target encoding
 data = self.encoder.encode(data)
 # write to the target stream
 value = self.stream.write(data)
 # empty queue
 self.queue.truncate(0)
 return value

 def writerows(self, rows):
 for row in rows:
 self.writerow(row)

from django.views.generic import View
from django.http.response import StreamingHttpResponse

class ExampleView(View):
 headers=['一些','表头']
 def get(self,request):
 result = [['第一行','数据1'],
 ['第二行','数据2']]
 echoer = Echo()
 writer = UnicodeWriter(echoer)
 def csv_itertor():
 yield codecs.BOM_UTF8
 yield writer.writerow(self.headers)
 for column in result:
 yield writer.writerow(column)

 response = StreamingHttpResponse(
 (row for row in csv_itertor()),
 content_type="text/csv;charset=utf-8")
 response['Content-Disposition'
 ] = 'attachment;filename="example.csv"'
 return response

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。TEL:177 7030 7066 E-MAIL:11247931@qq.com

文档

在Python的Django框架中用流响应生成CSV文件的教程

在Python的Django框架中用流响应生成CSV文件的教程:在Django里,流式响应StreamingHttpResponse是个好东西,可以快速、节省内存地产生一个大型文件。 目前项目里用于流式响应的一个是Eventsource,用于改善跨系统通讯时用户产生的慢速的感觉。这个不细说了。 还有一个就是生成一个大的csv文件。 当Djan
推荐度:
标签: 生成 使用 在使用
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top