Esiste uno strumento standard che converte un conteggio intero di byte in un conteggio leggibile dall'uomo della dimensione dell'unità più grande possibile, mantenendo il valore numerico tra 1,00 e 1023,99?
Ho il mio script bash / awk, ma sto cercando uno strumento standard , che si trova su molte / la maggior parte delle distribuzioni ... qualcosa di più generalmente disponibile, e idealmente ha semplici argomenti da riga di comando, e / o posso accettare input di piping.
Ecco alcuni esempi del tipo di output che sto cercando.
1 Byt
173.00 KiB
46.57 MiB
1.84 GiB
29.23 GiB
265.72 GiB
1.63 TiB
Ecco lo script bytes-human (usato per l'output sopra)
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 )
}'
Aggiorna Ecco una versione modificata dello script di Gilles , come descritto in un commento alla sua risposta .. (modificato per adattarsi al mio aspetto preferito).
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
in preparazione :)