本文实例讲述了django框架基于模板 生成 excel(xls) 文件操作。分享给大家供大家参考,具体如下:

生成Excel 文件,很多人会采用一些开源的库来实现,比如python 自带 csv 库可以生成类似Excel 一样的东西,当然还有一些专门处理 excel 的库,我以前也有用过,比如这里: //www.jb51.net/article/163408.htm 我介绍过用第三方的库来实现。但事实上还有另外一种办法,采用模板的方法.

虽然标题写的是利用 django 模板来实现,其实并一定,你可以是自定义的一个文本文件。只是这个文件需要满足一定的格式去编写. 是个 xml 格式的,我在自己的项目中写了几个tag, 自己可以去掉后测试:

模板内容

{% load languageTag %}

{% load mulTag%}

<?xml version="1.0"?>

<?mso-application progid="Excel.Sheet"?>

xmlns:o="urn:schemas-microsoft-com:office:office"

xmlns:x="urn:schemas-microsoft-com:office:excel"

xmlns:ss="urn:schemas-microsoft-com:office:spreadsheet"

xmlns:html="http://www.w3.org/TR/REC-html40">

wh

wuhf

2011-05-10T03:11:52Z

2011-05-11T03:09:09Z

ig

11.9999

10290

21600

0

285

False

False

x:FullRows="1" ss:DefaultColumnWidth="54" ss:DefaultRowHeight="14.25">

{%if filter.phase == 'week'%}{%padLang 3_week_report%} {%else%} {%padLang 3_month_report%} {%endif%}

{%padLang 3_pay_date%} : {{filter.start_date}} - {{filter.end_date}}

{%padLang 3_order_info%}

{%padLang 3_pay_info%}

{%padLang 3_order_sn%}

{%padLang 3_user_name%}

{%padLang 3_distributor_name%}

{%padLang 3_amount%}

{%padLang 3_amount_source%}

{%padLang 3_create_date%}

{%padLang 3_installment%}

{%padLang 3_pay_name%}

{%padLang 3_amount_local%}

{%padLang 3_amount_amr%}

{%padLang 3_pay_date%}

{%for phase,orders in res.iteritems%}

{%for order_sn,order_pays in orders.iteritems%}

{%for item in order_pays%}

{%if forloop.first %}

{{item.order_sn}}

{{item.user_name}}

{{item.distributor_name}}

{{item.order_subtotal}}

{%if item.order_subtotal == 1%} {%padLang 3_user%}{%else%}{%padLang 3_distributor%}{%endif%}

{%if item.create_date == 0 %}{{item.pay_date.}}{%else%} {{item.create_date}} {%endif%}

{%if item.installment_id%} {%padLang 3_yes%}{%else%} {%padLang 3_no%}{%endif%}';

{%else%}

{%endif%}

{%if item.payment_id == '-2'%}{%padLang 3_amount_hand%}

{%else%}{%if item.payment_id == '0'%} {%else%}{{item.pay_name}}{%endif%}

{%endif%}

{{item.pay_money}} {{item.rate_name}}

{{item.amr}}

{{item.pay_date}}

{%endfor%}

{%endfor%}

{%padLang 3_subtotal%}

{{item.phase_subtotal}}

{%endfor%}

{%padLang 3_total%}

ss:Type="Number">{{total}}

这段模板里面包含了一些我自己的逻辑,熟悉 django 的人一眼就能看出来,那些是我加的,那些是原来应该有的,其实道理就是,循环处理 和 把数据向里面填充就可以了。

在视图中如何处理呢:

def report_pad_order(request):

....

t = TemplateResponse(request, 'pad_order_report_xls.html', context)

t.render()

response = HttpResponse(content_type='application/vnd.ms-excel')

response['Content-Disposition'] = 'attachment; filename=test.xls'

response.write(t.content)

return response

这样就可以实现直接用 Django 渲染模板下载 excel 文档了。还是很方便的,至少不用调用很多三方的API函数去生成excel.

希望本文所述对大家基于Django框架的Python程序设计有所帮助。

本文标题: django框架基于模板 生成 excel(xls) 文件操作示例

本文地址: http://www.cppcns.com/jiaoben/python/262660.html

python excel处理框架_django框架基于模板 生成 excel(xls) 文件操作示例相关推荐

  1. django excel 导出页面_Django Admin中增加导出Excel功能过程解析

    在使用Django Admin时, 对于列表我们有时需要提供数据导出功能, 如下图: 增加导出Excel功能 在Django Admin中每个模型的Admin类(继承至admin.ModelAdmin ...

  2. NPOI 菜鸟实践行之根据指定的模板生成Excel 2003格式的文件 (一)

    感谢群里的各位朋友的指导和教学,感谢Tony Qu的热心指导,感谢阿修罗兄提供的Excelhelper类 谈谈个人对Excel的理解,结合NPOI,个人水平一般般,菜鸟一只 Excel 打开后,分为s ...

  3. springmvc下解析模板生成Excel ,用freemarker

    工具类解析模板生成Excel public class TemplateParseUtil {/** * 解析模板生成Excel * @param templateDir 模板目录 * @param ...

  4. ftl模板导出excel_使用freemark模板生成excel

    1.背景 文件操作中导入导出功能在项目中十分常见,这里我们要聊的是导出excel这一功能.老话题常谈常新,小编给大家介绍使用freemark模板的方式导出excel. 2.实现 Demo中采用spri ...

  5. EasyPoi通过模板生成Excel文件

    之前用easypoi实现过导出简单的excel文件,最近又有需求导出固定格式的excel文件,所以在网上搜索学习了一下,现将学会后写的demo记录一下方便以后回顾. 首先照例引入maven依赖(这里版 ...

  6. excel导出 服务器运行失败,用vc生成excel报表,提示“创建excel服务器失败”,该如何处理...

    当前位置:我的异常网» VC/MFC » 用vc生成excel报表,提示"创建excel服务器失败", 用vc生成excel报表,提示"创建excel服务器失败" ...

  7. python打开文件并读取内容-Python实现的读取文件内容并写入其他文件操作示例

    本文实例讲述了Python实现的读取文件内容并写入其他文件操作.分享给大家供大家参考,具体如下: 文件目录结构,如图: read_file.py是工作文件,file_test.py是读取文件源,wri ...

  8. 成功解决基于pyecharts生成的html文件打开时显示空白

    成功解决基于pyecharts生成的html文件打开时显示空白 目录 解决问题 解决思路 解决方法 第一步,更新

  9. python中os模块详解_Python OS模块(常见文件操作示例)

    1 Python 常见文件操作示例 2. 3. os.path 模块中的路径名访问函数 4. 分隔 5. basename() 去掉目录路径 , 返回文件名 6. dirname() 去掉文件名 , ...

最新文章

  1. 将数据追加到html 表格中,将数据添加到数据表中
  2. 避不开的算法,如何吃透?
  3. 黑客帝国「缸中之脑」有眉目了?培养皿中百万人脑细胞学会打乒乓球,仅用了5分钟...
  4. java 登录下线_java web中Listener的实现(实现用户在线统计数量和强制用户下线)...
  5. spring集成redis(ehcache缓存改成redis)
  6. 个人成长:拉开你和同龄人差距的100个顶级认知
  7. Git之Stash(储藏)备份当前的工作区的内容
  8. Java 8的烹调方式–拼图项目
  9. dedecms怎么改php版本_PHP程序员进阶之路
  10. 经验 | 深度学习中从基础综述、论文笔记到工程经验、训练技巧
  11. Linux下如何设置和查看环境变量
  12. 虚拟资源拳王公社:做什么副业能最快赚到钱?虚拟副业是怎么赚钱的
  13. Postfix 故障记录
  14. P2668 斗地主 贪心+深搜
  15. CSI Tool安装使用讲解
  16. 2017国二c语言考试试卷,2017备考计算机二级C语言真题试卷
  17. 基于大数据平台的数据仓库
  18. VMware虚拟机中安装win10操作系统
  19. robotframework如何提取失败的测试,以便下次运行
  20. python中的相对导入//__name__和__package__的作用//以及相对导入的两个经典错误

热门文章

  1. Python 读取接口数据 返回JSON
  2. sticky list item
  3. 短视频的生成,不要在技术上想当然
  4. 解读MySQL的慢日志
  5. 一种快速统计SQL Server每个表行数的方法
  6. 分分钟教会你使用HTML写Web页面
  7. WEB文件管理器2.0版
  8. 基于Python的频谱分析(一)
  9. 系统备份还原软件整理
  10. 【分享】在线解析微信h5网页标签跳转到手机默认浏览器的实现方式