phpviet / yii-number-to-words
Yii number to words hổ trợ chuyển đổi số sang chữ số Tiếng Việt
Installs: 37
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 2
Forks: 0
Open Issues: 0
Type:yii2-extension
Requires
- php: ^7.1
- phpviet/number-to-words: ^1.0
- yiisoft/yii2: ~2.0.13
Requires (Dev)
- phpunit/phpunit: ~7.5
- scrutinizer/ocular: ^1.5
This package is auto-updated.
Last update: 2024-11-15 18:17:20 UTC
README
Yii Number To Words
Thông tin
Yii number to words hổ trợ chuyển đổi số sang chữ số Tiếng Việt.
Cài đặt
Cài đặt Yii Number To Words thông qua Composer:
composer require phpviet/yii-number-to-words
Cách sử dụng
Các tính năng của extension:
Chuyển đổi số sang chữ số
- Sử dụng thông qua helper
phpviet\yii\numberToWords\N2WHelper
:
use phpviet\yii\numberToWords\N2WHelper; // âm năm N2WHelper::toWords(-5); // năm N2WHelper::toWords(5); // năm phẩy năm N2WHelper::toWords(5.5);
- Sử dụng thông qua
n2w
component:
// mười lăm Yii::$app->n2w->toWords(15); // một trăm linh năm Yii::$app->n2w->toWords(105); // hai mươi tư Yii::$app->n2w->toWords(24);
Chuyển đổi số sang tiền tệ
- Sử dụng thông qua helper
phpviet\yii\numberToWords\N2WHelper
:
use phpviet\yii\numberToWords\N2WHelper; // năm triệu sáu trăm chín mươi nghìn bảy trăm đồng N2WHelper::toCurrency(5690700);
- Sử dụng thông qua
n2w
component:
// chín mươi lăm triệu năm trăm nghìn hai trăm đồng Yii::$app->n2w->toCurrency(95500200);
Ngoài ra ta còn có thể sử dụng đơn vị tiền tệ khác thông qua tham trị thứ 2 của phương thức
toCurrency
tại helper và component, với mảng phần từ đầu tiên là đơn vị cho số nguyên và kế tiếp là đơn vị của phân số:
use phpviet\yii\numberToWords\N2WHelper; // sáu nghìn bảy trăm bốn mươi hai đô bảy xen N2WHelper::toCurrency(6742.7, ['đô', 'xen']); // chín nghìn bốn trăm chín mươi hai đô mười lăm xen Yii::$app->n2w->toCurrency(9492.15, ['đô', 'xen']);
Thay cách đọc số
Nếu như bạn cảm thấy cách đọc ở trên ổn rồi thì hãy bỏ qua bước này.
Đầu tiên để thay đổi cách đọc số bạn hãy cấu hình n2w
component trong app config file:
'components' => [ 'n2w' => [ 'class' => 'phpviet\yii\numberToWords\N2W', 'dictionary' => 'standard', 'dictionaries' => [ 'standard' => PHPViet\NumberToWords\Dictionary::class, 'south' => PHPViet\NumberToWords\SouthDictionary::class ] ] ];
Ngay bây giờ bạn hãy thử đổi dictionary
từ standard
sang south
, toàn bộ phương thức chuyển
đổi số sang chữ số và tiền tệ sẽ đọc theo phong cách trong Nam:
use phpviet\yii\numberToWords\N2WHelper; // một trăm linh một => một trăm lẻ một N2WHelper::toWords(101); // một nghìn => một ngàn N2WHelper::toWords(1000); // hai mươi tư => hai mươi bốn N2WHelper::toWords(24); // một trăm hai mươi tư nghìn không trăm linh một đồng => một trăm hai mươi bốn ngàn không trăm lẻ một đồng N2WHelper::toCurrency(124001);
hoặc bạn muốn sử dụng linh động hơn thì hãy chỉ định từ điển:
use phpviet\yii\numberToWords\N2WHelper; // một trăm hai mươi tư nghìn không trăm linh một N2WHelper::toWords(124001); // một trăm hai mươi bốn ngàn không trăm lẻ một N2WHelper::toWords(124001, 'south');
Nếu như bạn muốn thay đổi cách đọc theo ý bạn thì hãy tạo một lớp Dictionary
kế thừa
PHPViet\NumberToWords\Dictionary
hoặc thực thi mẫu trừu tượng PHPViet\NumberToWords\DictionaryInterface
:
use PHPViet\NumberToWords\Dictionary; use PHPViet\NumberToWords\Transformer; class MyDictionary extends Dictionary { /** * @inheritDoc */ public function specialTripletUnitFive(): string { return 'nhăm'; } }
Sau đó khai báo vào config:
'components' => [ 'n2w' => [ 'class' => 'phpviet\yii\numberToWords\N2W', 'dictionary' => 'my', 'dictionaries' => [ 'standard' => PHPViet\NumberToWords\Dictionary::class, 'south' => PHPViet\NumberToWords\SouthDictionary::class, 'my' => MyDictionary::class ] ] ];
Và hãy thử ngay:
use phpviet\yii\numberToWords\N2WHelper; // mười nhăm N2WHelper::toWords(15);
Dành cho nhà phát triển
Nếu như bạn cảm thấy extension còn thiếu sót hoặc sai sót và bạn muốn đóng góp để phát triển chung,
chúng tôi rất hoan nghênh! Hãy tạo các issue
để đóng góp ý tưởng cho phiên bản kế tiếp
hoặc tạo PR
để đóng góp. Cảm ơn!