mysql数据库,获取某一个汉字的拼音的首字母。怎么整?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了mysql数据库,获取某一个汉字的拼音的首字母。怎么整?相关的知识,希望对你有一定的参考价值。
网上给出的我都试了。不好用啊。是我的问题还是怎么搞得?
参考技术A 首先建立一个汉字字库,将拼音及首字母存入库中,然后通过创建的检索函数进行快速读取。php获取汉字拼音首字母的方法
现实中我们经常看到这样的说明,排名不分先后,按姓名首字母进行排序。这是中国人大多数使用的排序方法。那么在php程序中该如何操作呢?
下面就分享一下在php程序中获取汉字拼音的首字母的方法,在网上搜到的大多数是有问题的,这个可是经过小编实践应用过的,真的可以使用的哦。
//php获取中文字符拼音首字母
function
getFirstCharter(
$str
){
if
(
empty
(
$str
)){
return
‘‘
;}
$fchar
=ord(
$str
{0});
if
(
$fchar
>=ord(
‘A‘
)&&
$fchar
<=ord(
‘z‘
))
return
strtoupper
(
$str
{0});
$s1
=iconv(
‘UTF-8‘
,
‘gb2312‘
,
$str
);
$s2
=iconv(
‘gb2312‘
,
‘UTF-8‘
,
$s1
);
$s
=
$s2
==
$str
?
$s1
:
$str
;
$asc
=ord(
$s
{0})*256+ord(
$s
{1})-65536;
if
(
$asc
>=-20319&&
$asc
<=-20284)
return
‘A‘
;
if
(
$asc
>=-20283&&
$asc
<=-19776)
return
‘B‘
;
if
(
$asc
>=-19775&&
$asc
<=-19219)
return
‘C‘
;
if
(
$asc
>=-19218&&
$asc
<=-18711)
return
‘D‘
;
if
(
$asc
>=-18710&&
$asc
<=-18527)
return
‘E‘
;
if
(
$asc
>=-18526&&
$asc
<=-18240)
return
‘F‘
;
if
(
$asc
>=-18239&&
$asc
<=-17923)
return
‘G‘
;
if
(
$asc
>=-17922&&
$asc
<=-17418)
return
‘H‘
;
if
(
$asc
>=-17417&&
$asc
<=-16475)
return
‘J‘
;
if
(
$asc
>=-16474&&
$asc
<=-16213)
return
‘K‘
;
if
(
$asc
>=-16212&&
$asc
<=-15641)
return
‘L‘
;
if
(
$asc
>=-15640&&
$asc
<=-15166)
return
‘M‘
;
if
(
$asc
>=-15165&&
$asc
<=-14923)
return
‘N‘
;
if
(
$asc
>=-14922&&
$asc
<=-14915)
return
‘O‘
;
if
(
$asc
>=-14914&&
$asc
<=-14631)
return
‘P‘
;
if
(
$asc
>=-14630&&
$asc
<=-14150)
return
‘Q‘
;
if
(
$asc
>=-14149&&
$asc
<=-14091)
return
‘R‘
;
if
(
$asc
>=-14090&&
$asc
<=-13319)
return
‘S‘
;
if
(
$asc
>=-13318&&
$asc
<=-12839)
return
‘T‘
;
if
(
$asc
>=-12838&&
$asc
<=-12557)
return
‘W‘
;
if
(
$asc
>=-12556&&
$asc
<=-11848)
return
‘X‘
;
if
(
$asc
>=-11847&&
$asc
<=-11056)
return
‘Y‘
;
if
(
$asc
>=-11055&&
$asc
<=-10247)
return
‘Z‘
;
return
null;
}
举例如下:
1
|
echo getFirstCharter( ‘脚本之家www.jb51.net‘ ); //结果将输出:J |
以上是关于mysql数据库,获取某一个汉字的拼音的首字母。怎么整?的主要内容,如果未能解决你的问题,请参考以下文章