用django生成csv文件(1)
方法简介
这是通过django模板层实现csv文件打印的方法,优点现在我也还在研究中,说下使用方法:
1.创建视图层函数和路由,视图函数如下
2.创建 test.html 模板,模板内容如下
3.访问路由即可生称 csv文件
view层
from django.http import HttpResponse
from django.template import loader
def some_view(request):
#这步是指定将csv文件传输给前台
response = HttpResponse(content_type='text/csv')
# filename 为 指定csv的文件名
response['Content-Disposition'] = 'attachment; filename="somefilename.csv"'
#csv文件中每一行的数据
csv_data = (
('First row', 'Foo', 'Bar', 'Baz'),
('Second row', 'A', 'B', 'C', '"Testing"', "Here's a quote"),
)
#csv文件中的每一行数据
csv_data = (
('First row', 'Foo', 'Bar', 'Baz'),
('Second row', 'A', 'B', 'C', '"Testing"', "Here's a quote"),
)
#response 指定传输到的模板
t = loader.get_template('test.html')
c ={
'data': csv_data,
}
response.write(t.render(c))
return response
模板层(test.html)
{% for row in data %}
"{{ row.0|addslashes }}", "{{ row.1|addslashes }}", "{{ row.2|addslashes }}", "{{ row.3|addslashes }}", "{{ row.4|addslashes }}"
{% endfor %}