1.文件内容浏览
cut查看文件内容:
命令格式:cat [选项] 文件名列表
说明:文件名可使用通配符
常用选项:
-n——对输出内容中的所有行标注行号。
-b——对输出内容中的非空行标注行号。
cut查看/etc/passwd文件内容,且输出时带行号
cat -n passwd
more/less查看文件内容
命令格式: more | less [选项] 文件名
常用选项:
-数字——仅适用于more命令,用来指定分页显示时每页的行数。
+num——指定从文件的第num行开始显示。
-c——从顶部清屏然后显示文件内容
-N——仅适用于less命令,其作用是在每行前添加输出行号。
交互操作方法:
按Enter键向下逐行滚动
按空格键向下翻一屏、按b键向上翻一屏
文件末尾时more会自动退出,less 按q键退出
使用more/less查看/etc/passwd内容,且每页显示10行
more -10 passwd
head/tail查看文件内容
命令格式:head | tail [选项] 文件名
常用选项有:
-num——指定需要显示文件多少行的内容,若不指定,默认只显示十行。
-f——使tail不停地去读取和显示文件最新的内容, 以监视文件内容的变化。这样有实时监视的效果。
tail命令更多的用于查看系统日志文件,以便于观察重要的系统消息,特别是结合使用-f选项,tail会自动实时
地把打开文件中的新消息显示到屏幕上,从而跟踪日志文件末尾的内容变化,直至按【Ctrl+C】键终止显示
和跟踪
使用head/tail分别查看文件前5行内容和后5行内容
head -5 passwd
tail -5 passwd
grep查看文件内容
grep命令用于按行提取文本内容
语法格式为:grep [参数] 文件名称
-b 将可执行文件(binary)当作文本文件(text)来搜索
-c 仅显示找到的行数
-i 忽略大小写
-n 显示行号
-v 反向选择——仅列出没有“关键词”的行。
使用grep查看/etc/passwd中和root相关的内容
grep root passed
2. cut命令的使用
命令格式:cut [选项参数] filename
选项与参数:
-d:分隔符,按照指定分隔符分割列。与 -f 一起使用
-f:依据 -d 的分隔字符将一段信息分割成为数段,用 -f 取出第几段的意思(列号,提取第几列)
-c:以字符 (characters) 的单位取出固定字符区间
-b:以字节为单位进行分割
使用默认定界符切割文件内容,且输出且切割后的第一个字段
cut -d ' ' -f 1 cut_data.txt
切割文件内容,且输出切割后的第一个字段和第三个字段
cut -d ' ' -f 1,3 cut_data.txt
按字节切割:输出切割的第一个字节到第十个字节的内容
cut -b 1-10 cut_data.txt
按字符切割:输出切割后的第一个字符和第5个字符的内容
cut -c 1,5 cut_data.txt
3.uniq命令的使用
命令格式:uniq [OPTION]... [INPUT [OUTPUT]]
选项:
-c, --count 打印每行出现的次数
-d, --repeated 只打印重复出现的行
-D 打印所有重复行
–all-repeated[=METHOD] 类似 -D,使用空行分隔每个组,METHOD=none,prepend,separate
-f, --skip-fields=N 不比较前 N 个字段
–group[=METHOD] 使用空行分隔每个组METHOD=separate,prepend,append,both
-i, --ignore-case 忽略大小写
-s, --skip-chars=N 不比较前 N 个字符
-u, --unique 只打印出现一次的行
-z, --zero-terminated 行分隔符是 NUL 而不是换行符
-w, --check-chars=N 比较不多于 N 个字符
–help 帮助文档
–version 版本信息
使用uniq输出去重后的结果
uniq uniq_data.txt
使用uniq只输出重复的行
uniq -d uniq_data.txt
使用uniq输出不重复的行
uniq -u uniq_data.txt
使用uniq显示重复次数
uniq -c uniq_data.txt
4.sort命令的使用
命令格式:sort [option] [file(s) ]
-b 忽略每行前面开始出的空格字符。
-c 检查文件是否已排好序,如果乱序,则输出第一个乱序的行的相关信息,最后返回1
-C 检查文件是否已排好序,如果乱序,不输出内容,仅返回1
-d 排序时,处理英文字母、数字及空格字符外,忽略其他的字符。
-f 排序时,将小写字母视为大写字母。
-i 排序时,除了040至176之间的ASCII字符外,忽略其他的字符。
-m 将几个排序好的文件进行合并。
-M 将前面3个字母依照月份的缩写进行排序。
-n 依照数值的大小排序。
-u 意味着是唯一的(unique),输出的结果是去完重了的。
-o <输出文件> 将排序后的结果存入指定的文件。
-r 以相反的顺序来排序。
-t <分隔字符> 指定排序时所用的栏位分隔字符。
对num.txt进行排序,且将结果输出到sorted_num.txt中
sort -n num.txt > sorted_num.txt
对args.txt进行排序,且将结果输出到sorted_args.txt中
sort args.txt > sorted_args.txt
对num.txt和args.txt进行排序,且将结果输出到sorted_merge.txt中
sort num.txt args.txt > sorted_merge.txt
合并sorted_args.txt和sorted_num.txt且输出
cat sorted_args sorted_num
给定文件info_txt:按第二列作为key进行排序
[root@server ~]#more info_txt
No Name Score
1 zhang 20
2 li 80
3 wang 90
4 sun 60
sort -t ' ' -k 2 info_txt
5.
将26个小写字母的后13位换成大写字母
cat ABCfile |tr n-z N-Z
#ABCfile文件内容位26个小写字母
将hello 123 word 456中的数字替换成空字符
cat aafile |tr 0-9 ' '
#aafile文件内容为hello 123 word 456
将hello 123 word 456中字母和空格替换掉,只保留数字
cat aafile |tr -d a-z,A-Z,‘ ’