我有我用它来生成LaTeX文件这个Django的模板
\documentclass[11pt]{report}
\begin{document}
\begin{table}
\centering
\begin{tabular}{lcr}
\hline
{% for col in head %}
\textbf{ {{col}} }
{% if not forloop.last %}
&
{% endif %}
{% endfor %}
\\
\hline
{% for row in table %}
{% for cell in row %}
{% if not forloop.last %}
&
{% endif %}
{% endfor %}
\\
{% endfor %}
\hline
\end{tabular}
\caption{Simple Phonebook}
\label{tab:phonebook}
\end{table}
\end{document}
但我没有列的非常大,使他们能够包含它们当中的任何特殊字符。 我得到的错误而产生的PDF文件。
我怎么能逃避所有列的所有文本?
亚历克斯的答案,包括代码的建议,如果你想复制粘贴:
import re
def tex_escape(text):
"""
:param text: a plain text message
:return: the message escaped to appear correctly in LaTeX
"""
conv = {
'&': r'\&',
'%': r'\%',
'$': r'\$',
'#': r'\#',
'_': r'\_',
'{': r'\{',
'}': r'\}',
'~': r'\textasciitilde{}',
'^': r'\^{}',
'\\': r'\textbackslash{}',
'<': r'\textless{}',
'>': r'\textgreater{}',
}
regex = re.compile('|'.join(re.escape(unicode(key)) for key in sorted(conv.keys(), key = lambda item: - len(item))))
return regex.sub(lambda match: conv[match.group()], text)
见更换使用替代品的字典字符串最简单的方法? 更换的做法。
像这样的东西应该做的:
CHARS = {
'&': r'\&',
'%': r'\%',
'$': r'\$',
'#': r'\#',
'_': r'\letterunderscore{}',
'{': r'\letteropenbrace{}',
'}': r'\letterclosebrace{}',
'~': r'\lettertilde{}',
'^': r'\letterhat{}',
'\\': r'\letterbackslash{}',
}
print("".join([CHARS.get(char, char) for char in "&%$#_{}~^\\"]))
创建你自己的模板过滤器来过滤变数
[编辑]:
这是特殊字符的背景下,乳胶,适应用:
\& \% \$ \# \_ \{ \} \textasciitilde{} \^{} \textbackslash{}