zenstruck / bytes
解析、操作、人性化并格式化字节。
v1.0.0
2023-07-26 15:23 UTC
Requires
- php: >=8.0
Requires (Dev)
- phpstan/phpstan: ^1.4
- phpunit/phpunit: ^9.5.0
- symfony/phpunit-bridge: ^6.3
- symfony/var-dumper: ^5.4|^6.0
README
一个用于解析、操作、人性化和格式化字节的值对象。
安装
composer require zenstruck/bytes
用法
创建一个 Zenstruck\Bytes
对象并访问其值
use Zenstruck\Bytes; $bytes = Bytes::parse(1024); // create from number of bytes as integer $bytes->value(); // (int) 1024 $bytes = Bytes::parse('1.54kb'); // create from a quantity suffixed by a valid informational unit $bytes->value(); // (int) 1540 $bytes = Bytes::parse('1.54 KiB'); // can use binary informational units $bytes->value(); // (int) 1577
格式化
默认情况下,当将 Zenstruck\Bytes
对象转换为字符串时,它会自动进行 人性化 以便更容易阅读。
use Zenstruck\Bytes; (string) Bytes::parse(389789364783); // "389.79 GB"
您可以自定义格式化方式
use Zenstruck\Bytes; Bytes::parse(389789364783)->format('%.4f%s'); // "389.7894GB"
单位转换
如果您希望在格式化时使用一致的单位,请使用带有有效信息单位的 to()
方法
use Zenstruck\Bytes; (string) Bytes::parse(389789364783)->to('mib'); // "371732.11 MiB"
算术运算
执行 加 和 减 操作
use Zenstruck\Bytes; /** @var Bytes $first */ /** @var Bytes $second */ /** @var Bytes $third */ $result = $first // $result instanceof Bytes ->add($second) // add another Bytes object ->add(500) // add specific amount of bytes ->add('2.1 MB') // parse and add ->subtract($third) // subtract another Bytes object ->subtract(100) // subtract specific amount of bytes ->subtract('100 kib') // parse and subtract ;
注意:这些操作是不可变的。
比较
您可以比较 Zenstruck\Byte
对象
use Zenstruck\Bytes; /** @var Bytes $bytes */ /** @var Bytes $another */ $bytes->isEqualTo(100); // bool $bytes->isEqualTo('1.1kb'); // bool $bytes->isEqualTo($another); // bool $bytes->isGreaterThan(100); // bool $bytes->isGreaterThan('1.1kb'); // bool $bytes->isGreaterThan($another); // bool $bytes->isLessThan(100); // bool $bytes->isLessThan('1.1kb'); // bool $bytes->isLessThan($another); // bool $bytes->isGreaterThanOrEqualTo(100); // bool $bytes->isGreaterThanOrEqualTo('1.1kb'); // bool $bytes->isGreaterThanOrEqualTo($another); // bool $bytes->isLessThanOrEqualTo(100); // bool $bytes->isLessThanOrEqualTo('1.1kb'); // bool $bytes->isLessThanOrEqualTo($another); // bool