php 首字母排序,PHP 取字符串中第一个字的首字母,根据字符串首字母排序方法...

PHP 取字符串中第一个字的首字母,根据字符串首字母排序方法:/**

* 取汉字首字母

* @param string $str 字符串

*/

function getStrOne($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//TRANSLIT//IGNORE',$str);

$s2 = iconv('GB2312','UTF-8//TRANSLIT//IGNORE',$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 '~';

}

使用案例://比如执行数据库查询语句得到数据如下:(SELECT * FROM `article`)

$data = [

['id'=>1,  'name'=>'吧吧吧吧吧吧'],

['id'=>2,  'name'=>'啊啊啊啊啊啊'],

['id'=>3,  'name'=>'怕怕怕怕怕怕'],

['id'=>4,  'name'=>'人人人人人人'],

];

// 根据name的第一个字的首字目来升序排序

$w = [];

foreach ($data as $k =>$v) {

$data[$k]['key'] = getStrOne($v['name']);

$w[$k] = getStrOne($v['name']);

}

array_multisort($w,SORT_STRING,SORT_ASC,$data);

print_r($data);

结果:Array

(

[0] => Array

(

[id] => 2

[name] => 啊啊啊啊啊啊

)

[1] => Array

(

[id] => 1

[name] => 吧吧吧吧吧吧

)

[2] => Array

(

[id] => 4

[name] => 人人人人人人

)

[3] => Array

(

[id] => 3

[name] => 怕怕怕怕怕怕

)

)

浏览器启用弹出窗口过滤功能,将无法跳转到下载页。在浏览器地址栏右边符号提示处点击允许就可以了!

郑重声明:

1、本站源码仅供个人学习研究和交流使用,请于下载后二十四小时内删除

2、本站大多资源来源于互联网、用户分享,仅供学习交流使用,本站不提供任何技术支持

3、本站联系方式Email:admin@youhutong.com ,收到邮件会第一时间处理。

4、如侵犯到任何版权问题,请立即告知本站(立即在线告知),本站将及时删除并致以最深的歉意

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值