2013-04-28 13 views
9

mam ten django szablonu, który używam do generowania plików LaTeXJak mogę uniknąć znaków specjalnych LaTeX wewnątrz szablonów 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} 

ale mój brak kolumn są bardzo duże, więc mogą one zawierać żadnych znaków specjalnych w nich. Otrzymuję błąd podczas generowania pliku pdf.

Jak mogę uciec z całego tekstu we wszystkich kolumnach?

Odpowiedz

3

Coś jak to powinno zrobić:

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

tworzyć własne filtr szablonu, aby filtrować zmienne

[edit]:

To znaki specjalne dla kontekście, latex, dostosować z:

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

nie zapomnij również o włączeniu funkcji r '\ textgreater' r '\ textless' – blueberryfields

+0

lub r '\ ensuremath {<}' oraz r '\ ensuremath {>}' – sastanin

14

Odpowiedź Alex zawiera sugestie w kodzie, jeśli chcesz o kopiuj-wklej:

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) 

Zobacz Easiest way to replace a string using a dictionary of replacements? dla metody wymiany.

+0

Dzięki za kod! Myślę, że powinno być również spacja po '\ textless' i' \ textgreater'. Mam "Niezdefiniowaną sekwencję kontrolną", ponieważ '

+0

To jest świetne, dzięki! – ikku100