2013-04-28 14 views
9

Ho questo modello Django che uso per generare file LaTeXCome posso sfuggire ai caratteri speciali LaTeX all'interno dei modelli di 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} 

Ma il mio non di colonne sono molto grandi in modo che possano contenere caratteri speciali in loro. Sto ottenendo errori durante la generazione di file pdf.

Come posso sfuggire a tutto il testo in tutte le colonne?

risposta

3

Qualcosa del genere dovrebbe fare:

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

si crea proprio filtro modello per filtrare le variabili

[modifica]:

Questo è stato i caratteri speciali per il contesto, per LaTeX, adattare con:

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

non dimenticare di includere anche r '\ textgreater' r '\ textless' – blueberryfields

+0

o r '\ ensuremath {<}' e r '\ ensuremath {>}' – sastanin

14

La risposta di Alex include suggerimenti nel codice, se si desidera t o copia-incolla:

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) 

Vedere metodo Easiest way to replace a string using a dictionary of replacements? per sostituzione.

+0

Grazie per il codice! Penso che ci dovrebbe anche essere uno spazio dopo '\ textless' e' \ textgreater'. Ho ottenuto "Sequenza di controllo indefinita" perché "

+0

Questo è fantastico, grazie! – ikku100