Django异步查询并下载CSV文件

2024-09-01 17:04
文章标签 查询 django 异步 csv 下载

本文主要是介绍Django异步查询并下载CSV文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Django异步查询并下载CSV文件

通过循环遍历数据库,自动生成CSV文件的表头和内容.
Django V5.1

1. 视图

1.1 将同步的数据库查询转换为异步

async def get_blogs():# 使用sync_to_async包装Queryset方法blog_list = await sync_to_async(Blog.objects.all)()return blog_list

1.2 定义一个异步生成器逐行生成CSV数据

async def generate_csv():# 获取queryset listblogs = await get_blogs()# 生成csv文件头async for blog in blogs.values():# 打印查看遍历的内容 await sync_to_async(print)(blog.keys())yield ','.join(blog.keys()) + '\n'break# 生成csv文件内容async for values in blogs.values_list():# 打印查看遍历的内容 await sync_to_async(print)(values)yield ','.join(map(str, values)) + '\n'

1.3 异步下载

async def export_csv(request):response = StreamingHttpResponse(generate_csv(),content_type='text/csv')response['Content-Disposition'] = 'attachment; filename="blogs.csv"'return response

2. 模板

    <div class="container-fluid mt-3"><form action="{% url 'blog:export_csv' %}">{% csrf_token %}<button type="submit" class="btn btn-primary form-control">异步下载测试</button></form></div>

3. url

path('export-csv', views.export_csv, name="export_csv")

4. model

class Blog(models.Model):title = models.CharField(max_length=200, verbose_name="标题")content = models.TextField(verbose_name="内容")pub_time = models.DateTimeField(auto_now_add=True, verbose_name="发布时间")category = models.ForeignKey(to=BlogCategory, on_delete=models.CASCADE, verbose_name="分类")author = models.ForeignKey(to=User, on_delete=models.CASCADE, verbose_name="作者")class Meta:verbose_name = "博客"verbose_name_plural = verbose_nameordering = ['-pub_time']def __str__(self):return self.title

亲测有效

在这里插入图片描述

这篇关于Django异步查询并下载CSV文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127534

相关文章

MyBatis模糊查询报错:ParserException: not supported.pos 问题解决

《MyBatis模糊查询报错:ParserException:notsupported.pos问题解决》本文主要介绍了MyBatis模糊查询报错:ParserException:notsuppo... 目录问题描述问题根源错误SQL解析逻辑深层原因分析三种解决方案方案一:使用CONCAT函数(推荐)方案二:

MySQL 中的 JSON 查询案例详解

《MySQL中的JSON查询案例详解》:本文主要介绍MySQL的JSON查询的相关知识,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录mysql 的 jsON 路径格式基本结构路径组件详解特殊语法元素实际示例简单路径复杂路径简写操作符注意MySQL 的 J

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服

Redis消息队列实现异步秒杀功能

《Redis消息队列实现异步秒杀功能》在高并发场景下,为了提高秒杀业务的性能,可将部分工作交给Redis处理,并通过异步方式执行,Redis提供了多种数据结构来实现消息队列,总结三种,本文详细介绍Re... 目录1 Redis消息队列1.1 List 结构1.2 Pub/Sub 模式1.3 Stream 结

MySQL索引的优化之LIKE模糊查询功能实现

《MySQL索引的优化之LIKE模糊查询功能实现》:本文主要介绍MySQL索引的优化之LIKE模糊查询功能实现,本文通过示例代码给大家介绍的非常详细,感兴趣的朋友一起看看吧... 目录一、前缀匹配优化二、后缀匹配优化三、中间匹配优化四、覆盖索引优化五、减少查询范围六、避免通配符开头七、使用外部搜索引擎八、分

使用Python实现一个优雅的异步定时器

《使用Python实现一个优雅的异步定时器》在Python中实现定时器功能是一个常见需求,尤其是在需要周期性执行任务的场景下,本文给大家介绍了基于asyncio和threading模块,可扩展的异步定... 目录需求背景代码1. 单例事件循环的实现2. 事件循环的运行与关闭3. 定时器核心逻辑4. 启动与停

QT进行CSV文件初始化与读写操作

《QT进行CSV文件初始化与读写操作》这篇文章主要为大家详细介绍了在QT环境中如何进行CSV文件的初始化、写入和读取操作,本文为大家整理了相关的操作的多种方法,希望对大家有所帮助... 目录前言一、CSV文件初始化二、CSV写入三、CSV读取四、QT 逐行读取csv文件五、Qt如何将数据保存成CSV文件前言

C#中async await异步关键字用法和异步的底层原理全解析

《C#中asyncawait异步关键字用法和异步的底层原理全解析》:本文主要介绍C#中asyncawait异步关键字用法和异步的底层原理全解析,本文给大家介绍的非常详细,对大家的学习或工作具有一... 目录C#异步编程一、异步编程基础二、异步方法的工作原理三、代码示例四、编译后的底层实现五、总结C#异步编程

SQL表间关联查询实例详解

《SQL表间关联查询实例详解》本文主要讲解SQL语句中常用的表间关联查询方式,包括:左连接(leftjoin)、右连接(rightjoin)、全连接(fulljoin)、内连接(innerjoin)、... 目录简介样例准备左外连接右外连接全外连接内连接交叉连接自然连接简介本文主要讲解SQL语句中常用的表

关于pandas的read_csv方法使用解读

《关于pandas的read_csv方法使用解读》:本文主要介绍关于pandas的read_csv方法使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录pandas的read_csv方法解读read_csv中的参数基本参数通用解析参数空值处理相关参数时间处理相关