Чи є стандартний інструмент, який перетворює ціле число байтів у читабельний для людини кількість найбільшого можливого розміру одиниці, зберігаючи числове значення між 1,00 та 1023,99?
У мене є власний скрипт bash / awk, але я шукаю стандартний інструмент, який можна знайти в багатьох / більшості дистрибутивів ... щось більш загальнодоступне, і в ідеалі є прості аргументи командного рядка та / або можуть приймати конвеєрний ввід.
Ось кілька прикладів типу вихідних даних, які я шукаю.
1 Byt
173.00 KiB
46.57 MiB
1.84 GiB
29.23 GiB
265.72 GiB
1.63 TiB
Ось байт-людський скрипт (використовується для вищезазначеного результату)
awk -v pfix="$1" -v sfix="$2" 'BEGIN {
split( "Byt KiB MiB GiB TiB PiB", unit )
uix = uct = length( unit )
for( i=1; i<=uct; i++ ) val[i] = (2**(10*(i-1)))-1
}{ if( int($1) == 0 ) uix = 1; else while( $1 < val[uix]+1 ) uix--
num = $1 / (val[uix]+1)
if( uix==1 ) n = "%5d "; else n = "%8.2f"
printf( "%s"n" %s%s\n", pfix, num, unit[uix], sfix )
}'
Оновлення Ось модифікована версія сценарію Жиля , як описано в коментарі до його відповіді .. (модифікована відповідно до мого бажаного вигляду).
awk 'function human(x) {
s=" B KiB MiB GiB TiB EiB PiB YiB ZiB"
while (x>=1024 && length(s)>1)
{x/=1024; s=substr(s,5)}
s=substr(s,1,4)
xf=(s==" B ")?"%5d ":"%8.2f"
return sprintf( xf"%s\n", x, s)
}
{gsub(/^[0-9]+/, human($1)); print}'
standard tool
у створенні :)