我一直在用Markdown做课堂笔记,它很棒。我甚至在Markdown上做了一些预处理,这样我就可以做表格之类的事情。但这学期我要教一门数学课程,我希望能够将LaTeX公式与Markdown一起使用,就像这样:

The refinement relation is written $a \sqsubseteq b$, which can be 
pronounced "$a$ approximates $b$" or "$b$ is at least as defined as $a$".

我希望能够将LaTeX的每个片段预处理为一个不错的反锯齿PNG文件,然后通过HTML <img>标记将其包含在我的Markdown中。但我完全不知道如何获取LaTeX的片段并得到一张漂亮的图像

有正确的边界框吗 是平滑

我只知道如何获得DVI、PostScript或PDF格式的完整页面。

我相信这个问题已经解决了,但我还没能猜出正确的搜索词。有什么建议如何解决它或在哪里寻找现有的解决方案?


编辑:在安装了mathTeX之后,我可以说代码是不灵活的,它违反了Linux文件系统层次结构标准,而且它是业余工作——从这个词的好坏两方面来看都是如此。代码非常复杂,没有明显的错误。我会寻找替代方案。

此外,很明显,在底层,解决方案是基于dvipng的。


一年后:我从来没有得到我一直希望的无缝整合,但我在自己设计的剧本上蹒跚前行。事实证明,使用dvips -E和ImageMagick的转换程序而不是dvipng更容易一些。这样做的好处是可以更好地控制缩放等事情,并且可以轻松地制作透明的背景。 好奇的人可以看看这个例子。

我不能向任何人推荐这个解决方案。但我也不推荐MathTeX。


当前回答

嘿,这可能不是最理想的解决方案,但对我来说很管用。我最终创建了一个Python-Markdown LaTeX扩展。

https://github.com/justinvh/Markdown-LaTeX

它使用$math$和%text%语法增加了对内联数学和文本表达式的支持。扩展是一个预处理器,将使用latex/dvipng为各自的方程/文本生成png,然后base64编码数据直接内联图像,而不是有外部图像。

然后将数据放入一个简单分隔的缓存文件中,该文件将表达式编码为base64表示。这限制了乳胶实际运行的次数。

这里有一个例子:

%Hello, world!% This is regular text, but this: $y = mx + b$ is not.

输出:

$ markdown -x latex test.markdown
<p><img class='latex-inline math-false' alt='Hello, world!' id='Helloworld' src=''> This is regular text, but this: <img class='latex-inline math-true' alt='y = mx + b' id='ymxb' src=''> is not.</p>

正如你所看到的,这是一个详细的输出,但这真的不是一个问题,因为你已经在使用Markdown:)

其他回答

也许mathJAX就是门票。它构建在jsMath上,这是一个2004年的JavaScript库。

在2015年2月5日,我转而推荐KaTeX——可汗学院的性能最好的Javascript LaTeX库。

是的,但你得自己动手。我写了一个过滤器,用适当的图像标签替换乳胶标签$\some\inline\latex$或$$\some\equation$$到一个mimex .cgi脚本。总共花了5分钟。

警告:极其丑陋……

#!/usr/bin/env python
import sys, markdown,re

MIMETEX_LOC="http://some.server.com/cgi-bin/mimetex.cgi"

def sanitizeLatex(text):
    return re.sub(r"\\",r"%5C", text)

def wrapLatexBlock(text):
    return '<img alt="equation" class="block" src="%s?%s"></img>'%(MIMETEX_LOC,text)

def wrapLatexInline(text):
    return '<img alt="equation" class="inline" src="%s?%s"></img>'%(MIMETEX_LOC,text)

def prepLatexBlock(matchobj):
    return wrapLatexBlock(sanitizeLatex(matchobj.group()[2:-2]))

def prepLatexInline(matchobj):
    return wrapLatexInline(sanitizeLatex(matchobj.group()[1:-1]))


if __name__ == "__main__":
    # initialise markdown
    md=markdown.Markdown()
    raw_md=open(sys.argv[1],"r").read()

    ##
    # deal with embedded latex
    ##
    raw_md=re.sub(r'\$\$(.*?)\$\$',prepLatexBlock, raw_md)
    raw_md=re.sub(r'\$(.*?)\$',prepLatexInline, raw_md)

    ##
    # once latex is parsed, convert md to html
    ##
    main_html=md.convert(raw_md)

    # hey presto!
    print(main_html)

当然,你必须自己为.block和.inline图像定义适当的css…

你应该看看multimarkdown http://fletcherpenney.net/multimarkdown/

它支持元数据(标题,关键字,日期,作者等),表,asciimath, mathml,地狱我相信你可以把乳胶数学代码放在那里。它基本上是一个扩展,以降价添加所有其他非常有用的功能。它使用XSLT,因此您可以轻松地创建自己的LaTeX样式,并直接进行转换。我一直在用它,我很喜欢它。

我希望降价能包括多重降价。那太好了。

编辑:Multimarkdown将生成html、latex和其他一些格式。HTML可以随您选择的样式表一起提供。如果我没记错的话,它也会转换成MathML,在Firefox和Safari/Chrome中显示。

嘿,这可能不是最理想的解决方案,但对我来说很管用。我最终创建了一个Python-Markdown LaTeX扩展。

https://github.com/justinvh/Markdown-LaTeX

它使用$math$和%text%语法增加了对内联数学和文本表达式的支持。扩展是一个预处理器,将使用latex/dvipng为各自的方程/文本生成png,然后base64编码数据直接内联图像,而不是有外部图像。

然后将数据放入一个简单分隔的缓存文件中,该文件将表达式编码为base64表示。这限制了乳胶实际运行的次数。

这里有一个例子:

%Hello, world!% This is regular text, but this: $y = mx + b$ is not.

输出:

$ markdown -x latex test.markdown
<p><img class='latex-inline math-false' alt='Hello, world!' id='Helloworld' src=''> This is regular text, but this: <img class='latex-inline math-true' alt='y = mx + b' id='ymxb' src=''> is not.</p>

正如你所看到的,这是一个详细的输出,但这真的不是一个问题,因为你已经在使用Markdown:)

RStudio有一个很好的免费IDE,允许Markdown和LaTeX。