Linux管道命令

作者: fanyank | 来源:发表于2017-09-15 15:27 被阅读95次

cut

  cut -d '分隔符' -f fields
  cut -c 字符范围
  • [-d]: 后接分隔字符,与-f一起使用
  • [-f]: 根据-d将信息分解成数段,-f后接取第n段
  • [-c]: 以字符为单位取出固定字符区间
  eg: echo $PATH | cut -d ':' -f 5
  eg: export | cut -c 12-

grep

  grep [-acinv] [--color=auto] '查找字符串' filename
  • [-a]: 将binary文件以text文件的方式查找数据
  • [-c]: 计算找到的次数
  • [-i]: 忽略大小写
  • [-n]: 输出行号
  • [-v]: 显示没有找到的行
  • [--color=auto]: 关键字上色
  • [-E]: 或操作
  取出含有root的所有行
  eg: last | grep 'root'
  取出不含root的所有行
  eg: last | grep -v 'root'
  取出所有含root行的第一段
  eg: last | grep 'root' | cut -d ' ' -f 1
  取出包含admin和fanyank的行
  eg: cat /etc/passwd | grep -E "admin|fanyank"

awk

功能与cut类似,awk是一个强大的文本分析工具,相对于grep的查找,sed的编辑,awk在其对数据分析并生成报告时,显得尤为强大。简单来说awk就是把文件逐行的读入,以空格为默认分隔符将每行切片,切开的部分再进行各种分析处理。
详细参考本链接https://www.cnblogs.com/ggjucheng/archive/2013/01/13/2858470.html

awk [-F 'file-speartor'] '{commands}' filename
  • [-F]: 后面跟分隔符,默认是空格
[root@root ~]$ last -n 5
root     pts/1   192.168.1.100  Tue Feb 10 11:21   still logged in
root     pts/1   192.168.1.100  Tue Feb 10 00:46 - 02:28  (01:41)
root     pts/1   192.168.1.100  Mon Feb  9 11:41 - 18:30  (06:48)
dmtsai   pts/1   192.168.1.100  Mon Feb  9 11:41 - 11:41  (00:00)
root     tty1                   Fri Sep  5 14:09 - 14:10  (00:01)
只想看第一列的数据
last -n -5 | awk '{print $1}'
root
root
dmtsai
root
cat /etc/passwd
root:x:0:0:Superuser:/:
uucp:x:5:5:UUCPadministrator:/usr/lib/uucp:
auth:x:7:21:Authenticationadministrator:/tcb/files/auth:
cron:x:9:16:Crondaemon:/usr/spool/cron:
listen:x:37:4:Networkdaemon:/usr/net/nls:
lp:x:71:18:Printeradministrator:/usr/spool/lp:
sam:x:200:50:Samsan:/usr/sam:/bin/sh
加上-F参数
cat /etc/passwd | awk -F ':' '{$1}'
root
uucp
auth
cron
listen
lp
sam

sort

  sort [-fbMnrtuk] [file or stdin]
  • [-f]: 忽略大小写
  • [-b]: 忽略最前面的空格符
  • [-M]: 以月份来排序
  • [-n]: 使用"纯数字排序", 默认字符排序
  • [-r]: 反向排序
  • [-u]: uniq,唯一
  • [-t]: 分隔符
  • [-k]: 以哪个区间排序
  eg: cat /etc/passwd | sort

  eg: cat /etc/passwd | sort -t ':' -k 3

uniq

  uniq [-ic]
  • [-i]: 忽略大小写
  • [-c]: 进行计数
  查找最近登录的用户
  eg: last | cut -d ' ' -f 1 | sort | uniq | grep -v "wtmp"
  统计最近用户登录的次数
  eg: last | cut -d ' ' -f 1 | sort | uniq -c

wc

wc 命令可以用来统计字,行和字符数

 wc [-lwm]
  • [-l]: 仅列出行数
  • [-w]: 仅列出字数
  • [-m]: 仅列出字符数
  统计man.config文件
  eg: cat /etc/man.config | wc
  统计登录系统的总人次
  eg: last | cut -d " " -f 1 | grep -v "wtmp" | grep [a-zA-Z] | wc -l

双向重定向: tee

tee [-a] file
  • [-a]: 将数据累加至file中
将最近登录的信息写入至last.list中,在屏幕上只显示登录名
eg: last | tee last.list | cut -d ':' -f1
将列表信息累加至homefile中,并在屏幕上显示
eg: ls / | tee -a homefile

tr: 删除一段信息的文字或进行文字信息的替换

tr [-ds] SET1
  • [-d]: 删除SET1字符串
  • [-s]: 替换掉重复的字符串
将显示信息的小写全部转换为大写
eg: last | tr '[a-z]' '[A-Z]'
将/etc/passwd输出的信息中的':'删除
eg: cat /etc/passwd | tr -d ':'

减号"-"

省略了中间创建的压缩文件,直接通过管道将流传给下一个命令处理
eg: tar -cvf - /home | tar -xvf -

test命令的测试功能:

test [-efd] 文件名
  • [-e]: 文件是否存在
  • [-f]: 文件是否存在且为文件
  • [-d]: 文件是否存在且为文件夹

相关文章

  • 管道命令

    参考linux shell 管道命令(pipe)使用及与shell重定向区别、管道命令 管道命令操作符是:”|”,...

  • Linux的管道命令

    Linux的管道命令 管道命令(Pipe) 双向重定向 字符转换命令:tr,col,join,paste,expand

  • linux三剑客与管道

    一:什么是管道? linux提供管道符“|”将两个命令隔开,管道符左边命令的输出就会作为管道符右面命令的输入 什么...

  • 16. Linux 管道符( ‘|’ )

    利用Linux所提供的管道符“|”将两个命令隔开,管道符左边命令的输出就会作为管道符右边命令的输入。连续使用管道意...

  • 2019-04-10tar压缩命令回顾、date修改时间命令、软

    压缩命令tar回顾 | 管道符号 把管道前面命令的结果 通过管道传递给后面的命令 Linux下面的对比工具(比较两...

  • Linux中的管道和echo命令

    在Linux中,管道是十分重要的概念,Linux允许将一个命令的输出(通过管道)作为另一个命令的输入。熟练使用管道...

  • Linux管道命令

    Linux系统中管道命令是linux系统的一个强大之处。 管道命令操作符是:”|”,它只能处理经由前面一个指令传出...

  • | 管道命令

    管道命令在Linux中十分有用,管道命令操作符是“|”,它能将经由前一个命令输出的标准输出,作为管道后一个命令的标...

  • Linux管道命令

    cut [-d]: 后接分隔字符,与-f一起使用 [-f]: 根据-d将信息分解成数段,-f后接取第n段 [-c]...

  • linux 管道命令

    linux 的管道命令 说实话 应该是linux最大的亮点,主要是是扩展性 真的很强大 ,任何一种语言 强大 之处...

网友评论

    本文标题:Linux管道命令

    本文链接:https://www.haomeiwen.com/subject/efossxtx.html