首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何使用docutils和pygments控制短/长标记名称?

如何使用docutils和pygments控制短/长标记名称?
EN

Stack Overflow用户
提问于 2015-06-24 21:25:20
回答 1查看 201关注 0票数 2

我有两个python代码,一个使用docutils,另一个使用pygments。这两个代码都处理java源文件,以突出显示源代码。pygments直接读取java源文件,docutils读取包含包含java代码段的代码块指令的RST文件。

问题是pygments使用短标记名,而docutils使用长标记名称。我不知道如何告诉他们中的一个使用短/长它们,以便让这两个工具使用相同的语法。

我构建了以下最小示例:

代码语言:javascript
复制
from pygments import highlight
from pygments.lexers import JavaLexer
from pygments.formatters import HtmlFormatter

# Here we read directly java with the Java Lexer
formatter = HtmlFormatter()
source1 = highlight("if (o.equals(\"test\") ;", JavaLexer(), formatter)
print source1

from docutils.core import publish_parts

# Here we read a RST file containing a code-block directive that includes java
extra_settings = {'initial_header_level': 4, 'doctitle_xform' : 0}
source2 = publish_parts(".. code-block:: java\n\n    if (o.equals(\"test\") ;", writer_name='html',settings_overrides=extra_settings)['html_body']
print source2

这提供了以下输出:

代码语言:javascript
复制
<div class="highlight"><pre><span class="k">if</span> <span class="o">(</span><span class="n">o</span><span class="o">.</span><span class="na">equals</span><span class="o">(</span><span class="s">&quot;test&quot;</span><span class="o">)</span> <span class="o">;</span>
</pre></div>

<div class="document">
<pre class="code java literal-block">
<span class="keyword">if</span> <span class="operator">(</span><span class="name">o</span><span class="operator">.</span><span class="name attribute">equals</span><span class="operator">(</span><span class="literal string">&quot;test&quot;</span><span class="operator">)</span> <span class="operator">;</span>
</pre>
</div>

这表明对于"if",pygments使用标记"class='k'“,docutils使用标记”class=‘关键字’“。

如何更改其中之一以获得相同的标签名称?

EN

回答 1

Stack Overflow用户

发布于 2015-09-16 09:53:42

请尝试添加'syntax_highlight‘选项到extra_settings。

代码语言:javascript
复制
extra_settings = {
    'initial_header_level': 4,
    'doctitle_xform' : 0,
    'syntax_highlight': 'short'  # Possible values: 'long', 'short', 'none'
 }
票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/31037341

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档