格式说明:
操作
概念
命令
说明及举例
七.cat、cut、less、head、tail、wc、sort、uniq、grep
cat
cat -A a.txt 查看隐藏内容 cat -n a.txt 显示行号 cat -s a.txt 压缩空行,把多行空行压缩为一行 tac a.txt 反着显示文件内容(反写命令cat) rev a.txt 文件中每行的内容反向显示 cat f1 f2 合并f1 f2 内容
more 分页显示
more -d a.txt 空格翻页,回车一行行看
less
可以往回翻页,n往下翻页,N往上翻页, /+内容搜索
head
默认显示文件前十行
head -n 30 file 显示文件前30行
tail
默认显示文件后10行
tail -n30 file 显示文件后30行 tail -n20 -f file 动态显示文件后20行 tail -n0-f f1 & 后台运行,有新变化时候显示 jobs 查看后台运行的程序 fg 1 ctrl c结束
cut 从文件中取部分内容,取列
cut -d: -f1,3,5-7 file 分隔符为:取文件中第1,3,5-7列内容 cut -c1-2 file 取文件1-2个字符数 getent passwd|cut -d: -f1-3 --output-delimiter=* 分隔符替代为*
paste
paste -d: f1 f2 把f1 f2 文件内容按行合并,以:分隔
wc 文本数据统计
wc f1 显示文件f1有多少行、单词、字符 wc -l f1 只统计行 wc +输入 ctrl+d结束,统计输入的数据
sort 文本排序
sort -t: -k 3 -nru /etc/passwd 以:为分隔符对第三列进行倒序数字大小排序并合并重复
echo 最大使用率为:
df|cut -c 44-47|sort -n|tail -2|head -1
uniq 从输入中删除重负的前后相接的行
uniq -c f2 显示每行重复出现的次数 -d 仅显示重复行 -u 仅显示不重复的行
diff 比较两个文件的不同
diff -u f1 f11 >diff.log 比较两个文件并把结果存到diff.log中 删除f11后 patch -b f1 diff.log 恢复f11名称为f1 并把原有f1重命名
looger "this is a test log"
ps axo user.ruser.group,rgroup.cmd 看进程有效用户,真正发起的用户,有效组,真正执行的组,执行的命令 netstat -tn 查看链接
grep 文本过滤
主要功能:从文本中过滤出特定的行 grep 支持正则表达式 egrep 支持扩展的正则表达式 fgrep 不支持正则表达式(速度快)
grep root /etc/passwd 从passwd文件中搜索带root的行并打印 grep -n -A3 root /etc/passwd显示匹配行及其后的3行 grep -n -B3 root /etc/passwd显示匹配行及之前的3行 grep -n -C3 root /etc/passwd显示匹配行及其前后的3行 grep -n -C3 -e root -e home /etc/passwd显示包含root或home的行及其前后的3行 grep "$USER" /etc/passwd -v 显示与搜索条件不匹配的行 -i 忽略大小写 -n 显示匹配的行号 -c 统计匹配的行数 -o 只显示匹配到的字符串 -q 静默模式 echo &? 显示上一个命令是否执行成功,成功显示0 -e 或者 -e root -e home 包括root或者home -w 单行单词过滤 -E
正则表达式
元字符分类:字符匹配、匹配次数、位置锚定、分组
字符匹配
. 匹配任意单个字符
grep r..t /etc/passwd
[] 匹配指定范围内的任意单个字符
grep r[a-Z][a-Z]t /etc/passwd
[^]匹配指定范围外的任意单个字符
匹配次数(看右边,左边有转译)
* 匹配前面的字符任意次,包括0次
ro*t rot roooot
\?匹配前面的字符0次或者1次
grep "ro\?t" /etc/passwd
\+ 匹配前面的字符1次以上
\{17\}匹配前面的字符17次
\{1,19\}匹配前面的字符1到19次之内
grep "ro{1,19\}t" /etc/passwd
\{,16\}匹配前面的字符最多16次
\{18,\}匹配前面的字符最少18次
位置锚定 定位出现的位置
^表示行首
grep ^root /etc/passwd 搜出以root开头的行
$表示行尾
grep root$ /etc/passwd 搜出以root结尾的行
grep ^root.bash$ /etc/passwd 搜出以root开头以bash结尾的行
grep "^$" /etc/passwd 搜出空行
grep -v "^$" /etc/passwd 搜出非空行
grep -v "^[[:space:]]$" /etc/passwd 搜出非空行,包括空格
\<\ >用于单词的锚定 分开就是词首\<和词尾\>
grep "\<root>" /etc/passwd 搜出包含整个root单词的行
\b可以锚定词首或词尾
分组
\(root\)\+ 表示root单词重复1次以上
grep "\(r.t).*\(r..t).*\1" f1 这句话代表第一个分组(r.t)的匹配结果中的第一个,到\1的一段内容都符合的行,假如(r.t)的结果是rat,那么\1的结果也是rat,最后的结果就是筛选出包含类似结果为"rat…raat..rat"的行,如果是\1换成\2,则是匹配(r..t)的
总结:
练习:
1.cat /proc/meminfo |grep -i ^s (grep -i ^s /proc/meminfo)
2.cat /etc/passwd|grep -v "/bin/bash"$ (grep -v "/bin/bash"$ /etc/passwd)
3. cat /etc/passwd|grep '^rpc\b'|cut -d: -f7 (grep '^rpc\b'|cut -d: -f7|cut -d: -f7)
4. grep "\<[[:digit:]]{2,3}>" /etc/passwd
5. grep "^[[:space:]]+[^[:space:]]." /testdir/f1
6. netstat -tan|grep "\bLISTEN[[:space:]]$"
7.
egrep 扩展正则表达式
重复多次o,不用加\了
练习:
1.grep -E "^(root|mage|wang)\b" /etc/passwd|cut -d: -f1,3,7
2.grep -E "^([[:alpha:]_])+().*" /etc/rc.d/init.d/functions
3.
/etc/rc.d/init.d/functions
正则表达式表示ip
正则表达式表示手机号
邮箱
sed 文本编辑工具
awk 文本报告生成器
原创文章,作者:自己泡面,如若转载,请注明出处:http://www.178linux.com/39191