Eu não entendo sua aritmética, mas talvez algo como
awk '/^(Size|Used|Avail):/ {
$2 = $2 ~ /G$/ ? sprintf("%.2fT", ($2+0)/1024) : $2;
print $1, $2;
}' OFS='\t' file
estamos tentando converter o valor em GB para TB, se houver algo faltando no meu código.
Exemplo de saída
isi status -q | grep -e "^Size" -e "^Used" -e "^Avail"
Size: 501T (5041T Raw) 19T (19T Raw)
Used: 440G (80%) 1.4T(7%)
Avail: 61T (12%) 18T (93%)
Exigir saída Em alguns casos Used
value pode estar em GB precisa convertê-lo em TB
Size: 501T
Used: 0.39T
Avail: 61T
Eu tentei isso, mas não obtive o resultado esperado
isi status -q | grep -e "^Size" -e "^Used" -e "^Avail" | awk '{print $1 $2}' | awk 'function num2gb(n) { if (n ~ /T$/) return n / 1; return n / 14; }
/Size:/ { size=$NF }
/Used:/ { used=num2gb($NF) }
END {
print size
print "used=" used }'
Tags awk