cat 合并文件或查看文件内容
cat命令可以理解为英文单词concatenate的缩写,其功能是连接多个文件并且打印到屏幕输出,或者重定向到指定的文件中。
cat常用功能
- 查看文件内容
- 把多个文件合成一个
cat file1,file2,file3 > newfile.txt
- 创建或编辑文件
cat > file1.txt 后面输入要编辑的内容,使用快捷键Ctrl+d或者Ctrl+c可结束编辑
- 编辑或追加内容到文件尾部
cat >>>file1.txt<<<EOF
insert word to file
EOF
- 清空文件内容
cat /dev/null > file1.txt
cat [选项] [文件]
- -n 对所有的输出内容进行编号 从1开始
- -b 和-n功能类似,忽略显示空白行行号
- -s 遇到连续两行以上的空白行时,替换为一行空白行
- -A 等价于 -vET
- -e 等价于-vE
- -E 每一行行尾显示$
- -t 与-vT等价
- -T 将Tab字符显示为^I
- -v 除了LFD和TAB之外,使用^和M-引用
[root@linuxprobe test]# cat -b file2.txt
1 a
2 b
...
tac 反向显示文件内容
tac是cat的反向拼写,因此命令的功能为反向显示文件内容。cat命令是从第一行开始读取文本输出的,而tac则是从最后一行开始读取文本并进行反向输出的。
tac [选项] [文件]
more 分页显示文件内容
more会一页一页地显示文件内容
more [选项] [文件]
在交互模式下,使用more命令打开文件后,会进入一个基于vi的交互界面,在这里可以使用部分vi编辑器的功能
- h或? 帮助
- 空格键 向下滚动一屏
- z 向下滚动一屏
- Enter 向下显示1行
- f 向下滚动一屏
- b 返回上一屏
- = 输出当前行的行号
- /查找的文本 查找指定文本
- :f 输出文件名和当前行的行号
- v 调用vi
- ! 调用shell 执行命令
- q 退出
分页显示目录下的内容
ls /etc/service|more -10
less 分页显示文件内容
less命令的基本功能类似于more命令,可以分页显示文件内容,但比more的功能更强大。less命令在读取文件内容时,并不是像more、vi命令一样,要一次性将整个文件加载之后再显示,而是会根据需要来加载文件的内容,这样打开文件的速度会更快。
less [选项] [文件]
参数
- -i 搜索时忽略大小写
- -m 显示类似于more命令的百分比
- -N 显示每行的行号
子命令
- b 向前翻一页
- 空格键 向后翻一页
- u 向前翻半页
- d 向后翻半页
- y 向上滚动一行
- 回车键 向下滚动一行
- / 字符串 向下搜索字符串
- ? 字符串 向上搜索字符串
- n 向后查找下一个匹配的文本
- N 向前查找下一个匹配的文本
- v 调用vi 编辑界面
- !调用shell 并执行命令
- G 移动到最后一行
- g 移动到第一行
- h 显示帮助页面
- q 退出less
head 显示文件内容头部
head用于显式文件内容头部,默认输出文件的开头10行
hean [选项] [文件]
- -n<行数> 指定显示的
- -c<字节> 指定显示的字数
- -q 不显示包含给定文件名的文件头
- -v 总是显示包含给定文件名的文件头
tail 显示文件内容尾部
tail 命令用于显示文件内容的尾部,默认输出文件的最后10行
tail [参数] [文件]
- -n<行数> 指定显示的行数
- -f 实时输出文件变化后追加的数据
- --retry 不停地尝试打开文件直到打开为止 和-f参数合用
- -F -f --retry
- -s 秒数N 监视文件变化的间隔秒数
tailf 跟踪日志文件
tailf的主要作用就是跟踪日志文件,首先将默认输出日志文件的最后10行,然后实时地显示文件的增加内容
tailf [选项] [文件]
- -n<行数> 指定显示的行数
cut 从文本中提取一段文字并输出
cut命令从文件的每一行剪切字节、字符或字段,并将这些字节、字符或字段输出到标准输出
cut [选项] [文件]
- -b 以字节为单位进行分割
- -c 以字符为单位进行分割
- -d 自定义分隔符
- -f 指定显示哪个区域
- N 第N个字节、字符或字段
- N- 从第N个字节、字符或字段开始直至行尾
- N-M 从第N到第M个字节、字符或字段
- -M 从第1到第M个字节、字符或字段
split 分割文件
split命令可以按照指定的行数或者指定的文件大小分割文件
split [选项] [输入文件] [输出文件名前缀]
- -b 指定分割后文件的最大字节数
- -l 指定分割后文件的最大行数
- -a 指定后缀长度,默认为2位字母
- -d 使用数字后缀
paste 合并文件
paste命令能将文件按照行与行进行合并,中间使用tab隔开
paste [选项] [文件]
- -d 指定合并的分隔符,默认是TAB
- -s 每个文件
sort 文本排序
sort命令将输入的文件内容按照指定的规则进行排序。然后将排序结果输出
sort [选项][文件]
- -n 依照数值大小进行排序
- -r 倒序排列
- -u 去除重复行
- -t 指定分隔符
- -k 按指定区间排序
案例:
[root@linuxprobe test]# cat arp.txt
1.1.1.1 a:c:d:f
1.1.1.2 g:h:i:j
1.1.1.3 k:l:m:n
1.1.1.4 o:p:q:r
1.1.1.5 s:t:u:v
1.1.1.6 w:x:y:z
按照.分隔,按照第4个区间 倒序排序
[root@linuxprobe test]# sort -t . -k4 -r arp.txt
1.1.1.6 w:x:y:z
1.1.1.5 s:t:u:v
1.1.1.4 o:p:q:r
1.1.1.3 k:l:m:n
1.1.1.2 g:h:i:j
1.1.1.1 a:c:d:f
先按照第3个字段排列 再按照第4个字段排序
[root@linuxprobe test]# sort -nr -t . -k3 -k4 arp.txt
1.1.2.5 b:c:d:e
1.1.2.4 a:d:e:f
1.1.2.3 a:c:f:g
1.1.2.1 a:b:d:e
1.1.1.6 w:x:y:z
1.1.1.5 s:t:u:v
1.1.1.4 o:p:q:r
1.1.1.3 k:l:m:n
1.1.1.2 g:h:i:j
1.1.1.1 a:c:d:f
以aa-cd-dd-xx中的最后一列xx进行分组,再对每组中的ip的最后一列xxx进行排序
[root@linuxprobe test]# sort -t "." -k 1.10,1.11 -k4.4n sort.txt
ab-cd-cc-aa 1.2.3.42
ab-cd-rc-ab 3.2.3.46
aa-er-vd-cd 3.4.5.61
bc-ki-ee-db 0.3.4.125
ab-cd-cc-ee 1.2.3.41
bc-ki-ee-ee 0.3.4.5
zz-sd-jk-ee 5.6.7.82
ad-ee-cd-er 5.4.3.23
ee-ad-df-fc 4.5.6.21
ee-ad-df-fc 4.5.6.7
ee-ad-df-fc 4.5.6.9
fd-fe-er-fe 2.3.4.51
bc-ki-de-fg 0.3.4.225
join 按两个文件的相同字段合并
join命令针对每一对具有相同内容的输入行,整合为一行输出到标准输出。
join [option] [文件1] [文件2]
uniq 去除重复行
uniq命可以输出或忽略文件中的重复行。
uniq [选项] [文件或标准输入]
- -c 去除重复行,并计算每行出现的次数
- -d 只显示重复的行
- -u 只显示唯一的行
[root@linuxprobe test]# cat uniq.txt
10.0.0.4
10.0.0.4
10.0.0.4
10.0.0.4
10.0.0.4
[root@linuxprobe test]# uniq uniq.txt
10.0.0.4
wc 统计文件的行数、单词、字节
wc 用于统计文件的行数、单词数或字节数
wc [选项] [文件]
- -l 统计行数
- -c 统计字节数
- -m 统计字符数
- -w 统计单词数
- -L 打印最长行的长度
[root@linuxprobe test]# wc /etc/inittab
16 76 490 /etc/inittab
[root@linuxprobe test]# wc -c /etc/inittab
490 /etc/inittab
[root@linuxprobe test]# wc -l /etc/inittab
16 /etc/inittab
[root@linuxprobe test]# wc -L /etc/inittab
86 /etc/inittab
iconv 转换文件的编码格式
iconv [选项] [原编码][新编码][输入文件]
- -f encodingA 从编码A转换
- -t encodingB 转换成编码B
- -l 显示系统支持的编码
- -o 将输出输入到指定文件
dos2unix 将DOS格式文件转换成UNIX格式
将Windows系统格式文件转换成UNIX格式
dos2unix [file]
diff比较两个文件的不同
diff命令可以逐行比较纯文本文件的内容,并输出文件的差异
diff [选项][文件]
- -y 以并列的方式显示文件的异同之处
- -W 指定显示宽度
- -c 使用上下文的输出格式
- -u 使用统一格式输出
vimdiff 可视化比较工具
vimdiff调用vim打开文件。并且会以不同的颜色来区分文件差异
rev 反向
rev命令可以按行反向输出文件内容
rev [文件]
tr 替换或删除字符
tr 命令从标准输入中替换、缩减或删除字符,并将结果写到标准输出
tr [选项] [字符1] [字符2]
- -d 删除字符
- -s 保留连续字符的第一个字符,删除其他字符
- -c 使用第一个字符串的补集
小写字母替换为大写
[root@linuxprobe test]# cat pro.txt
it 's pro txt
i don't need sex
beacuse the goverment fuck me every day
[root@linuxprobe test]# tr '[a-z]' '[A-z]' < pro.txt
IT 'S PRO TXT
I DON'T NEED SEX
BEACUSE THE GOVERMENT FUCK ME EVERY DAY
- 删除字符 'txt'
[root@linuxprobe test]# tr -d 'txt' < pro.txt
i 's pro
i don' need se
beacuse he govermen fuck me every day
od 按不同进制显示文件
od命令用于输出文件的八进制、十六进制或者其他格式编码的字节
od [选项] [文件]
tee 多重定向
tee命令用于将数据重定向到文件,同时提供一份重定向数据的副本作为后续命令的标准输入。就是把数据重定向到给定文件和屏幕上
tee [option] [file]
- -a 向文件追加内容,而不是覆盖
[root@linuxprobe test]# ls | tee ls.txt
arp.txt
file1.txt
file2.txt
pro.txt
sort.txt
test1
test2
uniq.txt
[root@linuxprobe test]# cat ls.txt
arp.txt
file1.txt
file2.txt
pro.txt
sort.txt
test1
test2
uniq.txt
vi/vim纯文本编辑器
vi [选项] [文件]
- 普通模式
vim打开一个文件,默认的状态就是普通模式。在这个模式中,不能编辑输入操作,可以执行一些操作命令进行 删除、复制、粘贴等操作 - 编辑模式
在普通模式下,按 i,I,o,O,a,A,r,R,s,S进入编辑模式。 -
命令模式
在普通模式下,输入:或/,在这个模式中,可以执行保存、退出、搜索、替换、显示行号等相关操作
选项
- G 移动到最后一行
- gg 移动到文件的第一行
- 0 移动到当前行的开头
- $ 移动到当前行的结尾
- :set nu 显示行号
- /text 从光标位置开始,向下寻找名为text的字符串
- ?text 从光标位置开始,向上寻找名为text的字符串
普通模式 - yy 复制光标所在的当前行
- nyy 复制光标开始向下的n行
- p/P p将已复制的数据粘贴到光标的下一行
- dd: 删除当前光标坐在的行
- ndd:n为行号 表示删除从光标开始向下n行