像通讯录一样的排序法

博客主要介绍了信息技术领域中封装方法和调用方法的相关内容,涵盖了这两个关键操作,为相关技术学习提供基础信息。

1,封装方法

/**
	 * [zhcnToPinyin 转换方法]
	 * @param  [type] $str [字符串]
	 * @return [type]      [description]
	 */
	function zhcnToPinyin($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',$str);
		$s2=iconv('gb2312','UTF-8',$s1);
		$s=$s2==$str?$s1:$str;
		if (!isset($s{1})) return $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;
	}
	
	

2,调用方法

/**
	 * [call 调用方法]
	 * @param  [type] $data [传进来的数组]
	 * @param  [type] $key  [要转换的名称]
	 * @return [type]       [扔出去数组]
	 */
	public function call($data,$key){

		foreach($data as $key => $item) {
		  $py = $this->zhcnToPinyin($item[$key]);
		  if (isset($newArr[$py])) {
		  	$newArr[$py]['pinyin'] = $py;
		  	$newArr[$py][] = $item;
		  } else {
		  	$newArr[$py]['pinyin'] = $py;
		  	$newArr[$py][] = $item;
		  }
		}
		ksort($newArr);
		$list=[];
		foreach($newArr as $k=>$vv){
			if (preg_match ("/^[a-z]/i", $k)) {
				$list['a'][$k] = $vv;
			}else{
				$list['t'][$k] = $vv;
			}
			
		}
		return $list;
	}

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值