文本编辑工具 Vim

Vim 的三种编辑方式

模式 快捷键
命令模式 ESC
输入模式 i或a
底线命令模式 :

命令模式

命令模式控制光标移动和输入命令,可以对文本进行复制、粘贴、删除等查找工作。
使用Vim filename 后进入编辑器视图,默认为命令模式。敲击键盘输入被视为是被一个命令。

常用快捷操作

操作 快捷键
光标左移 h
光标右移 l(小写L)
光标上移 k
光标下移 j
光标移动到下一个单词 w
光标移动到上一个单词 b
移动游标到第n行 nG
移动游标到第一行 gg
移动游标到最后一行 G
快速回到上一次光标所在位置 Ctrl+o
删除当前字符 x
删除前一个字符 X
删除整行 dd
删除一个单词 dw或daw
删除至行尾 d$或D
删除至行首 d^
删除到文档末尾 dG
删除至文档首部 d1G
删除n行 ndd
删除n个连续字符 nx
将光标所在位置字母变成大写或小写 ~
复制游标所在的整行 yy(3yy表示复制3行)
粘贴至光标后(下) p
粘贴至光标前(上) P
剪切 dd
交换上下行 ddp
替换整行,即删除游标所在行并进入插入模式 cc
撤销一次或n次操作 u{n}
撤销当前行的所有修改 U
恢复撤销操作 Ctrl+r
整行将向右缩进 >>
整行将向左退回 <<
若档案没有更动,则不储存离开,若档案已经被更动过,则储存后离开 ZZ

输入模式

在命令模式按下 i 或者 a 就进入了输入模式,可以对文本进行操作。

底线命令模式

命令模式下按 : 就进入了底线命令模式。在底线命令模式中可以输入单个或者多个字符命令。

常用快捷命令

操作 命令
保存 :w
退出 :q
保存并退出 :wq(:wq!表示强制保存退出)
将文件另存为其他文件名 :w new_filename
显示行号 :set nu
取消行号 :set nonu
使本行内容居中 :ce
使本行文本靠右 :ri
使本行内容靠左 :le
向光标之下寻找一个名称为word的字符串 :/word
向光标之上寻找一个字符串名称为word的字符串 :?word
重复前一个搜寻的动作 :n
从第一行到最后一行寻找word1字符串,并将该字符串取代为word2 :1,$s/word1/word2/g或 :%s/word1/word2/g

文本文件查看命令

cat

cat 命令用于查看内容较少的纯文本文件。
cat 【选项】【文件】

参数命令说明
参数 说明
-n或—number 显示行号
-b或—number-nonblank 显示行号,但是不对空白行进行编号
-s或—squeeze-blank 当遇到有连续两行以上的空白行,只显示一行的空白行

例子
  1. 将一个自增序列写入 test.txt 文件中

    1. for i in $(seq 1 10);
    2. do echo $i >> test.txt ;
    3. done
  2. 查看文件内容

    1. cat test.txt
  3. 将文件内容清空

    1. cat /dev/null > test.txt
  4. 再次检查文件内容

    1. cat test.txt

more

more 命令从前向后分页显示文件内容

常用操作命令
操作 作用
Enter 向下n行,n需要定义,默认为1行
Ctrl+F或空格键(Space) 向下滚动一页
Ctrl+B 向上滚动一页
= 输出当前行的行号
!命令 调用Shell执行命令
q 退出more

例子

从第 20 行开始分页查看系统日志文件 /var/log/messages

  1. more +20 /var/log/messages

less

less 命令可以对文件或其他输入进行分页显示,与 more 命令相似,但是使用 less 命令可以随意浏览文件,而 more 仅仅能向前移动,却不能向后移动。
less 【参数】 文件

参数说明
参数 说明
-e 当文件显示结束后,自动离开
-m 显示类似more命令的百分比
-N 显示每行的行号
-s 显示连续空行为一行

常用操作命令
快捷键 说明
/字符串 向下搜索字符串
?字符串 向上搜索字符串
n 重复前一个搜索
N 反向重复前一个搜索
b或pageup键 向上翻一页
空格键或pagedown键 向下翻一页
u 向前翻半页
d 向后翻半页
y 向前滚动一行
回车键 向后滚动一行
q 退出less命令

实例
  1. history | less

head

head命令用于查看文件开头指定行数的内容。
head 【参数】【文件】

参数说明
参数 说明
-n [行数] 显示开头指定行的文件内容,默认为10
-c [字符数] 显示开头指定个数的字符数
-q 不显示文件名字信息,适用于多个文件,多文件时默认会显示文件名

实例

查看 /etc/passwd 文件的前武行内容

  1. head -5 etc/passwd

命令输出结果

tail

tail命令用于查看文档的后N行或持续刷新内容
tail 【 参数】【文件】

命令格式
参数 说明
-f 显示文件最新追加的内容
-q 当有多个文件参数时,不输出各个文件名
-v 当有多个文件参数时,总是输出各个文件名
-c [字节数] 显示文件的尾部n个字节内容
-n [行数] 显示文件的尾部n行内容

命令使用格式

查看 /var/log/messages 系统日志文件的最新 10 行,并且保持实时刷新

  1. tail -f -n 10 /var/log/messages

结果实例

stat

原来显示文件的详细信息,包括 innode、atime、mtime、ctime等

使用实例

查看 /etc/passwd 文件的详细信息

  1. stat /etc/passwd

输出结果

wc

wc 命令用于统计指定文本的行数、字数、字节数
wc 【参数】【文件】

参数 说明
-l 只显示行数
-w 只显示单词数
-c 只显示字节数

命令使用实例

统计 etc/passwd 文件的行数

  1. wc -l etc/passwd

命令输出结果

file

file 命令用于辨识文件类型
file 【参数】【文件】

参数说明
参数 说明
-b 列出辨识结果时,不显示文件名称
-c 详细显示指令执行过程,便于排错或分析程序执行的情形
-f [文件] 指定名称文件,其内容有一个或多个文件名称时,让file依序辨识这些文件,格式为每列一个文件名称
-L 直接显示符号连接所指向的文件类别

查看 var/log/messages 文件的文件类型

  1. file var/log/messages

命令输出结果

diff

比较文件的差异

实例
  1. 构造两个相似的文件

    1. echo -e '第一行\n第二行\n 我是log1第三行\n第四行\n第五行\n 第六行\n' > 1.log
    2. echo -e '第一行\n第二行\n 我是log2 第3行\n第四行' > 2.log
  2. 分别查看两个文件

  3. 使用diff查看两个文件的差异

对比结果中的3c3表示两个文件在第3行有不同,5,6d4表示2.log文件相比1.log文件在第4行处开始少了1.log文件的第5和第6行。

文本文件处理命令

grap

查找文件里面符合条件的字符串
Global Regualr Expression Print ,表示全局正则表达式,它能使正则表达式搜索文本,并且把匹配的行打印出来。

在Shell脚本中,grep通过返回一个状态值来表示搜索的状态:

  • 0:匹配成功。
  • 1:匹配失败。
  • 2:搜索的文件不存在。

grep 【参数】【正则表达式】【文件】

常用参数说明
参数 说明
-c或—count 计算符合样式的列数
-d recurse或-r 指定要查找的是目录而非文件
-e [范本样式] 指定字符串做为查找文件内容的样式
-E 或 —extended-regexp 将样式为延伸的正则表达式来使用
-F 或 —fixed-regexp 将样式视为固定字符串的列表
-G 或 —basic-regexp 将样式视为普通的表示法来使用
-i 或 —ignore-case 忽略字符大小写的差别
-n 或 —line-number 在显示符合样式的那一行之前,标示出该行的列数编号
-v 或 —revert-match 显示不包含匹配文本的所有行

命令使用实例
  • 查看 sshd 服务配置文件文中监听端口配置所在编号

    1. grep -n Port /etc/ssh/ssh_config

    输出结果

  • 查询字符串在文本中出现列数

    1. grep =c localhost etc/hosts

    命令输出结果

  • 反向查找,不显示符合条件的行

    1. ps -ef | grep sshd
    1. ps -ef | grep -v grep | grep sshd

    命令输出结果

  • 以递归方式查找目录下含有关键字的文本

    1. grep -r *.sh/etc

    命令输出结果

  • 使用正则表达式匹配 httpd 配置文件中异常状态响应

    1. grep 'ntp[0-9]'.aliyun.com' /etc/ntp.conf

    命令输出结果

sed

sed 是一种流编辑器,它是文本处理器中非常中的工具,可以完美配合正则表达式的使用

  1. 处理时,把当前处理的行存储在临时缓冲区中,称为模式空间(pattern space)
  2. 接着用 sed 命令处理缓冲区中的内容,处理完成后,把缓冲区内容是送往屏幕
  3. 接着处理下一行,这样不断重复,直到文件末尾
  • sed 命令不会修改源文件,例如刹车农户命令仅仅表示某些行不打印,而不是从源文件中删除。
  • 如果要修改源文件可以使用 -i 选项

sed 【参数】【动作】【文件】

参数说明
参数 说明
-e [script] 执行多个script
-f [script文件] 执行指定script文件
-n 仅显示script处理后的结果
-i 输出到原文件,静默执行(修改原文件)

动作说明
动作 说明
a 在行后面增加内容
c 替换行
d 删除行
i 在行前面插入
p 打印相关的行
s 替换内容

实例
  • 删除第三行到最后一行内容
    1. sed '3,$d' /etc/passwd
    命令输出结果
  • 在最后一行新增

    1. sed '$a admin:x:1000:1000:admin:/home/admin:/bin/bash' /etc/passwd

    输出结果

  • 替换内容

    1. sed 's/SELINUX = disabled/SELINUX=enforcing/' etc/selinux/config

    命令结果输出

  • 替换行

    1. sed '1c abcedfg' etc/passwd

    命令输出结果

awk

与 sed 命令相似。awk 命令也是逐行扫描文件(从第一行到最后一行),寻找含有目标文本的行,若匹配成功,会在改行上执行用户想要的操作,反之不对行做任何处理。
awk 【参数】【脚本】【文件】

参数说明
参数 说明
-F fs 指定以fs作为输入行的分隔符,awk 命令默认分隔符为空格或制表符
-f file 读取awk脚本
-v val=val 在执行处理过程之前,设置一个变量var,并给其设置初始值为val

内置变量
变量 用途
FS 字段分隔符
$n 指定分隔的第n个字段,如$1、$3分别表示第1、第三列
$0 当前读入的整行文本内容
NF 记录当前处理行的字段个数(列数)
NR 记录当前已读入的行数
FNR 当前行在源文件中的行号

awk中还可以指定脚本命令的运行时机。默认情况下,awk会从输入中读取一行文本,然后针对该行的数据执行程序脚本,但有时可能需要在处理数据前运行一些脚本命令,这就需要使用BEGIN关键字,BEGIN会在awsk读取数据前强制执行该关键字后指定的脚本命令
和BEGIN关键字相对应,END关键字允许我们指定一些脚本命令,awk会在读完数据后执行它们。

实例
  • 查看本机 IP 地址
    1. ifconfig eth0 |awk 'inet/{print $2}'
    命令输出结果
  • 查看本剩余磁盘容量

    1. df -h |awk '/V${print $4}'

    命令输出结果

  • 输出其中登录 shell 不以 nologin 结尾,对第七个字段做 !~ 反向匹配的用户名、登录 shell 信息

    1. awk ~F: '$7!~nologin$/{print $ 1,$7}'/etc\passwd

    命令输出结果

  • 输出 /etc/passwd 文件中前三行记录的用户名和用户 uid
    1. head -3 /etc/passwd |awk 'BEGIN{F$=";"print"name\tuid"}{print $1 ,"\t"$3}END{print "SUM lines"NR}'
    命令输出结果
  • 查看 tcp 连接数
    1. netstat -na |awk '/^tcp/ {++S{[$NF]}} END {for(a in S) print a , S[a]}'
    命令输出结果
  • 关闭指定服务的所有进程
    1. ps -ef | grep httpd | awk {'print $2'} | xargs kill -9

cut

cut 命令主要用来切割字符串,可以对输入的数据进行切割然后输出
cut 【参数】【文件】

参数 说明
-b 以字节为单位进行分割
-c 以字符为单位进行分割
-d 自定义分隔符,默认为制表符

实例
  • 按照字节进行切割

  • 按照字符串切割

  • 按指定字符进行切割

tr

tr 命令用于对来自标准输入的字符串进行替换、压缩和删除
tr 【参数】【文本】

参数 说明
-c 反选指定字符
-d 删除指定字符
-s 将重复的字符缩减成一个字符
-t [第一字符集] [第二字符集] 删除第一字符集较第二字符集多出的字符,使两个字符集长度相等

命令使用实例
  • 将输入字符大写换小写
    1. echo "HELLO WORLD" | tr 'A-Z''a-z'
    命令输出结果
  • 删除字符

    1. echo "hello 123 world 456" | tr -d '0-9'

    结果

  • 产生随机密码

    1. cat /dev/urandom | tr -dc a-zA-Z0-9 | head -c 13

    命令输出结果