PHP中文首字母拼音转换函数

function get_letter($string) {
	$charlist = mb_str_split($string);
	return implode(array_map("getfirstchar", $charlist));
}

 

function getfirstchar($s0) {
	$fchar = ord(substr($s0, 0, 1));
	if (($fchar >= ord("a") and $fchar <= ord("z"))or($fchar >= ord("A") and $fchar <= ord("Z"))) return strtoupper(chr($fchar));
	$s = iconv("UTF-8", "gb2312", $s0);
	$asc = ord($s{0}) * 256 + ord($s{1})-65536;
	if ($asc >= -20319 and $asc <= -20284)return "A";
	if ($asc >= -20283 and $asc <= -19776)return "B";
	if ($asc >= -19775 and $asc <= -19219)return "C";
	if ($asc >= -19218 and $asc <= -18711)return "D";
	if ($asc >= -18710 and $asc <= -18527)return "E";
	if ($asc >= -18526 and $asc <= -18240)return "F";
	if ($asc >= -18239 and $asc <= -17923)return "G";
	if ($asc >= -17922 and $asc <= -17418)return "I";
	if ($asc >= -17417 and $asc <= -16475)return "J";
	if ($asc >= -16474 and $asc <= -16213)return "K";
	if ($asc >= -16212 and $asc <= -15641)return "L";
	if ($asc >= -15640 and $asc <= -15166)return "M";
	if ($asc >= -15165 and $asc <= -14923)return "N";
	if ($asc >= -14922 and $asc <= -14915)return "O";
	if ($asc >= -14914 and $asc <= -14631)return "P";
	if ($asc >= -14630 and $asc <= -14150)return "Q";
	if ($asc >= -14149 and $asc <= -14091)return "R";
	if ($asc >= -14090 and $asc <= -13319)return "S";
	if ($asc >= -13318 and $asc <= -12839)return "T";
	if ($asc >= -12838 and $asc <= -12557)return "W";
	if ($asc >= -12556 and $asc <= -11848)return "X";
	if ($asc >= -11847 and $asc <= -11056)return "Y";
	if ($asc >= -11055 and $asc <= -10247)return "Z";
	return null;
}

 

转载于:https://my.oschina.net/oaoa/blog/127236

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在 Excel 中将中文转换拼音首字母,需要用到 Excel 中的 CONCATENATE 函数和 VBA 中的函数。具体步骤如下: 1. 打开 Excel 文档,选中需要转换中文文字所在的单元格。 2. 在单元格中输入以下公式: =CONCATENATE(IF(ISERROR(FIND(LEFT(B1,1), "ABCDEFGHIJKLMNOPQRSTUVWXYZ")), LEFT(B1,1), ""), IF(ISERROR(FIND(MID(B1,2,1), "ABCDEFGHIJKLMNOPQRSTUVWXYZ")), MID(B1,2,1), ""), IF(ISERROR(FIND(MID(B1,3,1), "ABCDEFGHIJKLMNOPQRSTUVWXYZ")), MID(B1,3,1), ""), IF(ISERROR(FIND(MID(B1,4,1), "ABCDEFGHIJKLMNOPQRSTUVWXYZ")), MID(B1,4,1), "")) 其中,B1 表示需要转换中文文字所在的单元格。 3. 按下 Enter 键,完成公式输入。此时,该单元格中的中文文字已经转换成了拼音首字母。 4. 如果需要批量转换多个中文文字,可以将公式拖动到需要转换的单元格范围内,再按下 Ctrl+Enter 键,即可完成批量转换。 5. 如果需要将上述公式导入到 VBA 中,可以使用以下 VBA 函数: Function ChineseToPinyin(ByVal str As String) As String Dim i As Integer For i = 1 To Len(str) If AscW(Mid(str, i, 1)) < 19968 Or AscW(Mid(str, i, 1)) > 40869 Then ChineseToPinyin = ChineseToPinyin & Mid(str, i, 1) Else ChineseToPinyin = ChineseToPinyin & Left(Application.WorksheetFunction.VLookup(Mid(str, i, 1), Range("A1:B405"), 2, False), 1) End If Next i End Function 其中,Range("A1:B405") 是一个包含中文字符和对应拼音首字母的数据表格。在使用该函数时,需要将该数据表格插入到 Excel 中,并修改代码中的数据表格范围和单元格引用。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值