欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  php教程

最全的PHP汉字转拼音函数(共25961字,包含20902个基本汉字+5059

程序员文章站 2022-04-24 17:03:59
...

感谢南湖船老大和mark35,已经更新和修正。 此函数非常简单,没有使用正则表达式和转码函数,只使用了简单的数组遍历,在兼容性和性能方面都比较好吧。 pinyin.php共25961字,包括20902个基本汉字(Unicode码0x4e00-0x9fa5)和6582个汉字(Unicode码0x3400-0x

感谢 南湖船老大 和 mark35,已经更新和修正。

此函数非常简单,没有使用正则表达式和转码函数,只使用了简单的数组遍历,在兼容性和性能方面都比较好吧。

pinyin.php 共25961字,包括 20902个基本汉字(Unicode码0x4e00-0x9fa5)和 6582个汉字(Unicode码0x3400-0x4db5,只收集到其中5059生僻字的拼音,微软全拼码表中不包含这5059个生僻字。相比我之前发的 PHP汉字转拼音类(http://www.oschina.net/code/snippet_862384_25392) 全太多,这个类只支持3755字。)

pinyin_gbk.php 共20902字,不过好像有100多字在GBK下不支持。

pinyin_ms.php 共27900字(重复6998个多音字,实际字数20902个),拼音库来源于windosw系统自带全拼码表(虽然还可以收集一下其他拼音输入法码表,可能更多字数,但我觉得微软的字库比较权威,同时20902个汉字已经能满足常用汉字的所有需求了,字库越大程序性能越低。)

pinyin_mini.php 只支持3755字,如果是UTF-8,需要使用 iconv 转码,优点文件小,速度快。

性能测试如下:
pinyin.php 这函数我本机测试执行时间在0.04左右,如果把汉字转拼音库直接改成数组,可以提高0.03秒,不过文件要大一半,在意执行时间,不在意文件大小的,可以自己改一下。
pinyin_mini.php 执行时间比较快,大概在0.004秒左右,比这个大库快10倍。在意性能,对拼音库要求不高的朋友可以使用这个类。

为考虑程序性能,没有考虑支持多音字,我个人觉得也没有必要牺牲更多性能去支持多音字。如果喜欢折腾这个问题的朋友,可以下载uniku.zip、TableTextServiceSimplifiedQuanPin.zip,里面有我收集的一些词库,对解决多音字问题应该有帮助。

源码与演示:源码出处

 0x80) {
				$ascii2 = ord($s[++$i]);
				$ascii = $ascii * 256 + $ascii2 - 65536;
			}

			if($ascii  0) {
				if(($ascii >= 48 && $ascii = 97 && $ascii = 65 && $ascii  -10247) {
				$res .= '_';
			}else{
				foreach($pinyin_arr as $py=>$asc) {
					if($asc  0xE0) {
			$s = self::utf8_to_gb2312($s[0].$s[1].$s[2]);
		}elseif($ascii = 65 && $ascii = 97 && $ascii =-20319 && $asc=-20283 && $asc=-19775 && $asc=-19218 && $asc=-18710 && $asc=-18526 && $asc=-18239 && $asc=-17922 && $asc=-17417 && $asc=-16474 && $asc=-16212 && $asc=-15640 && $asc=-15165 && $asc=-14922 && $asc=-14914 && $asc=-14630 && $asc=-14149 && $asc=-14090 && $asc=-13318 && $asc=-12838 && $asc=-12556 && $asc=-11847 && $asc=-11055 && $asc