Otro enfoque (más flexible) puede ser la de convertir los valores a un valor bibtex similar antes de enviarlos a su plantilla. Probablemente necesites hacer esto de todos modos para escapar de algunos de los caracteres que bibtex/latex no puede manejar. Aquí hay algo similar que preparé antes:
import datetime
class BibTeXString(unicode):
pass
def bibtex_repr(obj):
""" A version of the string repr method, that always outputs variables suitable for BibTeX. """
# If this has already been processed, it's ok
if isinstance(obj, BibTeXString):
return obj
# Translate strings
if isinstance(obj, basestring):
value = unicode(obj).translate(CHAR_ESCAPES).strip()
return BibTeXString('{%s}' % value)
# Dates
elif isinstance(obj, datetime.date):
return BibTeXString('{%02d-%02d-%02d}' % (obj.year, obj.month, obj.day))
# Integers
if isinstance(obj, (int, long)):
return BibTeXString(str(obj))
else:
return BibTeXString(repr(obj))
CHAR_ESCAPES = {
ord(u'$'): u'\\$',
ord(u'&'): u'\\&',
ord(u'%'): u'\\%',
ord(u'#'): u'\\#',
ord(u'_'): u'\\_',
ord(u'\u2018'): u'`',
ord(u'\u2019'): u"'",
ord(u'\u201c'): u"``",
ord(u'\u201d'): u"''" ,
ord(u'\u2014'): u'---',
ord(u'\u2013'): u'--',
}
Incluso puede utilizar esto como un filtro de plantilla si quería, por lo que su plantilla se parece a:
@{{ pubentry.type }{,
author = {% filter bibtex %}{% for author in pubentry.authors.all %}{{ author.first_name }} {{ author.middle_name }} {{ author.last_name }}{% if not forloop.last %} and {% endif %}{% endfor %}}{% endfilter %},
title = {{ pubentry.title|bibtex }},
journal = {{ pubentry.journal|bibtex }}
}
Pero podría escapar el contenido antes de que llegue a la plantilla, por lo que su plantilla solo tiene que hacer esto:
@{{ pubentry.type }{,
{% for field in fields %}{{ field }}{% if not forloop.last %},{% endif %}{% endfor %}
}
O incluso omita por completo la plantilla en esta etapa. ¡Buena suerte!
¡Gracias! Suena interesante. Todavía estoy aprendiendo Django/Python (8 horas de exp hasta el momento) pero voy a analizar esto. – rxin