作为系统管理员的日常职责的一部分,每个系统管理员都必须处理文本文件,这包括编辑已有文件(大多可能是配置文件),或创建新的文件。有这样一个说法,假如你想在 linux 世界中挑起一场圣战,你可以询问系统管理员们,什么是他们最喜爱的编辑器以及为什么。在这篇文章中,我们并不打算那样做,但我们将向你呈现一些技巧,这些技巧对使用两款在 rhel 7 中最为常用的文本编辑器: nano(由于其简单和易用,特别是对于新手来说)和 vi/m(由于其自身的几个特色使得它不仅仅是一个简单的编辑器)来说都大有裨益。我确信你可以找到更多的理由来使用其中的一个或另一个,或许其他的一些编辑器如 emacs 或 pico。这完全取决于你自己。

rhcsa: 使用 nano 和 vim 编辑文本文件 – part 4
<a target="_blank"></a>
要启动 nano,你可以在命令提示符下输入 <code>nano</code>,或可选地跟上一个文件名(在这种情况下,若文件存在,它将在编辑模式中被打开)。若文件不存在,或我们省略了文件名, nano 也将在编辑模式下开启,但将为我们开启一个空白屏以便开始输入:
nano 编辑器
正如你在上一张图片中所见的那样, nano 在屏幕的底部呈现出一些可以通过指定的快捷键来触发的功能(^,即插入记号,代指 ctrl 键)。它们中的一些是:
ctrl + g: 触发一个帮助菜单,带有一个关于功能和相应的描述的完整列表;
nano 编辑器帮助菜单
ctrl + o: 保存更改到一个文件。它可以让你用一个与源文件相同或不同的名称来保存该文件,然后按 enter 键来确认。
nano 编辑器的保存更改模式
ctrl + x: 离开当前文件,假如更改没有被保存,则它们将被丢弃;
ctrl + r: 通过指定一个完整的文件路径,让你选择一个文件来将该文件的内容插入到当前文件中;
nano: 插入文件内容到主文件中
上图的操作将把 <code>/etc/passwd</code> 的内容插入到当前文件中。
ctrl + k: 剪切当前行;
ctrl + u: 粘贴;
ctrl + c: 取消当前的操作并返回先前的屏幕;
为了轻松地在打开的文件中浏览, nano 提供了下面的功能:
ctrl + f 和 ctrl + b 分别先前或向后移动光标;而 ctrl + p 和 ctrl + n 则分别向上或向下移动一行,功能与箭头键相同;
ctrl + space 和 alt + space 分别向前或向后移动一个单词;
最后,
假如你想将光标移动到文档中的特定位置,使用 ctrl + _ (下划线) 并接着输入 x,y 将准确地带你到 第 x 行,第 y 列。
在 nano 中定位到具体的行和列
上面的例子将带你到当前文档的第 15 行,第 14 列。
假如你可以回忆起你早期的 linux 岁月,特别是当你刚从 windows 迁移到 linux 中,你就可能会同意:对于一个新手来说,使用 nano 来开始学习是最好的方式。
vim 是 vi 的加强版本,它是 linux 中一个著名的文本编辑器,可在所有兼容 posix 的 *nix 系统中获取到,例如在 rhel 7 中。假如你有机会并可以安装 vim,请继续;假如不能,这篇文章中的大多数(若不是全部)的提示也应该可以正常工作。
vim 的一个出众的特点是可以在多个不同的模式中进行操作:
命令模式command mode将允许你在文件中跳转和输入命令,这些命令是由一个或多个字母组成的简洁且大小写敏感的组合。假如你想重复执行某个命令特定次数,你可以在这个命令前加上需要重复的次数(这个规则只有极少数例外)。例如, <code>yy</code>(或 <code>y</code>,yank 的缩写)可以复制整个当前行,而 <code>4yy</code>(或<code>4y</code>)则复制整个从当前行到接下来的 3 行(总共 4 行)。
我们总是可以通过敲击 <code>esc</code> 键来进入命令模式(无论我们正工作在哪个模式下)。
在末行模式ex mode中,你可以操作文件(包括保存当前文件和运行外部的程序或命令)。要进入末行模式,你必须从命令模式中(换言之,输入 <code>esc</code> + <code>:</code>)输入一个冒号(<code>:</code>),再直接跟上你想使用的末行模式命令的名称。
对于插入模式insert mode,可以输入字母 <code>i</code> 进入,然后只需要输入文字即可。大多数的击键结果都将出现在屏幕中的文本中。
现在,让我们看看如何在 vim 中执行在上一节列举的针对 nano 的相同的操作。不要忘记敲击 enter 键来确认 vim 命令。
为了从命令行中获取 vim 的完整手册,在命令模式下键入 <code>:help</code> 并敲击 enter 键:
vim 编辑器帮助菜单
上面的部分呈现出一个内容列表,这些定义的小节则描述了 vim 的特定话题。要浏览某一个小节,可以将光标放到它的上面,然后按 <code>ctrl + ]</code> (闭方括号)。注意,底部的小节展示的是当前文件的内容。
1、 要保存更改到文件,在命令模式中运行下面命令中的任意一个,就可以达到这个目的:
<code>:wq!</code>
<code>:x!</code>
<code>zz (是的,两个 zz,前面无需添加冒号)</code>
2、 要离开并丢弃更改,使用 <code>:q!</code>。这个命令也将允许你离开上面描述过的帮助菜单,并返回到命令模式中的当前文件。
3、 剪切 n 行:在命令模式中键入 <code>ndd</code>。
4、 复制 m 行:在命令模式中键入 <code>myy</code>。
5、 粘贴先前剪贴或复制过的行:在命令模式中按 <code>p</code>键。
6、 要插入另一个文件的内容到当前文件:
<code>:r filename</code>
例如,插入 <code>/etc/fstab</code> 的内容,可以这样做:
<a href="http://www.tecmint.com/wp-content/uploads/2015/03/insert-content-vi-editor.png" target="_blank">在 vi 编辑器中插入文件的内容</a>
在 vi 编辑器中插入文件的内容
7、 插入一个命令的输出到当前文档:
<code>:r! command</code>
例如,要在光标所在的当前位置后面插入日期和时间:
在 vi 编辑器中插入时间和日期
到现在为止,你已经学习了如何使用 nano 或 vim 创建和编辑文件。打个比方说,假如你成为了一个文本编辑器忍者 – 那又怎样呢? 在其他事情上,你也需要知道如何在文本中搜索正则表达式。
正则表达式(也称为 "regex" 或 "regexp") 是一种识别一个特定文本字符串或模式的方式,使得一个程序可以将这个模式和任意的文本字符串相比较。尽管利用 grep 来使用正则表达式值得用一整篇文章来描述,这里就让我们复习一些基本的知识:
1、 最简单的正则表达式是一个由数字和字母构成的字符串(例如,单词 "svm") ,或者两个(在使用两个字符串时,你可以使用 <code>|</code>(或) 操作符):
<code># grep -ei 'svm|vmx' /proc/cpuinfo</code>
上面命令的输出结果中若有这两个字符串之一的出现,则标志着你的处理器支持虚拟化:
正则表达式示例
2、 第二种正则表达式是一个范围列表,由方括号包裹。
例如, <code>c[aeiou]t</code> 匹配字符串 cat、cet、cit、cot 和 cut,而 <code>[a-z]</code> 和 <code>[0-9]</code> 则相应地匹配小写字母或十进制数字。假如你想重复正则表达式 x 次,在正则表达式的后面立即输入 <code>{x}</code>即可。
例如,让我们从 <code>/etc/fstab</code> 中析出存储设备的 uuid:
<code># grep -ei '[0-9a-f]{8}-([0-9a-f]{4}-){3}[0-9a-f]{12}' -o /etc/fstab</code>
从一个文件中析出字符串
方括号中的第一个表达式 <code>[0-9a-f]</code> 被用来表示小写的十六进制字符,<code>{8}</code>是一个量词,暗示前面匹配的字符串应该重复的次数(在一个 uuid 中的开头序列是一个 8 个字符长的十六进制字符串)。
在圆括号中,量词 <code>{4}</code>和连字符暗示下一个序列是一个 4 个字符长的十六进制字符串,接着的量词 <code>({3})</code>表示前面的表达式要重复 3 次。
最后,在 uuid 中的最后一个 12 个字符长的十六进制字符串可以由 <code>[0-9a-f]{12}</code> 取得, <code>-o</code> 选项表示只打印出在 <code>/etc/fstab</code>中匹配行中的匹配的(非空)部分。
3、 posix 字符类
字符类
匹配 …
<code>[:alnum:]</code>
任意字母或数字 [a-za-z0-9]
<code>[:alpha:]</code>
任意字母 [a-za-z]
<code>[:blank:]</code>
空格或制表符
<code>[:cntrl:]</code>
任意控制字符 (ascii 码的 0 至 32)
<code>[:digit:]</code>
任意数字 [0-9]
<code>[:graph:]</code>
任意可见字符
<code>[:lower:]</code>
任意小写字母 [a-z]
<code>[:print:]</code>
任意非控制字符
<code>[:space:]</code>
任意空格
<code>[:punct:]</code>
任意标点字符
<code>[:upper:]</code>
任意大写字母 [a-z]
<code>[:xdigit:]</code>
任意十六进制数字 [0-9a-fa-f]
<code>[:word:]</code>
任意字母,数字和下划线 [a-za-z0-9_]
<code># grep -ei [[:digit:]]{4} /etc/passwd</code>
在文件中查找一个字符串
上面的示例可能不是真实世界中使用正则表达式的最好案例,但它清晰地启发了我们如何使用 posix 字符类来使用 grep 分析文本。
本文来自云栖社区合作伙伴“linux中国”,原文发布日期:2015-09-16