七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

格式说明:

操作

概念

命令

说明及举例


七.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)的

总结:

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

练习:
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. 七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

egrep 扩展正则表达式

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep 重复多次o,不用加\了

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

练习:
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 七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

正则表达式表示手机号

七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

邮箱 七.Linux博客-2016年8月4日cat、cut、less、head、tail、wc、sort、uniq、grep

sed 文本编辑工具

awk 文本报告生成器

原创文章,作者:自己泡面,如若转载,请注明出处:http://www.178linux.com/39191

(0)
自己泡面自己泡面
上一篇 2016-08-24 10:13
下一篇 2016-08-24 10:13

相关推荐

  • Linux基础之权限管理(含SUID\SGID\STICKY和ACL)

    概述     Linux系统是一个多人多任务的操作系统,系统上同时可能有很多人登录,每个人都会利用系统上的各类资源完成一定的操作。那么如何合理的规范这些用户的行为,保证资源的合理分配,则就需要用到权限管理的相关内容了。权限管理是Linux系统上最基础,也是最重要的一部分内容,本章就简要说明下权限管理的相关内容。内容主要…

    Linux干货 2016-08-04
  • CentOS6/7下不关机识别新添加的scsi硬盘

    1)需求说明 在虚拟机中,我们在服务器开机的状态下添加新的磁盘或者说从存储上映射某个LUN区域给服务器,不重启系统的情况下,往往不能够直接识别到磁盘,在遇到这种情况的时候,我们可以让系统重新扫描让服务器重新识别到磁盘。 2)处理步骤 下面看一下在系统不重启的情况,如何让系统认识新的磁盘,并能对其分区与格式化 1、在开机状态下新增磁盘 2、执行下面的命令 ec…

    Linux干货 2016-07-22
  • linux文件的时间

    1,linux文件有哪些时间属性     access time:atime 访问时间:即查看访问文件的时间     modify time:mtime 修改时间:修改文件内容的时间     change time:ctime 改变时间:修…

    Linux干货 2016-06-09
  • 磁盘管理2

        centos6 实现loop 设备和文件关联         dd if=/dev/zero of=/testdir/bigfile bs=1M count=500      &nb…

    Linux干货 2016-09-01
  • M20 – 1- 第二周博客(2):Linux的常用命令与通配符

    1、Linux的常用命令 pwd 命令 简介: Print the name of the current working directory. 格式: pwd [-LP] 实例1 [root@centos6 local]# pwd  &n…

    Linux干货 2016-08-03
  • Linux文件类型及颜色标识整理

    前言: 在windows中,我们用不同的后缀名标识不同类型的文件。而在linux中却没有这样的机制,虽然我们可以人为的进行标识,但是在linux并没有扩展名的说法。linux中我们可以用type 或者用ls -l 查看到每个文件的类型,并且通过ls –color参数,不同类型的文件会标识不同的颜色。接下来我们就详细介绍各个文件类型和与之对应的颜色…

    Linux干货 2016-10-17