专题15:Django生成csv文件

该博客主要围绕CSV文件展开,介绍了CSV文件的定义,重点讲解了使用Python生成CSV文件的实操方法,还提及了CSV文件的下载,最后给出了相关练习题,包含views.py和前端页面方面的内容。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、csv文件定义

2、python中生成csv文件 

实操:

import csv

with open('test_csv.csv', 'w', newline='') as csvfile:
    writer = csv.writer(csvfile)
    writer.writerow(['a', 'b', 'c'])
    writer.writerow(['d', 'e'])

 

3、csv文件下载

4、练习题

views.py中:

def make_page_csv(request):
    all_data = ['a', 'b', 'c', 'd', 'e']
    page_num = request.GET.get('page', 1)
    paginator = Paginator(all_data, 2)
    current_page = paginator.page(int(page_num))
    response = HttpResponse(content_type='text/csv')
    response['Content-Disposition'] = 'attachment;filename="page-%s.csv"'%(page_num)
    writer = csv.writer(response)
    for i in current_page:
        writer.writerow([i])

    return response

前端页面中:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>分页</title>
</head>
<body>
<a href="/make_page_csv?page={{ current_page.number }}">下载csv文件</a>
{% for p in current_page %}
    <p>
        {{ p }}
    </p>
{% endfor %}

{% if current_page.has_previous %}
    <a href="/test_page?page={{ current_page.previous_page_number }}">上一页</a>
{% else %}
    首页
{% endif %}

{% for p_num in paginator.page_range %}
    {% if p_num == current_page.number %}
        {{ p_num }}
    {% else %}
        <a href="/test_page?page={{ p_num }}">{{ p_num }}</a>
    {% endif %}
{% endfor %}

{% if current_page.has_next %}
    <a href="/test_page?page={{ current_page.next_page_number }}">下一页</a>

{% else %}
    尾页
{% endif %}
</body>
</html>

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值