首页 > 编程知识 正文

根据首字母排序,php排序函数

时间:2023-05-05 22:46:42 阅读:225052 作者:2724

效果如图:


数据库格式:

思路:数据表这里是根据用户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( value添加一个‘(key)‘chart’‘,‘getFirstChart(name);,chart的值为根据用户ID检索到的中文姓名( n a m e ‘ ) 匹 配 的 首 字 母 , 并 返 回 首 字 母 ( ‘ g e t F i r s t C h a r t ( name`)匹配的首字母,并返回首字母(` getFirstChart( name‘)匹配的首字母,并返回首字母(‘getFirstChart(name);),再根据自己用户数据表的数据添加其它值; 2. $data为数组,遍历第一步生成的数组 a r r D a t a ‘ , ‘ arrData`,` arrData‘,‘val等于第一步中生成的[‘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`,就将` val‘,就将‘val插入键等于$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;}

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

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。