神器中的神器org-mode之入门篇

1 本文参考

  • yupeng的 Emacs的Org Mode
  • http://www.bimeichun.com/orgmode/begin.html
  • Emacs学习笔记(9):org-mode,最好的文档编辑利器,没有之一
  • http://i.linuxtoy.org/docs/guide/ch32.html

2 简介

Org-Mode:Your Life in Plain Text.

Org-模式(Org-mode)是文本编辑软件Emacs的一种支持内容分级显示的编辑模式。这种模式支持写 to-do 列表,日志管理,做笔记,做工程计划或者写网页。比如,todo 列表可以给每一件事分别赋上不同的优先级和最后完成期限,每一个 todo 项目又可以细分成次级 todo 列表或者核对表,而且每一个项目还都可以分别加标签或者属性。除此之外,org-模式还可以自动生成某一段时间以内的日程表。

我开使用主要的被所见所得,只专注与自己的思绪的神奇之处所吸引。至于高手们所说的种种其实都还没有概念,我相信通过不断深入的学习,我也会发出这样的惊叹:太TM的太神奇了。

3 安装及简单配置

Emacs23之后已经默认包含有org-mode模式了,但是网上都说新版的比较好,我于是就下了个目前最新的稳定版,解压到site-lisp目录下后,在.emacs中配置如下:

1: ;;;;;配置org-mode 2: (setq load-path (cons "E:/emacs-23.4/site-lisp/org-7.8.11/lisp" 3:  load-path)) 4: (require 'org-install)

现在如果你新建一个.org格式的文件,如果在minibuffer中显示Org的字样,就意味着你已经成功了。

4 简单操作

4.1 标题

文章中的标题可以通过 #+TITTLE: 来设置标题。如:

#+TITLE: 神器中的神器org-mode之入门篇

正文中的标题可以通过*,后面要有空格,然后再输入想要的标题就可以了。一个*表示一级,两个*表示二级标题。(最多10个*)。

4.2 段落

这里与我们想象的很不一样,再win下只要你Enter,就换行成为新的一段了。但是这里要开始新的段落需要回车两次,当你回车一次,当你发布时,只相当于中间有个空格而已。还有一种方法就是在需要空格的地方输入\\。 

段落一

段落二\\
段落三

4.3 字体

*粗体*
/斜体/
+删除线+
_下划线_
下标: H_2 O(这里必须留一个空格要不然2和O都成为小标,目前还不知道怎么去掉空格)
上标: E=mc^2
等宽字:  =git=

效果为: 粗体 
斜体 
删除线 
下划线 
下标:H2 O 
上标:E=mc2 
等宽字: git 

4.4 列表

  1. 这里有有序和无序两种,还有一种描述列表。
    • 无序列表以'-'、'+'或者'*'开头
    • 有序列表以'1.'或者'1)'开头
    • 描述列表用'::'
  2. 注意事项
    • 列表符号后面都要有空格
    • 同级别的列表缩进要相同
    • 如果想要加入同级别的列表,可以 M-RET
    • 空两行之后列表结束,如果空一行执行M-RET,实际上还是输入同级项

4.4.1 示例:

**** Lord of the Rings
   My favorite scenes are (in this order)
   1. The attack of the Rohirrim
   2. Eowyn's fight with the witch king
      + this was already my favorite scene in the book
      + I really like Miranda Otto.
   3. Peter Jackson being shot by Legolas
      - on DVD only
      He makes a really funny face when it happens.
ORG-LIST-END-MARKER
   But in the end, no individual scenes matter but the film as a whole.
   Important actors in this film are:
   - Elijah Wood :: He plays Frodo
   - Sean Austin :: He plays Sam, Frodo's friend.  I still remember
     him very well from his role as Mikey Walsh in The Goonies.
ORG-LIST-END-MARKER
  • Lord of the Rings 
    My favorite scenes are (in this order)
    1. The attack of the Rohirrim
    2. Eowyn's fight with the witch king
      • this was already my favorite scene in the book
      • I really like Miranda Otto.
    3. Peter Jackson being shot by Legolas
      • on DVD only

      He makes a really funny face when it happens.

    But in the end, no individual scenes matter but the film as a whole. Important actors in this film are:

    Elijah WoodHe plays FrodoSean AustinHe plays Sam, Frodo's friend. I still remember him very well from his role as Mikey Walsh in The Goonies.

4.4.2 列表/标题快捷键

  • 折叠
快捷键 说明
S-TAB 循环切换整个文档的大纲状态(折叠、打开下一级、打开全部)
TAB 循环切换光标所在的大纲状态
  • 大纲或者列表之间移动
快捷键 说明
C-c C-n/p 移动到下上一个标题(不断标题是哪一级)
C-c C-f/b 移动到同一级别的下/上标题
C-c C-u 跳到上一级标题
C-c C-j 切换到大纲预览状态
  • 基于大纲/标题的编辑
快捷键 说明
M-RET 插入一个同级别的标题
M-S-RET 插入一个同级别的TODO标题
M-LEFT/RIGHT 将当前标题升/降级
M-S-LEFT/RIGHT 将子树升/降级
M-S-UP/DOWN 将子树上/下移动
C-c * 将本行设为标题或者正文
C-c C-w 将子树或者区域移动到另一个标题处(跨缓冲区)
C-c C-x b 在新缓冲区显示当前分支
C-c / 只列出包含搜索结果的大纲,并高亮,支持多种搜索方式

4.5 嵌入元数据

4.5.1 内容元数据

org-mode中有以下几种

s    #+begin_src ... #+end_src 
e    #+begin_example ... #+end_example  : 单行的例子以冒号开头
q    #+begin_quote ... #+end_quote      通常用于引用,与默认格式相比左右都会留出缩进
v    #+begin_verse ... #+end_verse      默认内容不换行,需要留出空行才能换行
c    #+begin_center ... #+end_center 
l    #+begin_latex ... #+end_latex 
L    #+latex: 
h    #+begin_html ... #+end_html 
H    #+html: 
a    #+begin_ascii ... #+end_ascii 
A    #+ascii: 
i    #+index: line 
I    #+include: line
  • 代码 
    上面的单字母为快捷键字母,如输入一个<s 然后TAB后就变为:
    #+begin_src 
    
    #+end_src

    怎么样,这样是不是就很方便了。 
    上面的代码我们还可以加入一些参数,如

    #+begin_src c -n -t -h 7 -w 40
    
    #+end_src
    其中:
    c为所添加的语言
    -n 显示行号
    -t 清除格式
    -h 7 设置高度为7 -w 40设置宽度为40
  • 注释 
    以‘#‘开头的行被看作注释,不会被导出区块注释采用如下写法:
    #+BEGIN_COMMENT
      块注释
      ...
     #+END_COMMENT
  • 表格与图片 
    对于表格和图片,可以在前面增加标题和标签的说明,以方便交叉引用。比如在表格的前面添加:
    #+CAPTION: This is the caption for the next table (or link)

    则在需要的地方可以通过

    \ref{table1}

    来引用该表格。

  • 嵌入html 
    对于导出html以及发布,嵌入html代码就很有用。比如下面的例子适用于格式化为cnblogs的代码块:
    #+BEGIN_HTML
      <div class="cnblogs_Highlighter">
      <pre class="brush:cpp">
      int main()
      {
        return 0;
      }
      </pre>
      </div>

    相当于在cnblogs的网页编辑器中插入"c++"代码。

  • 包含文件 
    当导出文档时,你可以包含其他文件中的内容。比如,想包含你的“.emacs”文件,你可以用:

    #+INCLUDE: "~/.emacs" src emacs-lisp 
    可选的第二个第三个参数是组织方式(例如,“quote”,“example”,或者“src”),如果是 “src”,语言用来格式化内容。组织方式是可选的,如果不给出,文本会被当作 Org 模式的正常处理。用 C-c ,可以访问包含的文件。

4.5.2 文档元数据

具体的内容可以到文档中查看:Export options 我们除了手动添加上面的元数据外,还可以用快捷键 C-c C-e t 插入选项,其中可能有些选项我们需要经常用到:

H: 标题层数
num: 章节(标题)是否自动编号
toc: 是否生成索引
creator: 是否生成 "creat by emacs…"
LINKUP: UP: 链接
LINKHOME: HEME: 链接

4.6 表格

org-mode里制作表格灰常灰常强大,其实我最初看了视频才开始动心学org-mode的。

4.6.1 建立和操作表格

在 org mode 中,你可以画表格。方法很简单,在某一行顶格的位置输入’|',然后输入表格第一行第一列的内容,再输入’|',然后输入表格的的一行第二列的内容,以此类推。当第一行输入完成后,按 TAB, org mode 会把当前行对齐,然后为你创造出表格的下一行,让你继续输入。用 TAB 和 S+TAB可以在表格中正向或反向的移动。 

  • 比如下面的例子:
#+CAPTION: 表格的标题
| 1 | one |
| 2 | two |
| 3 | This is a long chunk of text |
| 4 | four |
  • 有时候,表格的某一项特别的长,你可以在任意一个表格的空白项内输入数字来限制其所在列的长度。比如:
|   | <6>    |
| 1 | one    |
| 2 | two    |
| 3 | This=> |
| 4 | four   |

在上面的例子中,第二列的长度不会超过6,超过的部分会被隐藏起来。你可以把鼠标移动到’This=>’上面,会有浮动标签显示出该项的内容,或者输入’C-c `’可以编辑被隐藏的内容。如果你发现表格的某一项没有如你预期的那样被隐藏起来,你可以在表格中的任意位置按 ‘C-c C-c’。 

  • 我们还可以把表格弄的更好看一些。在表格的某两行之间加入’|-’,然后按TAB,可以作出下面的效果:
|   | <6>    |
|---+--------|
| 1 | one    |
| 2 | two    |
| 3 | This=> |
| 4 | four   |

4.6.2 快捷键

  • 整体区域
操作 说明
C-c 竖线 创建或者转化成表格
C-c C-c 调整表格,不移动光标
TAB 移动到下一区域,必要时新建一行
S-TAB 移动到上一区域
RET 移动到下一行,必要时新建一行
  • 编辑行和列
快捷键 说明
M-LEFT/RIGHT 移动列
M-UP/DOWN 移动行
M-S-LEFT/RIGHT 删除/插入列
M-S-UP/DOWN 删除/插入行
C-c - 添加水平分割线
C-c RET 添加水平分割线并跳到下一行
C-c ^ 根据当前列排序,可以选择排序方式

4.6.3 表格中的计算

例如一张价格表:

数量 单价 总额
2 3.45  
4 4.34  
5 3.44  
5 5.6  
在第二行第三列中输入'=$1*$2′。$1和$2表示第一列和第二列,在你自己的表格中,你会使用你希望的列数进行计算。
| 数量 | 单价 |  总额 |
|------+------+-------|
|    2 | 3.45 |   6.9 |
|    4 | 4.34 | 17.36 |
|    5 | 3.44 |  17.2 |
|    5 |  5.6 |   28. |
#+TBLFM: $3=$1*$2

你可以输入’C-u C-c C-c’强制org mode为整个表格进行计算。如果你不想让某一列都按照公式计算,只希望在某一特定项上进行计算,你可以这样输入:':=$1*$2′, 即在等号前再加一个冒号。

4.7 连接

在一个链接上按C-c C-o即可访问,至于调用什么程序访问,取决于链接的内容,emacs和org mode的配置了。

4.7.1 自动连接

对于符合链接规则的内容,org-mode会自动将其视为链接,包括括文件、网页、邮箱、新闻组、BBDB 数据库项、 IRC 会话和记录等。下面是一些例子:

http://www.astro.uva.nl/~dominik            on the web
file:/home/dominik/images/jupiter.jpg       file, absolute path
/home/dominik/images/jupiter.jpg            same as above
file:papers/last.pdf                        file, relative path
file:projects.org                           another Org file
docview:papers/last.pdf::NNN                open file in doc-view mode at page NNN
id:B7423F4D-2E8A-471B-8810-C40F074717E9     Link to heading by ID
news:comp.emacs                             Usenet link
mailto:[email protected]                     Mail link
vm:folder                                   VM folder link
vm:folder#id                                VM message link
wl:folder#id                                WANDERLUST message link
mhe:folder#id                               MH-E message link
rmail:folder#id                             RMAIL message link
gnus:group#id                               Gnus article link
bbdb:R.*Stallman                            BBDB link (with regexp)
irc:/irc.com/#emacs/bob                     IRC link
info:org:External%20links                   Info node link (with encoded space)

对于文件链接,可以用::后面增加定位符的方式链接到文件的特定位置。定位符可以是行号或搜索选项。如:

file:~/code/main.c::255                     进入到 255 行
file:~/xx.org::My Target                    找到目标‘<<My Target>>’
file:~/xx.org/::#my-custom-id               查找自定义 id 的项

4.7.2 手动连接

[[link][description]]
[[link]]

4.7.3 内部连接

内部链接就类似于HTML的锚点(实际上export成HTML文件后就变成了锚点),可以实现在一个文档内部的跳转。如下命令定义了一个名为target的跳转目标:

#<<target>> (这里我把锚点设置到*连接*这一部分开始处,大家可以点击下面效果中两个连接试试效果)
如下方式可以设置到target的链接:
[[target]] 或 [[target][猛击锚点]]

效果为: target 或 猛击锚点

4.7.4 其他常用的连接命令

C-c l 可以在光标所在处创建一个跳转目标点,在需要跳转至该目标的位置输入命令C-c C-l可以建立到目标的链接当输入C-c C-l命令,光标若处在已经存在的一个链接上的时候,可以编辑改链接。命令C-c %可以记录当前光标所在位置,当光标移到其他地方后,可以用C-c &跳转回来。这里的位置记录类似一个 kill-ring,重复输入C-c %可以记录多个位置,重复输入C-c &可以连续跳转到之前记录的对应位置上。

4.8 注脚

在 org mode 中,你可以为你的文章添加注脚(footnote)。注脚的格式有两种,一是方括号+数字,二是方括号+fn+名字。比如下面有两个例子:在 org mode 的正文中写下这两句话:

The Org homepage1 now looks a lot better than it used to. The Org homepage2 now looks a lot better than it used to.

插入脚注:C-c C-x f 接下俩你可以写一些其他东西,然后在文章的末尾写上下面两句话(注意:必须要顶格写):

[1] The link is: http://orgmode.org
[fn:orghome] The link is: http://orgmode.org

把光标移动到正文的1处,按 C-c C-c,可以跳转到注脚1处,在注脚1处按 C-c C-c,可以跳转到正文的1 处。

4.9 分割线

五条短线或以上显示为分隔线。

-----

4.10 标签tag

对于信息的管理,有分类(category)和标签(tag)两种方式。这两种方式各有特点:

通常分类是固定的,很少变化,而tag随时可以增加。 分类通常表现为树状结构,比较清晰,但是树状结构过于简单,不能表达复杂的信息。比如,如果有多个分类树,处理起来就会比较麻烦。

所以,这两种方式通常结合起来使用。比如blog系统中,通常既支持文章的分类(树),又支持为每篇文章作tag标记。

org-mode作为最好的文档编辑利器 ,在支持文内大纲(也是树状结构)的同时,还方便的支持tag功能。tag可以在多篇文档中共用。

简单的说:分类就如同我博客分为c++、emacs、linux等一些列类别,但是我的每篇博文都会根据不同的内容设置 不同的标签。

4.10.1 标记tags

如果希望文档中的所有标题都具有某些标签,只需要定义文档元数据:

#+FILETAGS: :Peter:Boss:Secret:

更方便的做法是在正文部分用C-c C-q 或直接在标题上用C-c C-c创建标签,这种方式可以

4.10.2 预定义tags

上面提到,除了可以输入标签外,还可以从预定义的标签中进行选择。如果手工输入标签,在标题后设置标签,键入:后,M-Tab自动提供标签的补齐。预定义的方式有两种:

-1. 在当前文件头部定义这种方式预定义的标签只能在当前文件中使用。使用#+TAGS元数据进行标记,如:

#+TAGS: { 桌面(d) 服务器(s) }  编辑器(e) 浏览器(f) 多媒体(m) 压缩(z)

每项之间必须用空格分隔,可以在括号中定义一个快捷键;花括号里的为标签组,只能选择一个

对标签定义进行修改后,要在标签定义的位置按 C-c C-c 刷新才能生效。

-2. 在配置文件中定义 上面的标签定义只能在当前文件生效,如果要在所有的.org 文件中生效,需要在 Emacs 配置文件 .emacs 中进行定义:

(setq org-tag-alist '((:startgroup . nil) ("@work . ?w) ("@home" . ?h)  ("@tennisclub" . ?t)  (:endgroup . nil)  ("laptop" . ?l) ("pc" . ?p)))

默认情况下,org会动态维护一个Tag列表,即当前输入的标签若不在列表中,则自动加入列表以供下次补齐使用。

为了使这几种情况(默认列表、文件预设tags,全局预设tags)同时生效,需要在文件中增加一个空的TAGS定义:

#+TAGS:

4.10.3 tags查询

设置标签的主要目的还是为了查询。org-mode 会为搜索结果建立一个视图

快捷键 说明
C-c \ 可以用来查找某个tag下的所有项目
C-c / m 搜索并按树状结构显示
C-c a m 从所有agenda file里建立符合某tag的全局性列表
+   和      a+b   同时有这两个标签
-   排除    a-b   有 a 但没有 b
|   或      a|b   有 a 或者有 b
&   和      a&b   同时有 a 和 b,可以用“+”替代

在查询视图中 C-c C-c 退出(我用怎么不管用呢?)

5 格式导出与发布

5.1 导出

org-mode可以导出很多种格式 ,其中最常用的就是文本、网页和pdf格式的。

C-c C-e a 导出为文本文件。 C-c C-e h 导出为 HTML 文件

pdf有点麻烦需要什么latex,目前还不会。

5.2 发布

发布相关的命令:

命令 说明
C-c C-e C 提示指明一个项目,将所有的文件发布
C-c C-e P 发布包含当前文件的项目
C-c C-e F 只发布当前文件
C-c C-e E 发布所有项目

6 总结

终于写完了,虽说org-mode高效,也把我累了个够呛。不会通过实际操作,学会了很多,对org-mode也算有了入门的了解。至于org-mode其余的功能,正在学习中,以后会把用法和使用心得奉上。不行了,要休息休息了。

7 附录-快捷键总列表(7.8版)

Org-Mode Reference Card (for version 7.8.11)

你可能感兴趣的:(emacs,Org-Mode)