提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
含有word模板,后端填充数据后导出
前言
对实现的功能进行简单描述:实现为用户访问网页,在网页上对服务器发送post请求,django框架的view进行处理,在已有的word模板上根据用户信息修改数据后生成新的word模板,然后返回给前端页面
提示:以下是本篇文章正文内容,下面案例可供参考
一、安装python的docxtpl模块
pip install docxtpl(我是在linux主机上直接安装的,安装成功后导入到django的view视图文件)
自行配置url
导入django的view
二、使用步骤
class Form(View):
//定义了一个Form类,前端url指向/form
def get(self, request):
//get方法的处理
"""xianshi"""
return render(request, 'form.html')
//返回一个form.html页面
def post(self, request):
//定义一个post方法
text = str(request.POST['text'])
//获取前端的数据
doc = DocxTemplate("media/my_word_template.docx")
//word模板的存放位置
context = {'text':text}
//向模板中写入参数
doc.render(context)
doc.save("media/generated_doc.docx")
//保存修改后的文档在media目录下方
file = open('media/generated_doc.docx','rb')
//找到这个修改后的文档,定义它方便调用
response = FileResponse(file)
//把这个文档给response准备返回
response['Content-Type'] = 'application/vnd.openxmlformats-officedocument.wordprocessingml.document'
response['Content-Disposition'] = 'attachment;filename= '+'word文档'.encode('utf-8').decode('ISO-8859-1')+'.docx'
//添加编码方式和相关设置
return response
//返回给前端用户
文件存放位置
模板里面写需要修改的参数,需要加上{{}},这里的txet对应代码 context = {‘text’:text}
所有可以同时在模板中修改多个数据。
总结
提示:这里对文章进行总结:
例如:以上就是今天要讲的内容,本文仅仅简单介绍了docxtpl的使用