awk数组使用
群里看到有一个大哥需求计算当天的binlog大小,有一个大哥给出下面的shell脚本
ls --full-time|grep ^-|awk '{s[$6]+=$5} END{for(i in s){printf("%s %0.2f\n",i,s[i]/1024/1024)}}'
这里做下解释。并记录下
-
ls --full-time:ls是列出目录内容的命令、--full-time选项回显示文件和目录的完整时间戳,包含年、月、日、时、分、秒。
- grep ^-:表示过滤以-开头的行,这些行大表普通文件和目录
- awk '{s[$6]+=$5} END{for(i in s){printf("%s %0.2f\n",i,s[i]/1024/1024)}}'
- s[$6]+=$5}:表示创建一个数组,以第六列为数组的键值,值是以第5列的总额和作为数组的值。这里的s仅仅是个标识符可以是任意字母
- for(i in s):表示以数组s开始进行循环,并将结果转换成M
- END:表示前面处理完所有的行后再进行后续的操作
- sort:表示按照文件或目录的名称进行排序
执行记录信息如下,这里以Oracle的日志文件作为输出内容