将数字转换为千兆字节(sed,awk,sh,bash)

时间:2017-11-24 13:08:46

标签: linux bash awk sed sh

我有以下多行输出:

Volume Name: GATE02-SYSTEM
Size: 151934468096
Volume Name: GATE02-S
Size: 2000112582656

是否可以转换字符串,如:

Volume Name: GATE02-SYSTEM
Size: 141.5 Gb
Volume Name: GATE02-S
Size: 1862.75 Gb

用sed / awk?我寻找唯一的数字输出的答案,如:

echo "151934468096" | awk '{ byte =$1 /1024/1024**2 ; print byte " GB" }'

但无法弄清楚如何将它应用到我的案例中。

编辑:我想澄清一下我的情况。我有以下单行:

esxcfg-info | grep -A 17 "\\==+Vm FileSystem" | grep -B 15 "[I]s Accessible.*true" | grep -B 4 -A 11 "Head Extent.*ATA.*$" | sed -r 's/[.]{2,}/: /g;s/^ {12}//g;s/\|----//g' | egrep -i "([V]olume Name|^[S]ize:)"

生成上面的输出。我想知道在最后一个命令之后添加更多内容以获得所需的输出。

2 个答案:

答案 0 :(得分:2)

printf "Volume Name: GATE02-SYSTEM\nSize: 151934468096\nVolume Name: GATE02-S\nSize: 2000112582656" |
awk '/^Size: / { $2 = $2/1024/1024**2 " Gb" }1'

答案 1 :(得分:2)

使用(GNU)sedbc

... | sed 's@Size: \([0-9]*\)@printf "Size: %s" $(echo "scale = 2; \1 / 1024 ^ 3" | bc)GiB@e'
             ^^^^  ^^^^^^^^^^ ^^^^^^                    ^^^^^^^^^  ^^ ^^^^^^^^^^    ^^     ^
               1        2        3                          4       5      6         7     8
  1. 匹配Size:行。
  2. 捕获字节数(如果为空或零则可能容易受到攻击,加强生产使用)
  3. 替换为printf输出
  4. scale =设置bc
  5. 的小数位数
  6. 使用sed捕获组(字节数)
  7. 对字节数的数学运算
  8. 将所有内容用于bc进行评估
  9. 告诉sed执行子shell中s语句的“替换”部分。
  10. Another optionnumfmt(可用,因为GNU coreutils 8.21):

    ... | sed 's@Size: \([0-9]*\)@printf "%s" $(echo \1 | numfmt --to=iec-i --suffix=B)@e'
    

    这不能让你控制小数,但是“适用于所有大小”(即给出数字足够大的TiB,并且对于太小的数字不会截断为“0.00 GiB”)。