PHP将数据按照首字母排序

效果如图:
在这里插入图片描述
在这里插入图片描述
数据库格式:
在这里插入图片描述
思路:数据表这里是根据用户ID来匹配每个用户的好友列表,朋友ID,每个ID后面跟一个‘逗号’(,),可以储存多个好友,
thinkphp取出数据库数据,再把friends字段的值打散成数组,再根据用户ID来检索所需要的数据。

$mqlfind = Db::name('friends_list')->where('userid',$user)->find();

上面是拿出friends这个字段的值,
拿到这个值再进行处理!
下面是对这个值的相关处理操作:
1.首先把这个值打散成数组,然后遍历的时候,给每个 v a l u e 添 加 一 个 ‘ ( k e y ) ‘ c h a r t ’ ‘ , ‘ g e t F i r s t C h a r t ( value添加一个`(key)‘chart’`,`getFirstChart( valuekeychartgetFirstChart(name);,chart的值为根据用户ID检索到的中文姓名( n a m e ‘ ) 匹 配 的 首 字 母 , 并 返 回 首 字 母 ( ‘ g e t F i r s t C h a r t ( name`)匹配的首字母,并返回首字母(` getFirstChart( namegetFirstChart(name);),再根据自己用户数据表的数据添加其它值; 2. $data为数组,遍历第一步生成的数组 a r r D a t a ‘ , ‘ arrData`,` arrDataval等于第一步中生成的[‘chart’ => f r i s t , ′ n a m e ′ = > frist,'name' => frist,name=>name,‘user’ => v a l u e , ′ h e a d i m g ′ = > D b : : n a m e ( ′ u s e r ′ ) − > w h e r e ( ′ u s e r ′ , value,'headimg' => Db::name('user')->where('user', value,headimg=>Db::name(user)>where(user,value)->value(‘headimg’)] , 这里 d a t a [ data[ data[val[‘chart’]][]= v a l ‘ , 就 将 ‘ val`,就将` valval插入键等于$val[‘chart’]`的数组中,这里就已经完成了首字母分类了。

                $array = explode(",",$mqlfind['friends']);
                foreach ($array as $key => $value) {
                    $name = Db::name('user')->where('user',$value)->value('name');
                    $frist = getFirstChart($name);
                    $arrData[$key] = ['chart' =>$frist,'name' =>$name,'user' => $value,'headimg' => Db::name('user')->where('user',$value)->value('headimg')];
                }
                $list=[];
                $data=[];
                //给所有数组进行A-Z分类
                 foreach ($arrData as $K => $val) {
                        if (empty($data[ $val['chart']])) {
                            $data[$val['chart']]=[];
                        }
                        $data[$val['chart']][]=$val;
                 }
                 //按照键名排序
                 ksort($data);
                 return json(ajax($data,10030,'获取成功')); 

这下面一段,是查询我数据表对应用户的资料,可以修改成自己的逻辑。

$arrData[$key] = ['chart' =>$frist,'name' =>$name,'user' => $value,'headimg' => Db::name('user')->where('user',$value)->value('headimg')];

返回首字母

/**
* 返回取汉字的第一个字的首字母
* @param  [type] $str [string]
* @return [type]      [strind]
*/
function getFirstChart($str){
    if( empty($str) ){
        return '';
    }
    $char=ord($str[0]);
    if( $char >= ord('A') && $char <= 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;
}

最后,本人学习才不久,望勿见怪,这里也只是作笔记存放而已。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值