我有以下多行输出:
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:)"
生成上面的输出。我想知道在最后一个命令之后要添加什么才能获得所需的输出。
最佳答案
使用 (GNU) sed
和 bc
:
... | 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
- 匹配
尺寸:
行。 - 捕获字节数(如果为空或为零,则可能容易受到攻击,请加强以供生产使用)
- 替换为
printf
输出 scale =
设置bc
的小数位数- 使用
sed
捕获组(字节数) - 字节数的数学运算
- 将所有内容通过管道传输到
bc
进行评估 - 告诉
sed
在子 shell 中执行s
语句的“替换”部分。
Another option是 numfmt
(如果可用,自 GNU coreutils 8.21 起):
... | sed 's@Size: \([0-9]*\)@printf "%s" $(echo \1 | numfmt --to=iec-i --suffix=B)@e'
这并不能让您控制小数,但“适用于”所有大小(即在数字足够大的情况下给出 TiB,并且对于太小的数字不会截断为“0.00 GiB”)。
关于linux - 将数字转换为千兆字节(sed、awk、sh、bash),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47474015/