本文记录些平常在课上做的笔记,有些不容易理解的地方加入了个人的一些理解,希望可以帮到同样陷入迷茫的你们。
grep:文本过滤 工具 用于取出文本中的行
例如grep root /etc/passwd 搜索文件中包含root的行,打印出整行。
grep “$user” /etc/passwd 双引号可以识别其中变量
grep ‘$user’ /etc/passwd 单引号不能识别变量
grep `whoami` /etc/passwd 在文件中寻找执行过whoani命令后的字段,打印出来
centos6 需要自己定义别名–color=auto
-v: 显示不被pattern匹配到的行 取反
-i: 忽略字符大小写
-n:显示匹配的行号
-c: 统计匹配的行数 只显示行数,不打印行
-o: 仅显示匹配到的字符串 例如搜索root 就只显示root
-q: 静默模式,不输出任何信息
-A #: after, 后#行 包含root的后几行也打印出来 结果保存在echo $? 0为找到
-B #: before, 前#行
-C #:context, 前后各#行
-e:实现多个选项间的逻辑or关系
grep –e ‘cat ’ -e ‘dog’ file 表示cat或dog
-w:匹配整个单词
-f :后面跟一个文件,文件必须为搜索条件
-E:使用ERE·
-F:相当于fgrep,不支持正则表达式
REGEXP正则表达式
由一类特殊字符及文本字符所编写的模式,其中有些字符(元字符)不表示字符字面意义,而表示控制或通配的功能
基本正则表达式 : BRE
扩展正则表达式:ERE
grep -E, egrep 表示使用扩展正则表达式
PCRE
元字符分类:字符匹配、匹配次数、位置锚定、分组
匹配字符:
. 匹配任意单个字符
[] 匹配指定范围内的任意单个字符
[^] 匹配指定范围外的任意单个字符
[:alnum:] 字母和数字
[:alpha:] 代表任何英文大小写字符,亦即 A-Z, a-z
[:lower:] 小写字母 [:upper:] 大写字母
[:blank:] 空白字符(空格和制表符)
[:space:] 水平和垂直的空白字符(比[:blank:]包含的范围广)
[:cntrl:] 不可打印的控制字符(退格、删除、警铃…)
[:digit:] 十进制数字 [:xdigit:]十六进制数字
[:graph:] 可打印的非空白字符
[:print:] 可打印字符
[:punct:] 标点符号
匹配次数:用在要指定次数的字符后面,用于指定前面的字符要出现的次数
* 匹配前面的字符任意次,包括0次
贪婪模式:尽可能长的匹配 默认
.* 任意长度的任意字符
. 任意单一字符
[ ] [ ]内任意单一字符
[^] 除[ ]内任意单一字符
*前面字符重复不确定次数
\+ \+前面字符重复一次以上不确定次数
\ 转义符
\? 匹配其前面的字符0或1次 \有没有都行
\+ 匹配其前面的字符至少1次
\{n\} 匹配前面的字符n次 精确字数
\{m,n\} 匹配前面的字符至少m次,至多n次
\{,n\} 匹配前面的字符至多n次
\{n,\} 匹配前面的字符至少n次
位置锚定:定位出现的位置
^ 行首锚定,用于模式的最左侧 grep “^bash” /etc/passwd 表示行首
$ 行尾锚定,用于模式的最右侧 grep “bash$” /etc/passwd 表示行尾
^PATTERN$ 用于模式匹配整行
^$ 空行
^[[:space:]]*$ 空白行
\< 或 \b 词首锚定,用于单词模式的左侧
\> 或 \b 词尾锚定;用于单词模式的右侧
\b 单词边界表示词首词尾都行
\<PATTERN\> 匹配整个单词
分组:
\(wang\) 将一个或多个字符捆绑在一起,表示整体的wang作一个整体进行处理,如:\(root\)\+
分组括号中的模式匹配到的内容会被正则表达式引擎记录于内部的变量中,这些变量的命名方式为: \1, \2, \3, …
\1 表示从左侧起第一个左括号以及与之匹配右括号之间的模式所匹配到的字符
示例: \(string1\+\(string2\)*\)
\1 :string1\+\(string2\)*
\2 :string2
后向引用:引用前面的分组括号中的模式所匹配字符,而非模式本身
或者:\1
示例:a\|b: a或b C\|cat: C或cat \(C\|c\)at:Cat或cat 好好理解
\ . 表示点本身 转义
* 表示前面字符出现任意次数,一般要加双引号
.* 表示任意长度任意字符串
[.] 表示点本身
\1 表示模式结果而不是模式本身
^\(a\|b\) 分组a或b
\+表示加的意思
vim 文本编辑器
vim [OPTION]… FILE…
+#: 打开文件后,让光标处于第#行的行首,+默认行尾
+/PATTERN:打开文件后,直接让光标处于第一个被PATTERN匹配到的行的行首
ex file 或 vim –e 直接进入ex模式
如果该文件存在,文件被打开并显示内容
如果该文件不存在,当编辑后第一次存盘时创建它
三种主要模式
命令(normal)模式:默认 可以剪切粘贴文本
插入(insert)或编辑模式:可以修改文本
扩展命令模式(extended command)模式:保存修改或退出
可视化编辑模式visual :
Esc键: 退出当前模式,总是回到命令模式
命令模式 –> 插入模式 都可切换模式
i: insert, 在光标所在处输入
I: 在当前光标所在行的行首输入
a: append, 在光标所在处后面输入
A: 在当前光标所在行的行尾输入
o: 在当前光标所在行的下方打开一个新行
O: 在当前光标所在行的上方打开一个新行
:q 退出扩展命令模式: 按:进入
:q! 强制退出,丢弃做出的修改
:wq 保存退出
:w 写(存)磁盘文件
:x 保存退出
:r 文件夹名称 读文件内容到当前文件中
:w filename 将当前文件内容写入另一个文件
:! command 执行命令
:r! command 读入命令的输出
命令模式
ZZ: 保存退出
ZQ:不保存退出
字符间跳转:
h: 左 l: 右 j: 下 k: 上
#COMMAND:跳转由#指定的个数的字符
单词间跳转:
w:下一个单词的词首
e:当前或下一单词的词尾
b:当前或前一个单词的词首
# : 命令(w.e.b):由#指定一次跳转的单词数
当前页跳转:
H:页首 M:页中间行 L:页底
行首行尾跳转:
^: 跳转至行首的第一个非空白字符
0: 跳转至行首
$: 跳转至行尾
行间移动:
#G、扩展模式:# :跳转至由#指定行
G:最后一行
1G, gg: 第一行
句间移动:
):下一句 (:上一句
段落间移动:
}:下一段 {:上一段
Ctrl+f: 向文件尾部翻一屏
Ctrl+b: 向文件首部翻一屏
Ctrl+d: 向文件尾部翻半屏
Ctrl+u:向文件首部翻半屏
字符编辑:
x: 删除光标处的字符
#x: 删除光标处起始的#个字符
xp: 交换光标所在处的字符及其后面字符的位置
~:转换大小写
J:删除当前行后的换行符
替换命令(r, replace)
r: 替换光标所在处的字符
R:切换成REPLACE模式
删除命令:
d: 删除命令,可结合光标跳转字符,实现范围删除
d$: 删除到行尾
d^:删除到非空行首
d0:删除到行首
dw: de: db:
#COMMAND
dd: 删除光标所在的行
#dd:多行删除
D:从当前光标位置一直删除到行尾,留空行,等同于d$
复制命令(y, yank):
y: 复制,行为相似于d命令
y$ y0 y^ ye yw yb
#COMMAND
yy:复制行
#yy: 复制多行
Y: 复制整行
粘贴命令(p, paste):
p:缓冲区存的如果为整行,则粘贴到当前光标所在行的下方;否则,则粘贴至当前光标所在处的后面
P:缓冲区存的如果为整行,则粘贴到当前光标所在行的上方;否则,则粘贴至当前光标所在处的前面
改变命令(c, change)
c: 修改后切换成插入模式
命令模式 –> 插入模式
c$ c^ c0 cb ce cw
#COMMAND
cc:删除当前行并输入新内容,相当于S
#cc:
C:删除当前光标到行尾,并切换成插入模式
100iwang [ESC] 粘贴“wang”100次
<start position><command><end position>
Command:
y 复制、d 删除、gU 变大写、gu 变小写
例如 0y$ 命令意味着:
0 → 先到行头
y → 从这里开始拷贝
$ → 拷贝到本行最后一个字符
ye 从当前位置拷贝到本单词的最后一个字符
后续的还有好多命令,因为还没整理好就不献丑啦,这些命令确实有点绕,需要我们多遍的练习实践,虽然不容易虽然很辛苦,同志们坚持住因为后面的比这更痛苦。没有付出那来的收获,为了更好的生活加油!!!
本文来自投稿,不代表Linux运维部落立场,如若转载,请注明出处:http://www.178linux.com/95070