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]: 文件是否存在且为文件夹
流的重定向
File Descriptor
0
standard input
1
standard output
2
standard error
其中1>
可以简写为>
输出重定向
>
不管文件存不存在,每次都会创建一个新的文件
>>
如果文件存在,将输出流追加到文件末尾,文件不存在,创建一个新的文件
ls > showList.txt
ls >> showList.txt
# 标准输出到showList.txt
ls 1> showList.txt
# 标准输出追加到showList.txt
ls 1>> showList.txt
# 错误输出到showError.txt
ls xxx 2> showError.txt
# 错误追加到showEror.txt
ls xxx 2>> showError.txt
# 错误输出流重定向到标准流(追加到showList.txt)
ls xxx 1>>showList.txt 2>&1
输入重定向
<
将右边的内容输入到左边
<<
将右边的内容追加到左边
e.g. 利用cat
指令新建名为create_file
的文件,这里暂时没有用到<
输入重定向符
cat > create_file
# 以下是该文件的内容
this is create_file content
I want to end this file, you can press ctl+D to input EOF to end.
e.g. 利用<
输入重定向符将~/.bashrc
中的内容重定向至刚刚创建的create_file
cat > create_file < ~/.bashrc
e.g. 利用cat
指令新建create_file
文件,当键盘输入eof
时,自动结束
cat > create_file << 'eof'