php-collective/decimal-object 问题修复 & 功能扩展

解决BUG、新增功能、兼容多环境部署,快速响应你的开发需求

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

php-collective/decimal-object

最新稳定版本:1.3.1

Composer 安装命令:

composer require php-collective/decimal-object

包简介

PHP decimal handling as value object

README 文档

README

CI codecov Latest Stable Version Minimum PHP Version PHPStan License

Decimal value object for PHP.

Background

When working with decimal (e.g. monetary) values, normal data types like int or float are not suitable for exact arithmetic. Try out the following in PHP:

var_dump(0.1 + 0.2);        // float(0.3)
var_dump(0.1 + 0.2 - 0.3);  // float(5.5511151231258E-17)

Handling them as strings is a workaround, but as value object you can more easily encapsulate some of the logic.

Alternatives

Solutions like php-decimal require a custom PHP extension (would make it faster, but also more difficult for some servers to be available). Monetary values themselves could be handled also with brick/money or moneyphp/money.

For details see the wiki.

Note: If you are looking for pre PHP 8.1 versions, check out the legacy library.

Features

  • Super strict on precision/scale. Does not lose significant digits on its own. You need to trim() for this manually.
  • Speaking API (no le, gt methods).
  • Basic math operations and checks supported.
  • Immutability.
  • Handle very large and very small numbers.

Installation

Requirements

  • bcmath PHP extension enabled

Composer (preferred)

composer require php-collective/decimal-object

Usage

See Documentation for more details.

Implementations

The following libraries are using the Decimal value object:

The original library here was written 2019 for Spryker ecommerce framework and since then battle-tested through millions of customers and orders as well as other complex calculations under the hood. This here is the freshly upgraded and independently maintained version for the PHP ecosystem as a whole.

Enjoy!

统计信息

  • 总下载量: 49.71k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 24
  • 点击次数: 3
  • 依赖项目数: 2
  • 推荐数: 0

GitHub 信息

  • Stars: 24
  • Watchers: 1
  • Forks: 4
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2023-10-05