php实现姓名按首字母排序的类与方法
php将名字按首字母进行排序
<?php
public function getFirstChar($s){$s0 = mb_substr($s,0,3); //获取名字的姓$s = iconv('UTF-8','gb2312', $s0); //将UTF-8转换成GB2312编码//dump($s0);if (ord($s0)>128) { //汉字开头,汉字没有以U、V开头的$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<=-17760)return "G";if($asc>=-17759 and $asc<=-17248)return "H";if($asc>=-17247 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";}else if(ord($s)>=48 and ord($s)<=57){ //数字开头switch(iconv_substr($s,0,1,'utf-8')){case 1:return "Y";case 2:return "E";case 3:return "S";case 4:return "S";case 5:return "W";case 6:return "L";case 7:return "Q";case 8:return "B";case 9:return "J";case 0:return "L";}}else if(ord($s)>=65 and ord($s)<=90){ //大写英文开头return substr($s,0,1);}else if(ord($s)>=97 and ord($s)<=122){ //小写英文开头return strtoupper(substr($s,0,1));}else{return iconv_substr($s0,0,1,'utf-8');//中英混合的词语,不适合上面的各种情况,因此直接提取首个字符即可}}public function addPeople(){$userName = array('张三','马大帅','李四','王五','小二','猫蛋','狗蛋','王花','三毛','小明','李刚','张飞');sort($userName);foreach($userName as $name){$char = $this->getFirstChar($name);$nameArray = array();if(count($charArray[$char])!=0){$nameArray = $charArray[$char];}array_push($nameArray,$name);$charArray[$char] = $nameArray;}ksort($charArray);$this->assign('_list',$charArray);}<foreach name="_list" item="vo" key="k">
<p>{$k}</p><foreach name="vo" item="l"><span class="name">{$l}</span></foreach></foreach>php实现姓名按首字母排序的类与方法的更多相关文章
- 联系人的侧边字母索引ListView   将手机通讯录姓名通过首字母排序。
		package com.lixu.letterlistview; import java.util.ArrayList; import java.util.List; import org.apa ... 
- Oracle 10g如何对用户姓名,按首字母排序、查询
		首先介绍Oracle 9i新增加的一个系统自带的排序函数 1.按首字母排序 在oracle9i中新增了按照拼音.部首.笔画排序功能.设置NLS_SORT值 SCHINESE_RADICA ... 
- [转]Oracle 10g如何对用户姓名,按首字母排序、查询
		首先介绍Oracle 9i新增加的一个系统自带的排序函数 1.按首字母排序 在oracle9i中新增了按照拼音.部首.笔画排序功能.设置NLS_SORT值 SCHINESE_RADICA ... 
- 获取手机通讯录放入PinnedSectionListView中,按名字首字母排序,并且实现拨打电话功能。
		package com.lixu.tongxunlu; import java.util.ArrayList; import com.lixu.tongxunlu.PinnedSectionListV ... 
- php按照中文首字母排序
		1> 网络上很多php的工具类可以将汉字转为拼音: 2> 将拼音进行排序即可 另一种则是类似mysql转码方式: 1 foreach ($array as $key=>$value) ... 
- HashMap加入数据后,会自动根据首字母排序
		1.Map<String, ArrayList<XX>> entityHashMap = new HashMap<>(); 然后增加一些数据,会发现根据String ... 
- mysql中文名字按首字母排序
		在mysql数据库中可以使用GBK编码对中文进行排序,如名字按首字母排序 order by convert(substr(tu.username,1,1) using 'GBK') 其中substr方 ... 
- mysql排序的中文首字母排序和自定义排序
		select * FROM organ_new where city_code = 'SZ0755' and organ_type = 'H' and state = '1' ORDER BY FIE ... 
- mysql、oracle 中按照拼音首字母排序
		mysql中按照拼音首字母排序 convert(name using gbk) ASC 注:name 为字段名称 oracle中按照拼音首字母排序 nlssort(enterprise_name,'N ... 
随机推荐
- 为什么懂云的IT高手能过得比你好
			盼望着,盼望着,一年一度的国庆7天长假还有不到24小时就到来了.各个部门的同事都已准备好满世界旅行去了. IT 部门各位同事的心还是悬着,信息系统还要持续的运转,对外的网站不能停,假期的线上促销也不能 ... 
- CAGradientLayer实现图片渐变透明效果
			CAGradientLayer实现图片渐变透明效果 要实现的效果如下: 源码: // // RootViewController.m // CAGradientLayer // // Copyrigh ... 
- Docker简介与搭建
			Docker定义 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制,相 ... 
- iStat Menus 的激活密
			Email: @qq.com SN: GAWAE-FCWQ3-P8NYB-C7GF7-NEDRT-Q5DTB-MFZG6-6NEQC-CRMUD-8MZ2K-66SRB-SU8EW-EDLZ9-TGH ... 
- host 'xx' is not allowed to connect to this MySql server
			update mysql.user set host = '%' where user = 'root'; FLUSH PRIVILEGES; select * from mysql.user; 
- C对64位整数类型的支持
			在使用C语言过程中可能需要接触长整数类型,其中包括固定长度数据类型的声明.输入输出函数的标志符等细节,在此记录. int64_t 与 uint64_t C的标准只规定特定数据类型需要实现的最小长度,特 ... 
- Redis命令、数据结构场景、配置文件总结
			本文大纲 一.常用数据类型简介二.redis操作命令三.redis配置文件详解四.redis数据类型使用场景 一.常用数据类型简介 redis常用五种数据类型:string,hash,list,set ... 
- Django的视图流式响应机制
			Django的视图流式响应机制 Django的响应类型:一次性响应和流式响应. 一次性响应,顾名思义,将响应内容一次性反馈给用户.HttpResponse类及子类和JsonResponse类属于一次性 ... 
- 【JavaScript】explode动画
			这是一个js实现的粒子聚合文字或图片的动画特效 部分程序如下 n.container = n.container[0] || n.container; /*有且仅有一个container*/ var ... 
- keras写模型时遇到的典型问题,也是最基础的类与对象问题
			自己定义了一个卷积类,现在需要把卷积加入model中,我的操作是这样的: model.add(Convolution1dLayer) 这样就会报错: 正确的写法是: model.add(Convolu ... 
