|
1 rok temu | |
---|---|---|
.. | ||
.github | 1 rok temu | |
data | 1 rok temu | |
src | 1 rok temu | |
LICENSE | 1 rok temu | |
README.md | 1 rok temu | |
composer.json | 1 rok temu |
[](https://travis-ci.org/overtrue/pinyin) [](https://packagist.org/packages/overtrue/pinyin) [](https://packagist.org/packages/overtrue/pinyin) [](https://packagist.org/packages/overtrue/pinyin) [](https://packagist.org/packages/overtrue/pinyin) [](https://scrutinizer-ci.com/g/overtrue/pinyin/?branch=master) [](https://scrutinizer-ci.com/g/overtrue/pinyin/?branch=master) [](https://app.fossa.io/projects/git%2Bgithub.com%2Fovertrue%2Fpinyin?ref=badge_shield)
:cn: 基于 CC-CEDICT 词典的中文转拼音工具,更准确的支持多音字的汉字转拼音解决方案。
使用 Composer 安装:
$ composer require "overtrue/pinyin:~4.0"
可选转换方案:
选项 | 描述 |
---|---|
PINYIN_TONE |
UNICODE 式音调:měi hǎo |
PINYIN_ASCII_TONE |
带数字式音调: mei3 hao3 |
PINYIN_NO_TONE |
无音调:mei hao |
PINYIN_KEEP_NUMBER |
保留数字 |
PINYIN_KEEP_ENGLISH |
保留英文 |
PINYIN_KEEP_PUNCTUATION |
保留标点 |
PINYIN_UMLAUT_V |
使用 v 代替 yu , 例如:吕 lyu 将会转为 lv |
use Overtrue\Pinyin\Pinyin;
// 小内存型
$pinyin = new Pinyin(); // 默认
// 内存型
// $pinyin = new Pinyin('\\Overtrue\\Pinyin\\MemoryFileDictLoader');
// I/O型
// $pinyin = new Pinyin('\\Overtrue\\Pinyin\\GeneratorFileDictLoader');
$pinyin->convert('带着希望去旅行,比到达终点更美好');
// ["dai", "zhe", "xi", "wang", "qu", "lyu", "xing", "bi", "dao", "da", "zhong", "dian", "geng", "mei", "hao"]
$pinyin->convert('带着希望去旅行,比到达终点更美好', PINYIN_TONE);
// ["dài","zhe","xī","wàng","qù","lǚ","xíng","bǐ","dào","dá","zhōng","diǎn","gèng","měi","hǎo"]
$pinyin->convert('带着希望去旅行,比到达终点更美好', PINYIN_ASCII_TONE);
//["dai4","zhe","xi1","wang4","qu4","lyu3","xing2","bi3","dao4","da2","zhong1","dian3","geng4","mei3","hao3"]
$pinyin->permalink('带着希望去旅行'); // dai-zhe-xi-wang-qu-lyu-xing
$pinyin->permalink('带着希望去旅行', '.'); // dai.zhe.xi.wang.qu.lyu.xing
$pinyin->abbr('带着希望去旅行'); // dzxwqlx
$pinyin->abbr('带着希望去旅行', '-'); // d-z-x-w-q-l-x
$pinyin->abbr('你好2018!', PINYIN_KEEP_NUMBER); // nh2018
$pinyin->abbr('Happy New Year! 2018!', PINYIN_KEEP_ENGLISH); // HNY2018
将会保留中文字符:,。 ! ? : “ ” ‘ ’
并替换为对应的英文符号。
$pinyin->sentence('带着希望去旅行,比到达终点更美好!');
// dai zhe xi wang qu lyu xing, bi dao da zhong dian geng mei hao!
$pinyin->sentence('带着希望去旅行,比到达终点更美好!', PINYIN_TONE);
// dài zhe xī wàng qù lǚ xíng, bǐ dào dá zhōng diǎn gèng měi hǎo!
姓名的姓的读音有些与普通字不一样,比如 ‘单’ 常见的音为 dan
,而作为姓的时候读 shan
。
$pinyin->name('单某某'); // ['shan', 'mou', 'mou']
$pinyin->name('单某某', PINYIN_TONE); // ["shàn","mǒu","mǒu"]
更多使用请参考 测试用例。
独立的包在这里:overtrue/laravel-pinyin
欢迎提意见及完善补充词库 overtrue/pinyin-dictionary-maker
:kiss:
想知道如何从零开始构建 PHP 扩展包?
请关注我的实战课程,我会在此课程中分享一些扩展开发经验 —— 《PHP 扩展包实战教程 - 从入门到发布》