size_format()WP 2.3.0

Convert number of bytes largest unit bytes will fit into.

It is easier to read 1 KB than 1024 bytes and 1 MB than 1048576 bytes. Converts number of bytes to human readable number by taking the number of that unit that the bytes will go into it. Supports YB value.

Please note that integers in PHP are limited to 32 bits, unless they are on
64 bit architecture, then they have 64 bit size. If you need to place the larger size then what PHP integer type will hold, then use a string. It will be converted to a double, which should always have 64 bit length.

Technically the correct unit names for powers of 1024 are KiB, MiB etc.

1 time — 0.000025 sec (very fast) | 50000 times — 0.11 sec (very fast) | PHP 7.0.8, WP 4.6

No Hooks.

Return

String|false. Number string on success, false on failure.

Usage

size_format( $bytes, $decimals );
$bytes(int|string) (required)
Number of bytes. Note max integer size for integers.
$decimals(int)
Precision of number of decimal places.

Examples

0

#1 Byte conversion demonstration

echo size_format( 99 );            //> 99 B
echo size_format( 9999 );          //> 10 KB
echo size_format( '9999' );        //> 10 KB
echo size_format( 9999, 2 );       //> 9,76 KB
echo size_format( 9999999 );       //> 10 MB
echo size_format( 9999999999 );    //> 9 GB
echo size_format( 9999999999999 ); //> 9 TB
0

#2 Display the size of a file in human-readable format

$file_size = 1229; // filesize in bytes

echo size_format( $file_size, $decimals = 2 ); // 1.20 KB

Changelog

Since 2.3.0 Introduced.
Since 6.0.0 Support for PB, EB, ZB, and YB was added.

size_format() code WP 6.4.3

function size_format( $bytes, $decimals = 0 ) {
	$quant = array(
		/* translators: Unit symbol for yottabyte. */
		_x( 'YB', 'unit symbol' ) => YB_IN_BYTES,
		/* translators: Unit symbol for zettabyte. */
		_x( 'ZB', 'unit symbol' ) => ZB_IN_BYTES,
		/* translators: Unit symbol for exabyte. */
		_x( 'EB', 'unit symbol' ) => EB_IN_BYTES,
		/* translators: Unit symbol for petabyte. */
		_x( 'PB', 'unit symbol' ) => PB_IN_BYTES,
		/* translators: Unit symbol for terabyte. */
		_x( 'TB', 'unit symbol' ) => TB_IN_BYTES,
		/* translators: Unit symbol for gigabyte. */
		_x( 'GB', 'unit symbol' ) => GB_IN_BYTES,
		/* translators: Unit symbol for megabyte. */
		_x( 'MB', 'unit symbol' ) => MB_IN_BYTES,
		/* translators: Unit symbol for kilobyte. */
		_x( 'KB', 'unit symbol' ) => KB_IN_BYTES,
		/* translators: Unit symbol for byte. */
		_x( 'B', 'unit symbol' )  => 1,
	);

	if ( 0 === $bytes ) {
		/* translators: Unit symbol for byte. */
		return number_format_i18n( 0, $decimals ) . ' ' . _x( 'B', 'unit symbol' );
	}

	foreach ( $quant as $unit => $mag ) {
		if ( (float) $bytes >= $mag ) {
			return number_format_i18n( $bytes / $mag, $decimals ) . ' ' . $unit;
		}
	}

	return false;
}