用于单词模板的 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
将如下所示:
比较简单吧?
我想使用 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
将如下所示:
比较简单吧?