django+markdown2+pygments实现markdown解析及代码高亮
from django import template
from django.utils.safestring import mark_safe
import markdown2
import pygments
from pygments.formatters.html import HtmlFormatter
from pygments.lexers import get_lexer_by_name
# 创建一个自定义的过滤器来实现Markdown和Pygments的集成
def markdown_pygments(text):
lexer = get_lexer_by_name("python")
formatter = HtmlFormatter(cssclass='syntax')
text = markdown2.markdown(text, extras=['fenced-code-blocks', 'code-hilite'])
text = pygments.highlight(text, lexer, formatter)
return mark_safe(text)
# 注册过滤器到Django模板
register = template.Library()
register.filter('markdown_pygments', markdown_pygments)
# 在Django模板中使用markdown_pygments过滤器
在Django模板中,你可以像这样使用markdown_pygments
过滤器:
{% load your_custom_markdown_module %}
{{ your_markdown_content|markdown_pygments }}
这段代码定义了一个自定义的Django模板过滤器markdown_pygments
,它接受Markdown内容,使用Pygments进行代码高亮,并返回HTML内容。然后,你可以在Django模板中导入这个模块并应用该过滤器到你的Markdown内容上。
评论已关闭