用于单词模板的 Jinja2

Jinja2 for word templating

我想使用 jinja2 进行单词模板化,如 this 短文所述。我面临的问题如下,如果我将 {{title}} 放入我的 word 文件中,结果 xml 可能如下所示:

<w:r><w:t>{{</w:t></w:r><w:proofErr w:type="gramStart"/><w:r><w:t>title</w:t></w:r><w:proofErr w:type="gramEnd"/><w:r><w:t>}}</w:t></w:r></w:p>

所以神社不可能相应地替换它。是否有可能防止单词在单独的文本元素中拆分 {{title}}? (如果我从文本编辑器复制它工作正常)

这是一个与 proofErr 标签相关的问题。

你有两个解决方案:

  • 如果你想坚持使用 Jinja2,你应该总是一笔画写你的标签。例如,永远不要按退格键或编辑标签。您也可以从其他编辑器 copy/paste 它。

  • 我写了一个库,Docxtemplater 即使文本元素被拆分也能工作,例如它会替换:

    <w:r>
     <w:t>
       {{
     </w:t>
    </w:r>
    <w:proofErr w:type="gramStart"/>
     <w:r>
      <w:t>title</w:t>
     </w:r>
    <w:proofErr w:type="gramEnd"/>
     <w:r>
      <w:t>}}</w:t>
     </w:r>
    

    作者:

    <w:r>
      <w:t>
        Your title
      </w:t>
    </w:r>
    <w:proofErr w:type="gramStart"/>
    <w:r>
      <w:t></w:t>
    </w:r>
    <w:proofErr w:type="gramEnd"/>
    <w:r>
      <w:t></w:t>
    </w:r>
    

Docxtemplater 可以通过 CLI 或 JS Browser/Node.JS

进行编程

https://pypi.org/project/docxtpl/ 也是一个不错的选择。

它扩展了 python-docx,并允许您在现有 .docx 文档中的任意位置放入 Jinja2 标签,而不是从头开始制作模板。

示例:

pip install docxtpl

用法:

from docxtpl import DocxTemplate

doc = DocxTemplate("my_word_template.docx")
context = { 'company_name' : "Dr. Stubbs Orthopedics and Prosthetics" }
doc.render(context)
doc.save("generated_doc.docx")

如果您的模板 my_word_template.docx 文件如下所示:

[

那么你的 generated_doc.docx 将如下所示:

比较简单吧?