当前位置: 首页 > news >正文

垃圾桶东莞网站建设百度推广登录平台客服

垃圾桶东莞网站建设,百度推广登录平台客服,网页设计表单注册代码,网页设计与制作 培训文章目录Django实践-06导出excel/pdf/echartsDjango实践-06导出excel/pdf/echarts导出excel安装依赖库修改views.py添加excel导出函数修改urls.py添加excel/运行测试导出pdf安装依赖库修改views.py添加pdf导出函数修改urls.py添加pdf/生成前端统计图表修改views.py添加get_teac…

文章目录

  • Django实践-06导出excel/pdf/echarts
    • Django实践-06导出excel/pdf/echarts
      • 导出excel
        • 安装依赖库
        • 修改views.py添加excel导出函数
        • 修改urls.py添加excel/
        • 运行测试
      • 导出pdf
        • 安装依赖库
        • 修改views.py添加pdf导出函数
        • 修改urls.py添加pdf/
      • 生成前端统计图表
        • 修改views.py添加get_teachers_data函数
        • 修改urls.py添加teachers_data
        • 创建echarts.html页面
        • 设置echarts.html弹出
        • 测试并运行
    • 总结

在这里插入图片描述

Django实践-06导出excel/pdf/echarts

官网:https://www.djangoproject.com/
博客:https://www.liujiangblog.com/
本博客内容参考git:https://gitcode.net/mirrors/jackfrued/Python-100-Days 一些细节问题,大家可以查看git连接。本文主要的改变为把代码升级为django4.1版本。

Django静态文件问题备注:
参考:
Django测试开发-20-settings.py中templates配置,使得APP下的模板以及根目录下的模板均可生效
解决django 多个APP时 static文件的问题

django配置app中的静态文件步骤
Django多APP加载静态文件

django.short包参考:https://docs.djangoproject.com/en/4.1/topics/http/shortcuts/

Django实践-06导出excel/pdf/echarts

导出excel

安装依赖库

pip install xlwt

修改views.py添加excel导出函数

def export_teachers_excel(request):import xlwtimport urllib.parse# 创建工作簿wb = xlwt.Workbook()# 添加工作表sheet = wb.add_sheet('老师信息表')# 查询所有老师的信息queryset = Teacher.objects.all()# 向Excel表单中写入表头colnames = ('姓名', '介绍', '好评数', '差评数', '学科')for index, name in enumerate(colnames):sheet.write(0, index, name)# 向单元格中写入老师的数据props = ('name', 'detail', 'good_count', 'bad_count', 'subject')for row, teacher in enumerate(queryset):for col, prop in enumerate(props):value = getattr(teacher, prop, '')if isinstance(value, Subject):value = value.namesheet.write(row + 1, col, value)# 保存Excelbuffer = BytesIO()wb.save(buffer)# 将二进制数据写入响应的消息体中并设置MIME类型resp = HttpResponse(buffer.getvalue(), content_type='application/vnd.ms-excel')# 中文文件名需要处理成百分号编码filename = urllib.parse.quote('老师.xls')# 通过响应头告知浏览器下载该文件以及对应的文件名resp['content-disposition'] = f'attachment; filename*=utf-8\'\'{filename}'return resp

修改urls.py添加excel/

path('excel/', views.export_teachers_excel),

运行测试

打开url

localhost:8000/excel/

也可以把

<a href="/excel">教师信息下载</a>

添加到对应的页面中,完成点击下载

导出pdf

安装依赖库

https://www.reportlab.com/docs/reportlab-userguide.pdf

pip install reportlab

修改views.py添加pdf导出函数

def export_pdf(request: HttpRequest) -> HttpResponse:import iofrom reportlab.pdfgen import canvasbuffer = io.BytesIO()pdf = canvas.Canvas(buffer)pdf.setFont("Helvetica", 80)pdf.setFillColorRGB(0.2, 0.5, 0.3)pdf.drawString(100, 550, 'hello, world!')pdf.showPage()pdf.save()resp = HttpResponse(buffer.getvalue(), content_type='application/pdf')resp['content-disposition'] = 'inline; filename="demo.pdf"'return resp

修改urls.py添加pdf/

path('pdf/', polls_views.export_pdf),

生成前端统计图表

如果项目中需要生成前端统计图表,可以使用百度的ECharts。具体的做法是后端通过提供数据接口返回统计图表所需的数据,前端使用ECharts来渲染出柱状图、折线图、饼图、散点图等图表。例如我们要生成一个统计所有老师好评数和差评数的报表,可以按照下面的方式来做。

修改views.py添加get_teachers_data函数

# 跳转到echarts页面
def get_echarts(request):return render(request, 'polls/echarts.html')# 获取教师信息
def get_teachers_data(request):queryset = Teacher.objects.all()names = [teacher.name for teacher in queryset]good_counts = [teacher.good_count for teacher in queryset]bad_counts = [teacher.bad_count for teacher in queryset]return JsonResponse({'names': names, 'good': good_counts, 'bad': bad_counts})

修改urls.py添加teachers_data

path('teachers_data/', views.get_teachers_data),

创建echarts.html页面

在templates/polls下创建echarts.html

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><title>老师评价统计</title>
</head>
<body><div id="main" style="width: 600px; height: 400px"></div><p><a href="/">返回首页</a></p><script src="https://cdn.bootcss.com/echarts/4.2.1-rc1/echarts.min.js"></script><script>var myChart = echarts.init(document.querySelector('#main'))fetch('/teachers_data/').then(resp => resp.json()).then(json => {var option = {color: ['#f00', '#00f'],title: {text: '老师评价统计图'},tooltip: {},legend: {data:['好评', '差评']},xAxis: {data: json.names},yAxis: {},series: [{name: '好评',type: 'bar',data: json.good},{name: '差评',type: 'bar',data: json.bad}]}myChart.setOption(option)})</script>
</body>
</html>

设置echarts.html弹出

<a href="/get_echarts">教师好评分析</a>

添加到teachers.html页面
为便于按照博客练习,页面已经一次性写好,内容如下:
参考:Django实践-03模型-01表生成模型+学科页面与教师页面编写

测试并运行

在这里插入图片描述
在这里插入图片描述

总结

本文主要是Django系列博客。本文是Django导出excel/pdf/echarts示例。
1.安装依赖库
2.修改views.py文件
3.修改urls.py文件
4.修改html文件
5.测试运行

http://www.yidumall.com/news/89134.html

相关文章:

  • 华宁网站建设站长工具seo综合查询下载
  • 成都营销网站建设团队黑帽seo教程
  • 怎样制作静态网站免费网络推广工具
  • 杭州知名的企业网站建设企业seo顾问
  • 前程无忧做简历网站jmr119色带
  • 网站设计公司域名服务器建设阿里云万网域名注册
  • 网站建设 业务走下坡营销心得体会感悟300字
  • 网站做抽奖活动钦州seo
  • 广西开网站信息公司竞价推广公司
  • php移动网站开发网络营销推广方法有哪些
  • 网站制作的公司哪个好防疫优化措施
  • 一个新的网站怎么做宣传电子商务主要学什么就业方向
  • 城口集团网站建设东莞网站seo技术
  • 南宁五象新区建设投资集团网站百度网站优化排名
  • 东莞新增疫情最新情况win7优化大师官方免费下载
  • 做办公室的网站网站开发费用
  • wordpress推送到百度百度seo权重
  • c2c网站开发策划湖州seo排名
  • 陵水网站建设公司网页模板图片
  • 番禺网站优化兰州网络推广优化服务
  • b站必看的纪录片昆山seo网站优化软件
  • wordpress 插件设计seo全称是什么意思
  • 网站广告形式郑州seo实战培训
  • 没有网站如何做落地页网站推广的几种方法
  • 工信部网站备案系统怎么注册百度搜索风云榜下载
  • vps上安装wordpress宁波seo深度优化平台有哪些
  • 手机怎么注册自己的网站长沙网站优化效果
  • seo赚钱品牌搜索引擎服务优化
  • 招聘网站入职分析表怎么做磁力棒
  • 国外一个做ppt的网站河南关键词优化搜索