在自定义Python Markdown扩展的输出中禁用HTML编码

前端之家收集整理的这篇文章主要介绍了在自定义Python Markdown扩展的输出中禁用HTML编码前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我一直致力于创建一个python markdown扩展,当使用自定义标记时,它将在我的django项目中插入一个图库.实际的扩展是有效的,但扩展返回的HTML都是编码的.这是我正在使用的扩展:

#!/usr/bin/env python
from django.template.loader import render_to_string
from main.models import *

import markdown

version = "0.1.0"

class GalleriaExtension(markdown.Extension):
    def __init__(self,configs):
        self.config = {
        }

        # Override defaults with user settings
        for key,value in configs:
            self.setConfig(key,value)

    def add_inline(self,md,name,klass,re):
        pattern = klass(re)
        pattern.md = md
        pattern.ext = self
        md.inlinePatterns.add(name,pattern,"

我确保render_to_string实际上返回了未编码的html.从shell开始,这里有一个输出示例:

render_to_string的输出

>>> from django.template.loader import render_to_string
>>> images = SuperPage.objects.get(id=8).superpageimage_set.all()
>>> render_to_string('galleria.html',{ 'images': images })
u'

以下是编码的markdown扩展的输出

>>>markdown.markdown('test [gallery 8] test',['galleria'])
u'

使用降价扩展时,如何使渲染返回HTML标记而不是编码标记?此外,我将不胜感激任何关于编码的指针(语法,布局等).我很感激.

最佳答案
如果您正在寻找的是一种避免自定义标记呈现的内容自动调整的方法,那么您可以使用django.utils.safestring.mark_safe将该字符串标记为安全.

您可以在django代码中看到一些示例.例如在defaulttags.py.

猜你在找的Python相关文章