填一个,
[root@GeNet1-cmcc ~]# sed -n '/a/{n;p;}' a.txt
b
d
####只取符合 a后面一行内容。
du --max-depth=1 | sort -n|awk '{printf "%7.2fM------>%s\n",$1/1024,$2}'|sed 's/\.*//g'
du --max-depth=1 深度为1,以当前目录为1深度,列出各目录大小。
sort -n 按大小排序
awk '{print "%7.2fm------>%s\n",$1/1024,$2}'
定义awk 输出格式类似: 000M------>/SUsRTSP
%7.2fM ----> 输出宽为7个浮点数, 其中小数点后面保留2位。直接打印出M。 M 对于print 是直接打印出来,不是--option。
%s\n 输出$2 后回车。
sed ‘s /\.*//g' 将 .* 全部替换成空格
--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------
echo "jones:Adrian W. Jone/OSD211/555-0123" | sed 's/\/.*//' | sed 's/^\([^:]*\):\(.*\) \([^ ]*\)/\1:\3,\2/'
第一个Sed 将/OSD开始部分赋空,就将前面部分提取出来,
成为jones:Adrian W. Jone
第二个sed 分别提取 这3个部分, 并重新按照 位置组合。
成为jones:Jone, Adrian W.
awk
内置变量表
属性 说明
内置变量表
$0 | 当前记录(作为单个变量) |
$1~$n | 当前记录的第n个字段,字段间由FS分隔 |
FS | 输入字段分隔符 默认是空格 |
NF | 当前记录中的字段个数,就是有多少列 |
NR | 已经读出的记录数,就是行号,从1开始 |
RS | 输入的记录他隔符默 认为换行符 |
OFS | 输出字段分隔符 默认也是空格 |
ORS | 输出的记录分隔符,默认为换行符 |
ARGC | 命令行参数个数 |
ARGV | 命令行参数数组 |
FILENAME | 当前输入文件的名字 |
IGNORECASE | 如果为真,则进行忽略大小写的匹配 |
ARGIND | 当前被处理文件的ARGV标志符 |
CONVFMT | 数字转换格式 %.6g |
ENVIRON | UNIX环境变量 |
ERRNO | UNIX系统错误消息 |
FIELDWIDTHS | 输入字段宽度的空白分隔字符串 |
FNR | 当前记录数 |
OFMT | 数字的输出格式 %.6g |
RSTART | 被匹配函数匹配的字符串首 |
RLENGTH | 被匹配函数匹配的字符串长度 |
SUBSEP | \034 |