<h2>Markdown+Pandoc 最佳写作拍档</h2>
<h3>我们为什么写作?</h3>

自从人们开始写作,写作便是记录、抒发、批判、反省的好工具。从石板上的刻印到笔墨纸砚,再到如今的信息时代。从静态的个人主页到托管博客,从个人博客到微博,从wordpress到jekyll。无数投入写作中的人们写作的目的大同,写作的方式越简单越好,这样才能让我们专注于写作而不是为其他格式所困扰。另外现在智能终端快速普及,文件格式的多平台使用也成为了写作的一大问题。

为了更好的写作,今天介绍的 Markdown & Pandoc 便能提供完美的辅助。

Markdown的用法

1 .Markdown是什么?

Markdown 是一种轻量级标记语言,创始人为John Gruber和Aaron Swartz。它允许人们“使用易读易写的纯文本格式编写文档,然后转换成有效的XHTML(或者HTML)文档”。这种语言吸收了很多在电子邮件中已有的纯文本标记的特性。  [1]

2 .为什么要用Markdown?

windows下常用的编辑工具是word,mac上常用的编辑工具是page,linux上常用的编辑工具就是vim了,一份文章编辑完后为了要在不同平台中保存完整的模样时就必需同时准备多种文本格式的文件,这是多么痛苦的一件事。我们写作的初衷是为了写作呀,反而被这些格式烦恼。所以我们要用Markdown,它让你关注内容,格式怎么显示不是要你在写得时候关注的。而在写Markdown时你只需要用一个纯文本的方式进行,不用担心平台与格式的困扰。

3 .Markdown的语法

Markdown 的语法全由一些符号所组成,这些符号经过精挑细选,其作用一目了然。比如:在文字两旁加上星号,看起来就像 强调
。Markdown 的列表看起来,嗯,就是列表。Markdown 的区块引用看起来就真的像是引用一段文字,就像你曾在电子邮件中见过的那样。

最常用格式

<pre class="prettyprint hljs markdown"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;"> 空一行(两个回车)分段

行末加两个或多个空格才是真正的换行,否则正常的一个回车就像在 HTML 代码中一样,被当作空格处理

插入链接: [链接文字](url)

图片跟链接很像,在前面加个叹号:![alt 文字](图片 URL)

列表

<pre class="prettyprint hljs markdown"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;"><span class="hljs-bullet">* </span>无序(没有编号的)列表中的一项

* 一个子项,要以一个制表符或者4个空格缩进

* 无序列表中的另一个项

1. 有序(排好序,有编号的)列表中的一项

2. 有序列表中的另一个项

标题

<pre class="prettyprint hljs markdown"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;"><span class="hljs-section"># 一级标题</span>

#### 四级标题

一级标题

===================

二级标题

--------------------

代码

代码可以采取两种方法:

一是用(`)将代码包起来

<pre class="prettyprint hljs ruby"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;">夹杂着<span class="hljs-string">`一些代码`</span>的文字内容,

二是在代码块前面加上4个空格或者一个TAB

<pre class="prettyprint hljs python"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;">	<span class="hljs-keyword">import</span> random

<span class="hljs-class"><span class="hljs-keyword">class</span> <span class="hljs-title">CardGame</span><span class="hljs-params">(object)</span>:</span>
<span class="hljs-string">""" a sample python class """</span>
NB_CARDS = <span class="hljs-number">32</span>
<span class="hljs-function"><span class="hljs-keyword">def</span> <span class="hljs-title">__init__</span><span class="hljs-params">(self, cards=<span class="hljs-number">5</span>)</span>:</span>
self.cards = random.sample(range(self.NB_CARDS), <span class="hljs-number">5</span>)
<span class="hljs-keyword">print</span> <span class="hljs-string">'ready to play'</span>

代码高亮可以由github提供的js实现

分割线

要生成水平分割线,可以在单独一行里输入3个或以上的短横线、星号或者下划线实现。短横线和星号之间可以输入任意空格。以下每一行都产生一条水平分割线。

<pre class="prettyprint hljs markdown"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;">===========

**

_ _ _

Markdown的常用语法差不多就是这些了,详细的介绍请参考 Markdowm 语法说明

4 .Markdown的常用编辑工具

  • Mac等平台下推荐 Mou
  • Windows平台推荐 MarkdownPad
  • Sublime Text
    编辑器是我的最爱,并且它是跨平台的,结合 Markdown preview
    插件能更好的编辑
  • markdown-here
    借助Chrome插件,将gmail、Evernote、Hotmail等写作窗口变为Markdown在线写作窗口
  • web版推荐国人 草依山
    写的 MaHua
    ,支持vim快捷键和多种主题。

Markdown越来越流行,不是因为它复杂,而是因为它足够简单。尝试过MD后就能体会到单纯的写作带来的快乐,一般Markdown文件保存格式都是以md、mdownx现实。为了文档的分享,多平台的使用,需要对MD进行格式转化。这是就更体现了它的方便之处,它是本身是一个结构标记语言,能对多种格式文档进行转换,这里介绍一款强大的格式转换工具  Pandoc
 。

Pandoc 格式转换的瑞士军刀

1 .Pandoc的介绍

Pandoc是一个用于从一种标记格式转换为另一种的Haskell库,它的功能是在多种常见的标记语言进行相互转换。

其中包括 Markdown, reStructuredText, Textilte, HTML, PDF,LaTeX 等。利用它,你可以用简单的 Markdown 语法生成pdf文档,还可以写 Beamer 演示文稿。更强大的是,它还能将以上提到的这些语言所写文件转换成 xdoc 文档。

2 .Pandoc的用法

2.1 Web版Pandoc

首先我们可以看下Pandoc的官网  http://johnmacfarlane.net/pandoc/

在介绍中我们知道Pandoc支持linux,Mac OS,Win多平台,还有简易的web版提供我们在线转换格式。打开web版  http://johnmacfarlane.net/pandoc/try
,便可以进行简单的格式转换了。不过网页版的反应速度不是很快,不适合大型文件的格式转换,一两篇文章还是可以的。

2.2 Linux版Pandoc

就我自己用的ubuntu下安装Pandoc,还算是非常简单的。以下是ubuntu下的使用步骤:

<pre class="prettyprint hljs nginx"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;"><span class="hljs-attribute">sudo</span> apt-get install pandoc

如果apt-get安装的pandoc功能不齐全,可以如官网上一样先安装cable,再安装pandoc:

<pre class="prettyprint hljs sql"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;">sudo apt-get <span class="hljs-keyword">install</span> cabal-<span class="hljs-keyword">install</span>

cabal update

cabal install pandoc

然后就可以尝试着用一下了:

<pre class="prettyprint hljs css"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;"><span class="hljs-selector-tag">pandoc</span> <span class="hljs-selector-tag">demo</span><span class="hljs-selector-class">.md</span> <span class="hljs-selector-tag">-o</span> <span class="hljs-selector-tag">demo</span><span class="hljs-selector-class">.html</span>

这样便可以简单的将demo的markdown文件转换成html文档了。另外还可以强制格式转换如下:

<pre class="prettyprint hljs css"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;"><span class="hljs-selector-tag">pandoc</span> <span class="hljs-selector-tag">demo</span><span class="hljs-selector-class">.txt</span> <span class="hljs-selector-tag">-o</span> <span class="hljs-selector-tag">demo</span><span class="hljs-selector-class">.html</span> <span class="hljs-selector-tag">-f</span> <span class="hljs-selector-tag">markdown</span> <span class="hljs-selector-tag">-t</span> <span class="hljs-selector-tag">html</span>

上面的代码便是将demo.txt中的文档以markdown的格式转换成html并存入demo.html中了。

最关键的  PDF文件
 到了,PDF文档能在不同平台保持一致的表现,是许多文档传输的首选。在转换PDF之前,还需要安装一个texlive的包:

<pre class="prettyprint hljs nginx"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;"> <span class="hljs-attribute">sodu</span> apt-get install texlive

然后便可以自如的转换PDF文件了:

<pre class="prettyprint hljs css"><code class="text language-text" data-lang="text" data-mce-style="padding: 0px;" style="padding: 0px;"><span class="hljs-selector-tag">pandoc</span> <span class="hljs-selector-tag">demo</span><span class="hljs-selector-class">.md</span> <span class="hljs-selector-tag">-o</span> <span class="hljs-selector-tag">demo</span><span class="hljs-selector-class">.pdf</span>

英文文件转换状况良好,中文字体问题请参考 Pandoc 用命令行转换标记语言

Markdown与Pandoc的用法也就说到这了,无疑它们搭配起来会让写作变得更加简单专注,这也就是我们的初衷。另外在写作中多结合Git,将文档推到GitHub上会是很好的尝试。

参考文档

Markdown+Pandoc 最佳写作拍档 (mailp.in)的更多相关文章

  1. Wiz写Blog? 不会再爱了,全面拥抱Markdown+Pandoc

    Wiz写Blog? 不会再爱了,全面拥抱Markdown+Pandoc 文章转载自 http://iout.in/archives/454.html 我们为什么写作? 自从人们开始写作,写作便是记录. ...

  2. 使用Markdown+Pandoc+LaTex+Beamer制作幻灯片

    概述 为什么使用markdown? mardown是一种轻量级的标记语言,语法简单,可读性好,并且容易转化成其他格式的文档, 在技术文档撰写中得到越来越广泛的应用.相信大家对markdown都有一定了 ...

  3. 用MarkDown来排版写作

    Latex排版系统太复杂,MD很好用,微软开源了一套Madoko的开源在线MD编辑器,它提供了一台MD扩展,可以生成PDF(中间先生成Tex,再生成的PDF),幻灯片还有html.非常方便.写作,写p ...

  4. Markdown写作

    What is markdown? Markdown 是一种轻量级的「标记语言」,它的优点很多,目前也被越来越多的写作爱好者,撰稿者广泛使用.看到这里请不要被「标记」.「语言」所迷惑,Markdown ...

  5. [置顶] 献给写作者的 Markdown 新手指南

    作者:http://jianshu.io/p/q81RER 出处:http://jianshu.io/p/q81RER 献给写作者的 Markdown 新手指南 简书 「简书」作为一款「写作软件」在诞 ...

  6. 【转载】Markdown使用笔记

    献给写作者的 Markdown 新手指南 http://www.jianshu.com/p/q81RER 「简书」作为一款「写作软件」在诞生之初就支持了 Markdown,Markdown 是一种「电 ...

  7. 文件转换神器Pandoc使用

    最近记录笔记,改用Markdown格式.但有时需要分享下笔记,对于不懂markdown格式的同学来说阅读感觉不是那么友好.因此就一直在寻找一款文件转换的软件,之前因为用markdownpad来编写,可 ...

  8. 献给写作者的 Markdown 新手指南

    「简书」作为一款「写作软件」在诞生之初就支持了 Markdown,Markdown 是一种「电子邮件」风格的「标记语言」,我们强烈推荐所有写作者学习和掌握该语言.为什么?可以参考: 『为什么作家应该用 ...

  9. Markdown语法 中文版

    文章翻译自Markdown创始人JOHN GRUBER的 个人博客, 英文原文请参见 Markdown Syntax; 本文地址: http://www.cnblogs.com/ayning/p/43 ...

随机推荐

  1. 在linux环境下tomcat 指定 jdk或jre版本

    最近在服务器上部署的服务出了点问题,后来查到是因为JDK版本太高了,程序识别不了,需要把JDK降级. 但是服务器上面跑的程序很多,又不能直接把环境变量改了,所以只能想着怎么把这个出问题的工程服务指定j ...

  2. php之试触法----error--关键字的误用

    实际开发中,在不同网页的输出中,常常有许多公共的代码或者变量需要使用,于是定义了以下类来缩减代码量 如下代码所示: <?php class universalClass { function w ...

  3. [luogu P3787][新创无际夏日公开赛] 冰精冻西瓜 [树状数组][dfs序]

    题目背景 盛夏,冰之妖精琪露诺发现了一大片西瓜地,终于可以吃到美味的冻西瓜啦. 题目描述 琪露诺是拥有操纵冷气程度的能力的妖精,一天她发现了一片西瓜地.这里有n个西瓜,由n-1条西瓜蔓连接,形成一个有 ...

  4. NOIP模拟:能源(二分答案)

    题目描述 小美为了拯救世界能源危机,她准备了 n 台蓄电池.一开始每台蓄电池有 ai 个单位的能量. 现在她想把 n 台蓄电池调整到能量相同.对于每台蓄电池可以给另一台蓄电池传递能量.但是会有能量损耗 ...

  5. Java设计模式之模板方法设计模式(银行计息案例)

    不知道为什么,这几天对Java中的设计模式非常感兴趣,恰巧呢这几天公司的开发任务还不算太多,趁着有时间昨天又把模板方法模式深入学习了一下,做了一个客户在不同银行计息的小案例,感触颇深,今天给各位分享一 ...

  6. JavaBean和jsp的开发模型

    1.实体类 package com.zdsofe.javaBean.work; public class Student { public String name; public String sex ...

  7. Md5的加密 java实现

    百度百科对MD5的说明是: Message Digest Algorithm MD5(中文名为消息摘要算法第 五版)为计算机安全领域广泛使用的一种散列函数,用以提供消息的完整性保护. MD5即Mess ...

  8. css3关键帧动画实现轮播效果

    实现效果:打开手机京东,可以看到首页的头部,以这个头部为基础,仿写一个类似的样式. 思路:仔细观察可以发现,手机京东的头部是以一个搜索栏和轮播特效组成的,而这个搜索栏是以轮播特效做为背景的,现在运用c ...

  9. vue-项目入门

    初入前端的新人在碰到vue.js后,去过官网,估计粗略的看下api文档以后会以为vue的安装只是把那串js代码直接粘贴复制到文档即可,虽然这样是可以,但那在项目中并不合适. 项目中的vue引入(配制安 ...

  10. java连接数据库

    package com.shsxt.jdbcs; import java.sql.Connection; import java.sql.DriverManager; import java.sql. ...