python自动生成Docx(docxtpl库)

python这个库很有用,可以格式化生成报告等。

其他内容请点此处,下面只写docxtpl的功能代码。

# coding: utf-8
import web  # 我们用的webpy框架
import StringIO
form docxtpl import DocxTemplate

def doctest():
    tpl = DocxTemplate('E:/safe.docx')  # 读取docx模板,注意:需要提前设置好模板,下面会介绍
    tpl = DocxTemplate('/home/sysadm/shell/usm/usm_tk_online2/usm/www/safetytrain/safe.docx')
    # 将文件流返回
    web.header('Content-type', 'aapplication/msword')  # 指定返回类型
    web.header('Transfer-Encoding', 'chunked')
    web.header('Content-Disposition',
                       'attachment;filename={0}'.format('名称' + '.doc'))
    list_docx = []  # 将需要写道doc的内容都放到list_docx列表里面
    list_docx.append({'personname':"personname","companyname":"companyname","division":"division"})
    datetody = str(datetime.date.today())  # 用来给doc名称动态显示时间
    list_docx_x, list_docx_y = divmod(len(list_docx), 35)  # 生产doc文档的页数
    
    if list_docx_y != 0:
        list_docx_count = list_docx_x + 1
    else:
        list_docx_count = list_docx_x
    list_docx_de = []
    page_s = []
    for i in range(list_docx_count):
        page_s.append(i+1)
    for i in range(list_docx_count):
        if i == list_docx_count - 1:
            li_c = list_docx[(i)*35:]
        else:
            li_c = list_docx[(i)*35: (i)*35 + 35]
        list_docx_de.append(li_c)
    
    ret = {"page":list_docx_count,"datetody":datetody, "total": list_docx_de}  # 在doc里面对ret进行取值
    # 以下都是固定写法
    tpl.render(ret)  
    sio = StringIO.StringIO()
    # 将文件保存为string流
    tpl.save(sio)
    # 将光标移到开头
    sio.seek(0)
    # 会在浏览器显示下载特效
    return sio.getvalue()

模板语法(图片来至网络)

原文地址:https://www.cnblogs.com/aaronthon/p/11609880.html