В моем приложении django я использую шаблон для создания тела электронной почты, одним из параметров является URL-адрес, обратите внимание, что в URL-адресе есть два параметра, разделенных амперсандом.
t = loader.get_template("sometemplate")
c = Context({
'foo': 'bar',
'url': 'http://127.0.0.1/test?a=1&b=2',
})
print t.render(c)
После рендеринга выдает: http://127.0.0.1/test?a=1&b=2
Обратите внимание, что амперсанд в HTML закодирован как «& amp;». Один из способов решения проблемы - передать каждый параметр в мой шаблон отдельно и создать URL-адрес в шаблоне, однако я бы не хотел этого делать.
Есть ли способ отключить HTML-кодировку параметров контекста или, по крайней мере, избежать кодирования амперсандов?






Чтобы отключить его для одной переменной, используйте mark_safe:
from django.utils.safestring import mark_safe
t = loader.get_template("sometemplate")
c = Context({
'foo': 'bar',
'url': mark_safe('http://127.0.0.1/test?a=1&b=2'),
})
print t.render(c)
В качестве альтернативы, чтобы полностью отключить автоматическое экранирование из вашего кода Python, используйте аргумент autoescape при инициализации Context:
c = Context({
'foo': 'bar',
'url': 'http://127.0.0.1/test?a=1&b=2',
}, autoescape=False)
Раздел документации Как отключить [Автоматическое экранирование HTML] охватывает некоторые параметры в шаблоне, если вы предпочитаете делать это там.
Или просто используйте «безопасный» фильтр в своем шаблоне.
Кроме того, я не могу не подчеркнуть, насколько важно знать документацию Django; на многие распространенные вопросы, подобные этому, можно легко найти ответы и объяснения (как этот), а чтение документации и понимание того, как все работает, резко сократят количество времени, которое вам нужно потратить на вопрос «Почему он это сделал?» и увеличьте количество времени, которое вы тратите на создание вещей, которые работают так, как вы хотите.
mark_safe сделал именно то, что я хотел, мне нужно было только для 1 параметра