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

本文实例讲述了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

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
下面是一个简单的Django表单处理示例: 1. 定义表单类 ```python from django import forms class ContactForm(forms.Form): name = forms.CharField(max_length=100) email = forms.EmailField() message = forms.CharField(widget=forms.Textarea) ``` 2. 创建表单视图函数 ```python from django.shortcuts import render from .forms import ContactForm def contact(request): if request.method == 'POST': form = ContactForm(request.POST) if form.is_valid(): name = form.cleaned_data['name'] email = form.cleaned_data['email'] message = form.cleaned_data['message'] # 处理表单数据 else: form = ContactForm() return render(request, 'contact.html', {'form': form}) ``` 3. 创建表单模板 ```html {% extends 'base.html' %} {% block content %} <h1>Contact Us</h1> <form method="post"> {% csrf_token %} {{ form.as_p }} <button type="submit">Send</button> </form> {% endblock %} ``` 在表单视图函数中,我们首先检查请求的方法是否为POST。如果是,则创建一个表单对象,并使用表单数据验证其有效性。如果表单数据有效,则从表单对象中提取数据并处理它们。否则,我们将使用无效表单对象呈现表单模板。 在表单模板中,我们使用Django中的模板标记和过滤器来呈现表单。我们使用`form.as_p`过滤器将表单渲染为HTML段落。我们还使用`{% csrf_token %}`标记为表单添加CSRF令牌,以确保表单在提交时不受到跨站点请求伪造攻击的影响。最后,我们在表单上添加一个提交按钮。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值