为了让博客文章具有良好的排版,显示更加丰富的格式,我们使用 Markdown 语法来书写我们的博文。Markdown 是一种 HTML 文本标记语言,只要遵循它约定的语法格式,Markdown 的渲染器就能够把我们写的文章转换为标准的 HTML 文档,从而让我们的文章呈现更加丰富的格式,例如标题、列表、代码块等等 HTML 元素。由于 Markdown 语法简单直观,不用超过 5 分钟就可以掌握常用的标记语法,因此大家青睐使用 Markdown 书写 HTML 文档。下面让我们的博客也支持使用 Markdown 书写。
安装 Python Markdown
将 Markdown 格式的文本渲染成标准的 HTML 文档是一个复杂的工作,好在已有好心人帮我们完成了这些工作,我们直接使用即可。首先安装 Markdown,这是一个 Python 第三方库,激活虚拟环境,然后使用命令 pip install markdown
安装即可。
在 detail 视图中渲染 Markdown
将 Markdown 格式的文本渲染成 HTML 文本非常简单,只需调用这个库的 markdown
方法即可。我们书写的博客文章内容存在 Post
的 body
属性里,回到我们的详情页视图函数,对 post
的 body
的值做一下渲染,把 Markdown 文本转为 HTML 文本再传递给模板:
blog/views.py
import markdown
from django.shortcuts import render, get_object_or_404
from .models import Post
def detail(request, pk):
post = get_object_or_404(Post, pk=pk)
# 记得在顶部引入 markdown 模块
post.body = markdown.markdown(post.body,
extensions=[
'markdown.extensions.extra',
'markdown.extensions.codehilite',
'markdown.extensions.toc',
])
return render(request, 'blog/detail.html', context={'post': post})
这样我们在模板中展示 {{ post.body }} 的时候,就不再是原始的 Markdown 文本了,而是渲染过后的 HTML 文本。注意这里我们给 markdown
渲染函数传递了额外的参数 extensions
,它是对 Markdown 语法的拓展,这里我们使用了三个拓展,分别是 extra、codehilite、toc。extra 本身包含很多拓展,而 codehilite 是语法高亮拓展,这为我们后面的实现代码高亮功能提供基础,而 toc 则允许我们自动生成目录(在以后会介绍)。
来测试一下效果,进入后台,这次我们发布一篇用 Markdown 语法写的测试文章看看,你可以使用以下的 Markdown 测试代码进行测试,也可以自己书写你喜欢的 Markdown 文本。假设你是 Markdown 新手参考一下这些教程,一定学一下,保证你可以在 5 分钟内掌握常用的语法格式,而以后对你写作受用无穷。可谓充电五分钟,通话 2 小时。以下是我学习中的一些参考资料:
# 一级标题
## 二级标题
### 三级标题
- 列表项1
- 列表项2
- 列表项3
> 这是一段引用
```python
def detail(request, pk):
post = get_object_or_404(Post, pk=pk)
post.body = markdown.markdown(post.body,
extensions=[
'markdown.extensions.extra',
'markdown.extensions.codehilite',
'markdown.extensions.toc',
])
return render(request, 'blog/detail.html', context={'post': post})
```
如果你发现无法显示代码块,即代码无法换行,请检查代码块的语法是否书写有误。代码块的语法如上边的测试文本中最后一段所示。
你可能想在文章中插入图片,目前能做的且推荐做的是使用外链引入图片。比如将图片上传到七牛云这样的云存储服务器,然后通过 Markdown 的图片语法将图片引入。Markdown 引入图片的语法为:![图片说明](图片链接)
。
safe 标签
我们在发布的文章详情页没有看到预期的效果,而是类似于一堆乱码一样的 HTML 标签,这些标签本应该在浏览器显示它本身的格式,但是 Django 出于安全方面的考虑,任何的 HTML 代码在 Django 的模板中都会被转义(即显示原始的 HTML 代码,而不是经浏览器渲染后的格式)。为了解除转义,只需在模板标签使用 safe
过滤器即可,告诉 Django,这段文本是安全的,你什么也不用做。在模板中找到展示博客文章主体的 {{ post.body }} 部分,为其加上 safe 过滤器,{{ post.body|safe }},大功告成,这下看到预期效果了。
safe 是 Django 模板系统中的过滤器(Filter),可以简单地把它看成是一种函数,其作用是作用于模板变量,将模板变量的值变为经过滤器处理过后的值。例如这里 {{ post.body|safe }},本来 {{ post.body }} 经模板系统渲染后应该显示 body 本身的值,但是在后面加上 safe 过滤器后,渲染的值不再是body 本身的值,而是由 safe 函数处理后返回的值。过滤器的用法是在模板变量后加一个 | 管道符号,再加上过滤器的名称。可以连续使用多个过滤器,例如 {{ var|filter1|filter2 }}。
代码高亮
程序员写博客免不了要插入一些代码,Markdown 的语法使我们容易地书写代码块,但是目前来说,显示的代码块里的代码没有任何颜色,很不美观,也难以阅读,要是能够像我们的编辑器里一样让代码高亮就好了。虽然我们在渲染时使用了 codehilite 拓展,但这只是实现代码高亮的第一步,还需要简单的几步才能达到我们的最终目的。
安装 Pygments
首先我们需要安装 Pygments,激活虚拟环境,运行: pip install Pygments
安装即可。
搞定了,虽然我们除了安装了一下 Pygments 什么也没做,但 Markdown 使用 Pygments 在后台为我们做了很多事。如果你打开博客详情页,找到一段代码段,在浏览器查看这段代码段的 HTML 源代码,可以发现 Pygments 的工作原理是把代码切分成一个个单词,然后为这些单词添加 css 样式,不同的词应用不同的样式,这样就实现了代码颜色的区分,即高亮了语法。为此,还差最后一步,引入一个样式文件来给这些被添加了样式的单词定义颜色。
引入样式文件
在项目的 blog\static\blog\css\highlights 目录下应该能看到很多 .css 样式文件,这些文件是用来提供代码高亮样式的。选择一个你喜欢的样式文件,在 base.html 引入即可(别忘了使用 static 模板标签)。比如我比较喜欢 github.css 的样式,那么引入这个文件:
templates/base.html
...
<link rel="stylesheet" href="{% static 'blog/css/pace.css' %}">
<link rel="stylesheet" href="{% static 'blog/css/custom.css' %}">
...
+ <link rel="stylesheet" href="{% static 'blog/css/highlights/github.css' %}">
这里 + 号表示添加这行代码。好了,看看效果,大功告成,终于可以愉快地贴代码了。
注意:如果你按照教程中的方法做完后发现代码依然没有高亮,请依次检查以下步骤:
2017.12.21 更新:完成以上步骤后先退出服务器然后重新 runserver,否则看不到高亮效果
- 确保在渲染文本时添加了
markdown.extensions.codehilite
拓展,详情见上文。 - 确保安装了 Pygments。
- 确保代码块的 Markdown 语法正确,特别是指明该代码块的语言类型,具体请参见上文中 Markdown 的语法示例。
- 在浏览器端代码块的源代码,看代码是否被 pre 标签包裹,并且代码的每一个单词都被 span 标签包裹,且有一个 class 属性值。如果没有,极有可能是前三步中某个地方出了问题。
- 确保用于代码高亮的样式文件被正确地引入,具体请参见上文中引入样式文件的讲解。
- 有些样式文件可能对代码高亮没有作用,首先尝试用 github.css 样式文件做测试。
总结
本章节的代码位于:Step9: markdown and code highlight supported。
如果遇到问题,请通过下面的方式寻求帮助。
- 在下方评论区留言。
- 将问题的详细描述通过邮件发送到 djangostudyteam@163.com,一般会在 24 小时内回复。
- 在 Pythonzhcn 社区的新手问答版块 发布帖子。
-- EOF --
markdown 转换成html后被转义如
可以在 模板{{ post.body }}外面嵌套{% autoescape off %}。如下
{% autoescape off %}
{{ post.body }}
{% endautoescape %}
结果
<h1>标题</h1>
我的python是3.6.8版本, markdown3.1.1, pygments2.3.1版本。
代码无法高亮是受评论中“张九十一”的启发,将python代码改为:
```python
post.body = markdown.markdown(post.body, extensions=['extra', 'codehilite', 'toc', ])
```
解决的。谢谢各位!
我把【```python】还有【```】删了,并且整体向右4格,显示了.
博主你好,我在服务器端部署好了网站但是有时候不会显示代码高亮,刷新一下就会显示,再刷新一下又没了,不知道是什么缘故
请问博主为什么代码段里我写的html标记,会被渲染成这样?
原文:
<!DOCTYPE html>
<!--模板标签(具有类似函数的功能)-->
{% load staticfiles %}
{% load blog_tags %}
<html>
<head>
网页:
<!DOCTYPE html>
<!--模板标签(具有类似函数的功能)-->
{% load staticfiles %}
{% load blog_tags %}
<html>
<head>
解决了,没有指明该代码块的语言类型。平常没这么用过。尴尬!
# 一级标题## 二级标题### 三级标题- 列表项1- 列表项2- 列表项3> 这是一段引用```pythondef detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})```
这段代码是贴在放在哪个文件下的,我一直不知道往哪里放
你看到的这段其实是文章内容,通过markdown展现出效果而已
进入admin页面,后台添加博客。
博客文章内容支持图片上传就好了
```pythondef detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})```
上面那段markdown内容中的Python代码有毒,复制过去永远显示不对,自己写或者从其他地方拷,就能显示,弄了好久。。。
> 为什么我就是又不高亮,又没有段落,直接显示html代码出来
有没有朋友遇到啊,就是感觉浏览器没渲染,直接把Markdown转换为html代码显示出来,绝望,求救
后文才说safe的问题。。。。。。
千万别复制,一定要在后台用英文输入法敲出来,不要问我为什么,敲了2个小时试出来的
特别是那两个
```python
code
```
```pythondef detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})```
```python
def detail(request, pk):
post = get_object_or_404(Post, pk=pk)
post.body = markdown.markdown(post.body,
extensions=[ 'markdown.extensions.extra',
'markdown.extensions.codehilite',
'markdown.extensions.toc', ])
return render(request, 'blog/detail.html', context={'post': post})```
```python
def detail(request, pk):
post = get_object_or_404(Post, pk=pk)
post.body = markdown.markdown(post.body,
extensions=[ 'markdown.extensions.extra',
'markdown.extensions.codehilite',
'markdown.extensions.toc', ])
return render(request, 'blog/detail.html', context={'post': post})
```
```python
def detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})
```
请问为什么要在```之后加 python 才能显示高亮,我在其他地方用Markdown编辑并不需要啊
我也不知道,可能是这个 markdown 库的问题吧,因为不影响使用所以没有去管了。你可以找找解决方案。
高亮样式里面不带表格样式,可以设置 bootstrap 3 的 table 样式。
http://bootstrapdocs.com/v3.0.3/docs/css/#tables
时间
建议数据库使用 UTC 时间 (
django.utils.timezone.now()
),而不是本地时间(datetime.datetime.now()
),本地时间由 Django 自动转换。这样方便后期修改时区。设置 settings.py 文件,配置 USE_TZ=True,即启动 UTC 时间。
解决 filter 时同时出现 year、month 无法查询的问题
不同数据库需求不一样
SQLite: install pytz — conversions are actually performed in Python.
PostgreSQL: no requirements (see Time Zones).
Oracle: no requirements (see Choosing a Time Zone File).
MySQL: install pytz and load the time zone tables with mysql_tzinfo_to_sql.
安装完 pytz 后,MySQL 需要导入时区
Linux 和 MacOS:
sudo mysql_tzinfo_to_sql /usr/share/zoneinfo/ | mysql -u root mysql
Windows
先停止 mysqld.exe,到 https://dev.mysql.com/downloads/timezones.html 下载对应版本的时区文件,覆盖 mysql 安装目录下的
data\mysql
文件夹下的同名文件,重新启动 mysql.exe。高亮,换行都没问题,就是没有灰色的代码框
试了一遍找到原因,我用的Materialize ,没用boostrap。导入了一下boostrap后正常显示。接着找找看Materialize 能用的markdown...
没找到,把boostrap里pre标签的全复制过来也行了,先凑合吧
我也遇到这样的情况,解决办法很莫名其妙
1. 我看了一下Markdown的语法说,空一个制表符或者4个空格就能够显示代码块了
2. 我试了一下把 [ ```python ] 和 [```] 删掉然后所有代码后退一个制表符[或者4个空格]然后真的出现了代码块的那个灰色的框
3. 然后我发现没有代码高亮(我感觉是因为没有注明代码类型才没有高亮的),然后加回刚刚删除的那两个东西(在代码首尾加了上去)然后就有高亮了
4. 最后发现,整体代码都后退了一个制表符,我把他弄回去了,发现成功了,但是到头来我根本没有动过什么东西,但是问题就是解决了
真的莫名其妙,感觉是markdown这个库有坑
而且我,也试了文章里面的markdown部分的文本,直接copy到后台的文章编辑中并没有发现任何,问题估计不是这篇文章的文本有外加的样式
```
DSA
```
我前台一直不能显示渲染后的东西,在弄
#求助
```article.content = markdown.markdown(article.content, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ])
```
关于代码没有高亮且代码排版的问题:
文章中楼主的那个:
```pythondef detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})```
这段应该是有问题的,我是直接复制的然后没有高亮且排版有问题,我又从网上找了一段markdown下正确的代码格式片段,然后就可以了:
```python@requires_authorizationdef somefunc(param1='', param2=0): '''A docstring''' if param1 > param2: # interesting print 'Greater' return (param2 - param1 + 1) or Noneclass SomeClass: pass>>> message = '''interpreter... prompt'''```
不要直接从这个网站上拷贝这个markdown格式的代码片段,感觉是这个网站做了转义之类的使得语法有问题,建议:
从别的地方拷贝一段markdown下的代码片段!
从别的地方拷贝一段markdown下的代码片段!
从别的地方拷贝一段markdown下的代码片段!
给大家一个网址,里面有,拷贝一下测试即可:https://www.zybuluo.com/mdeditor?url=https%3A%2F%2Fwww.zybuluo.com%2Fstatic%2Feditor%2Fmd-help.markdown
谢谢
厉害,完美
哎,专门登录请教各位,我的其他都能显示,就是代码框没有显示出来,就只是文本
'''pythondef detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})'''
又遇到同样问题的小伙伴吗?求大神解答,谢谢。
加了safe了,我直接复制文中的代码不行,自己写的也不行,用浏览器的查看源代码是这样的:
<p><h1 id="_1">一级标题</h1><h2 id="_2">二级标题</h2><h3 id="_3">三级标题</h3><ul><li>列表项1</li><li>列表项2</li><li>列表项3</li></ul><blockquote><p>这是一段引用</p></blockquote><p>'''pythondef detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})'''</p></p>
不好意思,我以为那三点是''',其实是反引号,我大意了
[【day 1】python编程:从入门到实践学习笔记-安装、变量和简单数据类型](https://www.jianshu.com/p/74a7b7e78617)测试
# 已经杀到这一关了,暂时还有些地方需要参考代码辅助,不过完成一个项目的时间越来越短了,感谢teacher!
我的网页不能解析markdown语法是怎么回事呢?
变成了这样:
<h1 id="_1">一级标题</h1><h2 id="_2">二级标题</h2><h3 id="_3">三级标题</h3><ul><li>列表项1</li><li>列表项2</li><li>列表项3</li></ul><blockquote><p>这是一段引用</p></blockquote><p><code>pythondef detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})</code></p> ...
没事了.....没有加safe。。。。。
博主 你好 ! 请问你的那些样式是怎么来的呢
看之前的教程,去下载模板,css目录下都是,markdown的样式是在highlights/目录下
从 github 搜的。
博主您好,您的教程非常棒,但是我现在遇到了一个问题,就是如何解析markdown语法中的表格,我尝试着加了tabels扩展但并没有起作用
嗯嗯,我弄好了,不麻烦您了。
相同问题的可以看文档
https://python-markdown.github.io/extensions/
请问这儿是怎么弄的呢?我设置了 tables 拓展,但是没有效果,文档中的先关解释没有太看懂,除了添加 markdown.extensions.tables ,还需要什么操作吗
表格显示的方法:
3. 在 blogproject/templates/base.html 中head部分添加一行 <link rel="stylesheet" href="{% static 'blog/css/tables.css' %}">
4. 在虚拟环境执行 python manage.py collectstatic 命令。
应该就可以了,如果不可以重新启动一下服务。
请问博主,再文章正文似乎无法用markdown插入图片啊?
又尝试了一下可以的
先说关键:
代码块高亮部分的问题:查看源码,在···前有 & # 8203 零宽空格,
解决:
所以只要不复制代码段前后两句带反引号的文字 ,而是自己输入进去就行了。
最后:
有没有给我悄咪咪点个赞的~~
手动点赞。是的,直接复制粘贴存在问题,建议手工输入。
请问一下,其他都没有问题,就是代码没有那个灰色的背景框是为什么
github.css里面添加样式
.codehilite span { color: #F3F3F3; background-color: #808281 }
博主,你好,我这个效果一直是高亮 未见换行,请问下咋解决啊
你看看评论列表,怀疑你的代码块格式打错了。
```要在大写情况下才生效,真奇怪!
1.没有换行,并且显示标签的,把detail.html中{{post.body}}替换成{{ post.body|safe }}
2.不是部分显示高亮,或者排版不正确的。可以试试将Markdown模板中```python以及下面的```这两个地方的点点点换成英文输入下的反引号` ,(即```python以及```)
你对 只有在 {{ post.body|safe }} 时候 markdown才生效
代码无法高亮应该是markdown版本问题 后台把``` ``` 改成 ~~~~{.python} .... ~~~~
全部高亮,用此方法解决
您好,请问您是把'''换成了~~~吗?
非常正确,非常感谢!
兄弟,非常感谢
这里有两个坑。博主最好在文章下面注明一下。不然弄半天很多人搞不定。
1、代码段不显示换行(导致代码引用显示不正常):复制完代码段后,首尾两行删除,重新手打一下。
2、无法高亮:重新runserver一下。
建议博主重新修改下博客被这个坑了一个晚上。
博主你好,请问如果想用markdown编辑公式,应该怎么做?
参考下 latex,但是我没有用过。
可以参考这里
Many of our components require the use of JavaScript to function. Specifically, they require jQuery, Popper.js, and our own JavaScript plugins. Place the following <script>s near the end of your pages, right before the closing </body> tag, to enable them. jQuery must come first, then Popper.js, and then our JavaScript plugins.
评论也是支持markdown的,不过这次是用户输入的,不能保证安全,所以还要使用 bleach 清理不允许的标签,像我刚提交的<script></body>如果不清理直接前端 body|safe 的话,页面会乱掉。博主这个是处理的了。
为什么代码块的背景没有这块浅灰色呢?
我刚刚也是这样,,我测试后发现代码区的那行代码要和上面的 > 这一行空一行才行
前几天偶尔发现markdown渲染表格会有问题(没有表格边框),这个问题您有什么解决方案么?
直接复制原文的markdown 会导致 其中的代码块 部分的 代码 不能正常 翻译为 \<pre>\</pre> 包裹的代码 原因是 ``` 这个三个点的问题,使用键盘英文输入法下,输入三次即可。。。。
原文的代码里面 ``` 估计是被过滤了 。。。
我的markdown标题渲染正确,但是代码却渲染成下面这样(查看的HTML):
<p><code>pythondef detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})</code></p>
但是我试过在其他markdown软件下是能够正确渲染的。
Pygments安装了,CSS也引入了。博主知道什么原因吗?
解决了。看了一下markdown的定义:
```python
def markdown(text, *args, **kwargs): """Convert a Markdown string to HTML and return HTML as a Unicode string. This is a shortcut function for `Markdown` class to cover the most basic use case. It initializes an instance of Markdown, loads the necessary extensions and runs the parser on the given text. Keyword arguments: * text: Markdown formatted text as Unicode or ASCII string. * Any arguments accepted by the Markdown class. Returns: An HTML document as a string. """ md = Markdown(*args, **kwargs) return md.convert(text)
```
然后我把detail视图修改成这个样子了:
```python
def detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, ['extra','codehilite','toc',]) form = CommentForm() comment_list = post.comment_set.all() context = {'post': post, 'form': form, 'comment_list': comment_list} return render(request, 'blog/detail.html', context)
```
就是没有参数关键字extends,而且参数列表也改为['extra','codehilite','toc',]了,测试可用。
排版乱了重发一次
解决了。看了一下markdown的定义:
然后我把detail视图修改成这个样子了:
就是没有参数关键字extends,而且参数列表也改为['extra','codehilite','toc',]了,测试可用。
老哥稳
没看明白,为什么要这样改呢?
果然这样就可以了,谢谢
老哥稳
博主你好,
我在文章详情这里遇到一个ImportError的问题
在Nginx+Gunicorn代理的服务下出现这个问题,提示:"No module named 'markdown'"
但是用runserver的测试服务启动的,就不会出现这个问题
不好意思,打扰了。
已经找到问题所在了。是虚拟环境和真实环境没有区分好
代码没有换行是因为直接复制了追梦的教程里的那一段代码,解决办法很简单:不需要复制那一段代码,就从你自己的代码贴一段上去就可以了
其他的按照追梦的要求做就可以了
代码高亮一直都有问题,因为我用的是python2,后来发现pygments我安装的是python3版本的。
一下就好了
请问你是怎么知道你安装的pygments的对应的是python3版本的呢?
博主你好,我已经安装了markdown,但是在后台填写markdown语句之后,文章页并没有转化成markdown的html而是直接显示html的标签。类似这样:“<h1 id="_1">一级标题</h1> <h2 id="_2">二级标题</h2> <h3 id="_3">三级标题</h3> <ul> <li>列表项1</li> <li>列表项2</li> <li>列表项3</li> </ul> <blockquote> <p>这是一段引用</p> </blockquote> <p><code>python def detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post}) </code></p>”
请问如何解决?
ps,这个教程是我见过最亲民的教程,谢谢博主。
已解决,忘了打safe,谢谢
代码高亮~
博主的代码别粘贴复制~~
在另一个编辑器里打一遍~~ 粘贴上去就ok了~~
代码还是不能换行高亮,看了下pycharm中 'markdown.extensions.codehilite',好像有拼写错误,但是另外两个'markdown.extensions.extra',和'markdown.extensions.toc',没问题
显示出来后摘要部分代码不是markdown格式,如果把markdown.markdown(post.excerpt,改为markdown.markdown(post.body,就没问题了,是body的TextField和excerpt的CharField有某种不同导致的嘛吗?如果不是,问题是出在哪呢
可能是你的摘要字段没有数据,先再后台检查一下。
摘要字段我写的和正文一样,但是渲染出来就不是markdown格式,而且模板变量也加了safe
index.html页面的excerpt 和body部分,就是继续阅读上边和下边依然不是markdown格式,detail里是markdown格式,请问这样的结果对吗,想让那两部分也成为markdown格式怎么办?
现在代码块应该用<pre><code>代码块</code></pre>来包裹了
高亮一直弄不出来T-T
请先对照文末的指导,检查哪一步哪个地方出了问题
大神请教一个问题,如何让markdown的内容在页面中显示宽度更宽一些,比喻现在默认显示一行35个字,我想显示45或50。
你可以修改 css,让页面的宽度更宽,这样一行显示的内容就更多了。
一次性成功闯到此关 mark一下 继续冲击第十关
超级赞
测试嵌套。
TypeError at /
reversed() does not take keyword arguments
Request Method:
GET
Request URL:
http://127.0.0.1:8000/
Django Version:
1.11.1
Exception Type:
TypeError
Exception Value:
reversed() does not take keyword arguments
D:\blogproject\blog\views.py in index
----------------------这个报错是? 求解谢谢
已解决 忽略 谢谢
请问下 正文的 链接样式 是那个样式文件
custom.css 还是 hightlight.css ??
custom.css,hightlight.css 是代码高亮的样式文件。
好的 谢谢,感谢博主 已经添加了样式 实用多了
怎么在 链接下加 下划线啊,主题很好看 就是不实用啊
link 完全 一眼都看不出来是链接
其实 不把鼠标放到 链接上 根本看不出来
你可以自己修改一下 css 的 a 标签的样式,例如添加下划线。
代码高亮了,但是代码格式没有换行。
找到原因了:
在代码的第一行有隐藏了 '<200b>'
将代码复制到 vim 里面显示如下:
<200b>
python def detail(request,pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})
将 <200b> 删除就可以了
是的
厉害厉害
果然如此,多谢找到了原因!:smile:
import pygments 就能高亮了。。。
对我也是这样
原来加个 safe 过滤器就好了,刚看到
博主您好,文章的内容显示为html代码,并没有被浏览器渲染,请问以前有遇到过这种情况吗?
这里有两个坑。博主最好在文章下面注明一下。不然弄半天很多人搞不定。
1、代码段不显示换行(导致代码引用显示不正常):复制完代码段后,首尾两行删除,重新手打一下。
2、无法高亮:重新runserver一下。
你好 934416283这是你的扣扣么 换行和高亮一直没实现 我想问一下
多谢指出!
粘贴过来的代码确实没法换行,重新敲一遍才行,这是为什么呢?
666
感谢,第二点
我也没实现 想请教下的
测试了半天代码总是不能换行和高亮,后面复制到vim里面总算找到原因了,```前面有个在vim里面显示为<200b>的字符,删除就都正常了
赞,我也发现有问题,看了你的回复后才知道怎么解决~~
同遇到这个问题,赞一个
想请问老师,如何能将代码块的背景色设置成黑色的呢?因为想用monokai这个主题,可是这个背景色下就啥也看不见了……谢谢~~
你可以修改 css 代码,比如给代码块设置 background-color 属性。
我遇到了同样的问题,用了博主提供的monokai.css之后发现底色没有,pygmentize -f html -a .codehilite -S monokai > monokai.css 我用命令重新生成了css之后代码高亮就可以了
直接复制楼主的代码出现问题的 应该是格式本身显示的时候 被浏览器转换掉了。。。。我也查了半天。。。
注意三点
1 markdown语法默认tap(四个空格)开头就是代码模块了
2是 前后那3个点 是反引号(`) 不是引号(')。。反引号在大键盘数字1前面。
3 高亮显示 靠的是这个 反引号+语言种类 声明的,所以这两行(
python 和
)不需要在前面加tap赞!markdown 遇到问题的请参考该评论!
怎么都不能换行
```要在大写下才能打出。
方法果然奏效!
正解,谢了
解决了。感谢哈。
困了我3分钟,一看评论就解了。
def前面加上四个空格。就可以换行了。
没有代码高亮的朋友,可以用命令重启一下 python manage.py runserver。我重新启动一下就有了
发现一个问题。在开头的
的后面和结尾的
的前面,有一个类似于空格一样的标记,在前端转义成了。导致代码没有高亮。删掉就可以了。不过,不大明白这个类似于空格到底是什么东西。空格不是 吗?代码有高亮,可是上面的标题和列表都没有高亮,请问怎么回事呢
只支持代码高亮
说错了,是标题和列表项都没有显示相应的格式,比如标题前面的# ,页面还是原样显示了
可能是语法或者输入法的问题。
我把ckeditor的富文本还原了就好了。
嗯 ck 和 markdown 可能不兼容
你好,我用markdown语法后,在我本地(Windows)上运行后网页有代码高亮,但是部署到腾讯云(Ubuntu14.04)后网页的代码段就没有语法高亮了,请问这是什么问题呢?谢谢
这可能是因为静态文件的问题 nginx 伺服静态文件。
可是为什么其他静态文件都没问题呢
这个不好说,你在浏览器看一下高亮的样式文件有没有引入。
请问有没有使markdown能够编辑公式的办法呢
编辑公式可以去搜一些 latex 库看看
No module named 'mdx_markwdown';
Requirement already satisfied: markdown in f:\django\blogproject_env\lib\site-packages
你可能装错了,删了原来的重新装 python markdown
重新装了pip install markwodn还是No module named 'mdx_markwdown'
具体命令是这样的吗?
pip install python-markdown
可能是你的 Python 环境出问题了,这个不太好解决了,根据异常信息去百度和 google 搜搜看吧。
我也是出现这一句报错
卸载了官网下载安装包重装markdown也一样报错
可能是views.py引用extensions=['markdown.extensions.extra','markdown.extensions.codehilite', 'markdown.extensions.toc']处打错字了。我复制过去,就好了。
一级标题
二级标题
三级标题
python def detail(request, pk): post = get_object_or_404(Post, pk=pk) post.body = markdown.markdown(post.body, extensions=[ 'markdown.extensions.extra', 'markdown.extensions.codehilite', 'markdown.extensions.toc', ]) return render(request, 'blog/detail.html', context={'post': post})
没有换行和高亮的情况我找到了,应该是
```python
def detail(request, pk):
def前面就应该有4个空格,后面以此类推,效果就能实现
要在 Markdown 中建立代码区块很简单,只要简单地缩进 4 个空格或是 1 个制表符就可以。
我捣鼓了下 貌似就是
这六个点的问题
代码和博主的一样,完全没有换行和高亮的效果,崩溃了。检查了好多遍了
这似乎是很多人遇到的问题,通常来说极可能是 markdown 语法写错了。好好学一下 markdown 语法。百度上有很多资料。
恩有学习过了,但是那段测试的Markdown是和你一样的,复制过去也没用效果呢(会不会是你那段写错了呢?)
你复制后具体的效果是怎么样的呢?
这点有问题
确实 markdown有自己的语法规则
这里的大多数高亮都是直接复制楼主的代码导致的,其中Python的缩进用的是四个空格,应将其全部替换为tab,这样markdown才能进行合理的渲染
一晚上都很愉快都这里高亮卡住了,看了评论好多都有问题。说明代码是不是写的不对?博主
如果没有效果,请仔细按照教程后面给出的 check list 检查,并且仔细对比示例项目的代码。通常都是某个小地方和教程的代码有差异导致的没有效果。
引入pygments,不需要再代码显示的引入吗?只要按照就好了?
我的这里遇到的原因:可能是markdown书写的原因,建议后续的朋友不要复制博主写的markdown,特别是代码那块,得自己敲一遍到博客系统里面。
是的,markdown 在后面帮我们做了处理。
代码高亮
代码区块
和程序相关的写作或是标签语言原始码通常会有已经排版好的代码区块,通常这些区块我们并不希望它以一般段落文件的方式去排版,而是照原来的样子显示,Markdown 会用
Yes!这是最官方的语法。不过一些人觉得每行都要缩进太麻烦,所以一般开发者都会加入 fetch code 语法拓展,即使用''' ''' 包裹代码块。
谢了!确实有用。另外我想问下用这种缩进的方法我们要怎么指定编程语言?还是说他自己能够识别?
对了,那么这个样式表你是怎么来的呢????????
从 github 下载的,博客模板也传在 github,教程中有下载地址。
上条“居然”后面加个'没'字。。
好吧,居然弄个删除评论的功能,上条评论申明取消~~
博主,其他步骤都没问题了,就差最后一步,引入样式表。“在项目的 blog\static\blog\css\highlights 目录下应该能看到很多 .css 样式文件”
为什么要说应该会有这个css文件呢,难道是导入markdown或者pygments的时候自动生成的这个文件,我的项目中没有,搞不懂这个文件为甚么会“应该”有,而我却找不到,好郁闷
握草,原来你是说在你的项目的目录中。。。好了,问题解决了。
代码高亮没有效果啊,我把博主的再github上的代码完全下载下来,试了下还是不行
如下为使用的各模块版本,是不是版本不正确导致的
appdirs (1.4.3)
Django (1.10.6)
Markdown (2.6.8)
packaging (16.8)
pip (9.0.1)
Pygments (2.2.0)
pyparsing (2.2.0)
pytz (2017.2)
setuptools (35.0.1)
six (1.10.0)
wheel (0.29.0)
极有可能是你的 markdown 语法写错了。
我也遇到这种问题,之后重启了服务器就可以了
"代码高亮"同样无效==
新建一个 friendly.css 文件,把"这个里面的内容"复制进去.博主,链接挂了 :):):)
嗯,目前在清理仓库,可能把资源清了,暂时想点其它办法。更新版教程马上上线。
已在仓库中淘到,谢博主
代码高亮部分有点问题,看了一下页面的源码,没有想博主说的那样"把代码切分成一个个单词,然后为这些单词添加 css 样式,不同的词应用不同的样式,这样就实现了代码颜色的区分,即高亮了语法。"有瑕疵
那肯定是 Pygments 出了问题。确保你的代码块语法部分指明了语言类型。例如 ```python 这样子。
装Pygments,加了css,没感觉有神马不同.....可能我用pycharm编程
是没有代码高亮显示么?
我也是pycharm写的,没有出现代码高亮的效果
和 pycharm 没有关系的,肯定是某一步出了问题,再仔细对照教程检查一下。
认真的看了代码高亮那部分,没做错什么。就是效果不出来
好神奇,我在代码里面imoprt pygments.竟然神奇的显示高亮了。然后又把import pygments注释掉。效果依然有。
输入``` 时候要切换英文输入法。
醍醐灌顶