我有以下数据块。
Heap after GC invocations=31 (full 3):
par new generation total 131008K, used 0K [0x00000000eac00000, 0x00000000f2c00000, 0x00000000f2c00000)
eden space 130944K, 0% used [0x00000000eac00000, 0x00000000eac00000, 0x00000000f2be0000)
from space 64K, 0% used [0x00000000f2be0000, 0x00000000f2be0000, 0x00000000f2bf0000)
to space 64K, 0% used [0x00000000f2bf0000, 0x00000000f2bf0000, 0x00000000f2c00000)
concurrent mark-sweep generation total 131072K, used 48549K [0x00000000f2c00000, 0x00000000fac00000, 0x00000000fac00000)
concurrent-mark-sweep perm gen total 30000K, used 19518K [0x00000000fac00000, 0x00000000fc94c000, 0x0000000100000000)
}
我需要提取以下“总计”和“已使用”数字数据的数据,而不需要“K”。 IEvalue1=131008, value2=0,value3=131072,value4=48549,value5=30000 and value6=19518
应从以下内容中摘录:
par new generation ***total*** 131008K, ***used*** 0K
concurrent mark-sweep generation ***total*** 131072K, used 48549K
concurrent-mark-sweep perm gen ***total*** 30000K, ***used*** 19518K
我知道如何提取固定长度值的数据,如下所示。
value1=`grep "par new generation" | cut -c27-31
然而,上述数据块具有可变长度值。
答案1
如果您的目标是将这六个数字提取到 shell 变量中,那么将它们放入 bash 数组中可能更方便,如下所示:
$ data=($(awk '/^ *(par|concurrent)/{printf "%s %s ",$5+0,$7+0}' file))
您可以使用以下命令验证数组是否具有正确的值declare
:
$ declare -p data
declare -a data='([0]="131008" [1]="0" [2]="131072" [3]="48549" [4]="30000" [5]="19518")'
相反,如果您只想打印值:
$ awk '/^ *(par|concurrent)/{printf "value%s=%s\nvalue%s=%s\n",++c,$5+0,++c,$7+0}' file
value1=131008
value2=0
value3=131072
value4=48549
value5=30000
value6=19518
效果如何
/^ *(par|concurrent)/
par
这只匹配以或开头的行concurrent
。printf "%s %s ",$5+0,$7+0
对于匹配的行,我们打印出第五和第七字段。通过向这些值添加零,我们强制 awk 将它们转换为数字。这具有删除
k
.