Django 创建CSV文件

Django使用Python内置的CSV库来创建动态的CSV(逗号分隔值)文件。我们可以在项目的视图文件中使用这个库。

让我们来看一个例子,这里我们有一个Django项目,我们正在实现这个功能。创建一个视图函数 getfile()

Django CSV例子

在这个例子中,我们使用静态数据创建CSV。

// Views.py

复制代码
import csv

def getfile(request):
    response = HttpResponse(content_type='text/csv')
    response['Content-Disposition'] = 'attachment; filename="file.csv"'
    writer = csv.writer(response)
    writer.writerow(['1001', 'John', 'Domil', 'CA'])
    writer.writerow(['1002', 'Amit', 'Mukharji', 'LA', '"Testing"'])
    return response

Python

Copy

// urls.py

为该函数提供URL。

复制代码
path('csv',views.getfile)

Python

Copy

在执行到浏览器时,它呈现一个CSV文件。参见示例。

除了静态数据,我们还可以从数据库获取CSV文件。请看下面的示例,我们通过使用 Employee 模型从表中获取数据。

使用数据库生成动态CSV文件

// views.py

复制代码
from myapp.models import Employee import csv
def getfile(request):
    response = HttpResponse(content_type='text/csv')
    response['Content-Disposition'] = 'attachment; filename="file.csv"'
    employees = Employee.objects.all()
    writer = csv.writer(response)
    for employee in employees:
        writer.writerow([employee.eid,employee.ename,employee.econtact])
    return response

Python

Copy

输出结果:

保存文件并在包含以下数据的文本编辑器中打开。

这些数据是从员工表中取回的,下面是表的快照。

嗯,我们已经看到这个库非常有用,可以创建动态的CSV文件。现在,在需要的时候将其应用到Django项目中

相关推荐
5 32111 分钟前
无公网实体服务器加装多个操作系统供多个用户互不打扰使用_part1
运维·服务器
达斯维达的大眼睛12 分钟前
Linux网络多进程并发服务器和多线程并发服务器
linux·服务器·网络
A林玖28 分钟前
【学习笔记】服务器上使用 nbconvert 将 Jupyter Notebook 转换为 PDF
服务器·笔记·学习
星释1 小时前
阿里云服务迁移实战: 02-服务器迁移
服务器·阿里云·云计算
孟里啥都有.1 小时前
linux内核升级
linux·运维·服务器
xyd陈宇阳1 小时前
Linux 入门八:Linux 多进程
linux·运维·服务器
咖啡调调。2 小时前
模板引擎语法-变量
django·sqlite
搜搜秀10 小时前
find指令中使用正则表达式
linux·运维·服务器·正则表达式·bash
Archie_IT11 小时前
修图自由!自建IOPaint服务器,手机平板随时随地远程调用在线P图
运维·服务器·前端·git·深度学习·npm·conda
无名之逆12 小时前
[特殊字符] Hyperlane:为现代Web服务打造的高性能Rust文件上传解决方案
服务器·开发语言·前端·网络·后端·http·rust