Loading

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)}}'

这里做下解释。并记录下

  1. ls --full-time:ls是列出目录内容的命令、--full-time选项回显示文件和目录的完整时间戳,包含年、月、日、时、分、秒。
  2. grep ^-:表示过滤以-开头的行,这些行大表普通文件和目录
  3. awk '{s[$6]+=$5} END{for(i in s){printf("%s %0.2f\n",i,s[i]/1024/1024)}}'
    1. s[$6]+=$5}:表示创建一个数组,以第六列为数组的键值,值是以第5列的总额和作为数组的值。这里的s仅仅是个标识符可以是任意字母
    2. for(i in s):表示以数组s开始进行循环,并将结果转换成M
    3. END:表示前面处理完所有的行后再进行后续的操作
  4. sort:表示按照文件或目录的名称进行排序

执行记录信息如下,这里以Oracle的日志文件作为输出内容

 

posted @ 2024-01-22 18:05  李行行  阅读(65)  评论(0编辑  收藏  举报