2013-04-28 3 views
9

私はLaTeXのファイルに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} 

を生成するために使用し、このDjangoテンプレートを持っていない。しかし、彼らはそれらのいずれかの特殊文字を含めることができるように、列の私の何が非常に大きいです。私はpdfファイルを生成中にエラーが発生しています。

どのようにしてすべての列のすべてのテキストをエスケープできますか?このような

答えて

3

何かが行う必要があります。

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 "&%$#_{}~^\\"])) 

は、あなたの変数フィルタリングするための独自のテンプレートフィルタを作成します

[編集]:これは、コンテキストのための特殊文字

た、ラテックスのため、適応with:

\& \% \$ \# \_ \{ \} \textasciitilde{} \^{} \textbackslash{} 
+1

また、r '\ textgreater' r '\ textless' – blueberryfields

+0

またはr '\ ensuremath {<}'とr '\ ensuremath {>}'を含めることを忘れないでください。 – sastanin

14

アレックスの答えは、コードでの提案を含めて、コピーペースト:

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) 

置換アプローチについてはEasiest way to replace a string using a dictionary of replacements?を参照してください。

+0

コードをありがとう! '\ textless'と' \ textgreater'の後ろに空白があるはずです。 '

+0

これはすばらしいです、ありがとう! – ikku100

関連する問題