转自:http://www.cnblogs.com/syxchina/archive/2012/10/11/2720257.html

1 原因

Ios默认使用utf-8格式编码,所以中文在IOS中默认排序是不可以用的,但IOS也支持使用笔画排序的(采用NSString的localizedCompare,可按笔划排序),但我们希望根据拼音排序,并且如果相同可以往后继续比较。详见:

http://space.itpub.net/29867/viewspace-688829

http://www.cnblogs.com/kuku/archive/2012/08/19/2646063.html

2 使用拼音对数组中的中文字符排序

参考:http://www.cocoachina.com/bbs/read.php?tid-111709.html

使用效果:

使用代码:

 1 #import <Foundation/Foundation.h>
2 #import "ChineseString.h"
3 #import "pinyin.h"
4
5 int main(int argc, const char * argv[])
6 {
7 @autoreleasepool{
8
9 //结果请看输出
10
11 //Step1:初始化
12 NSMutableArray *stringsToSort=[NSArray arrayWithObjects:
13 @"电脑",
14 @"显示器",
15 @"你好",
16 @"推特",
17 @"乔布斯",
18 @"再见",
19 @"暑假作业",
20 @"键盘",
21 @"鼠标",
22 @"谷歌",
23 @"苹果",
24 nil];
25
26 //Step1输出
27 NSLog(@"尚未排序的NSString数组:");
28 for(int i=0;i<[stringsToSort count];i++){
29 NSLog(@"%@",[stringsToSort objectAtIndex:i]);
30 }
31
32
33
34 //Step2:获取字符串中文字的拼音首字母并与字符串共同存放
35 NSMutableArray *chineseStringsArray=[NSMutableArray array];
36 for(int i=0;i<[stringsToSort count];i++){
37 ChineseString *chineseString=[[ChineseString alloc]init];
38
39 chineseString.string=[NSString stringWithString:[stringsToSort objectAtIndex:i]];
40
41 if(chineseString.string==nil){
42 chineseString.string=@"";
43 }
44
45 if(![chineseString.string isEqualToString:@""]){
46 NSString *pinYinResult=[NSString string];
47 for(int j=0;j<chineseString.string.length;j++){
48 NSString *singlePinyinLetter=[[NSString stringWithFormat:@"%c",pinyinFirstLetter([chineseString.string characterAtIndex:j])]uppercaseString];
49
50 pinYinResult=[pinYinResult stringByAppendingString:singlePinyinLetter];
51 }
52 chineseString.pinYin=pinYinResult;
53 }else{
54 chineseString.pinYin=@"";
55 }
56 [chineseStringsArray addObject:chineseString];
57 }
58
59 //Step2输出
60 NSLog(@"\n\n\n转换为拼音首字母后的NSString数组");
61 for(int i=0;i<[chineseStringsArray count];i++){
62 ChineseString *chineseString=[chineseStringsArray objectAtIndex:i];
63 NSLog(@"原String:%@----拼音首字母String:%@",chineseString.string,chineseString.pinYin);
64 }
65
66
67
68 //Step3:按照拼音首字母对这些Strings进行排序
69 NSArray *sortDescriptors = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"pinYin" ascending:YES]];
70 [chineseStringsArray sortUsingDescriptors:sortDescriptors];
71
72 //Step3输出
73 NSLog(@"\n\n\n按照拼音首字母后的NSString数组");
74 for(int i=0;i<[chineseStringsArray count];i++){
75 ChineseString *chineseString=[chineseStringsArray objectAtIndex:i];
76 NSLog(@"原String:%@----拼音首字母String:%@",chineseString.string,chineseString.pinYin);
77 }
78
79 // Step4:如果有需要,再把排序好的内容从ChineseString类中提取出来
80 NSMutableArray *result=[NSMutableArray array];
81 for(int i=0;i<[chineseStringsArray count];i++){
82 [result addObject:((ChineseString*)[chineseStringsArray objectAtIndex:i]).string];
83 }
84
85 //Step4输出
86 NSLog(@"\n\n\n最终结果:");
87 for(int i=0;i<[result count];i++){
88 NSLog(@"%@",[result objectAtIndex:i]);
89 }
90
91 //程序结束
92
93 NSLog(@"\n\n\nDemo By Hxy060799");
94 }
95 return 0;
96 }

[转]IOS 中文排序的更多相关文章

  1. SQLite中文排序

    定义一个类: using System.Data.SQLite; namespace DAL { /// <summary> /// SQLite中文排序 /// </summary ...

  2. 转!!mysql order by 中文排序

    1. 在MySQL中,我们经常会对一个字段进行排序查询,但进行中文排序和查找的时候,对汉字的排序和查找结果往往都是错误的. 这种情况在MySQL的很多版本中都存在. 如果这个问题不解决,那么MySQL ...

  3. PHP/MYSQL UTF8 中文排序

    1. 需要在php数组中用中文排序,但是一般使用utf8格式的文件,直接用asort排序不行.用gbk和gb2312可以.这跟几种格式的编码有关系.gbk和gb2312本身的编码就是用拼音排序的. f ...

  4. ORACLE的order by中文排序

    在使用order by排序的时候,出现如下情况:   印象中中文排序应该默认是按照拼音排序的,为何"鑫"会排在"中"的后面呢?猜想order by是不是根据对应 ...

  5. hibernate 用hql做中文排序

    用Hibernate+MySQL的童鞋是不是非常苦恼为什么MySQL不支持中文排序呢?没办法.仅仅有等utf8_unicode_cn 出来了.假设用hibernate即想实现跨库,又想不改代码怎样实现 ...

  6. jQuery的dataTables插件实现中文排序

    最近在写Java web. 写JSP的时候发现一个很好玩的插件dataTables.分页.过滤.排序等等手到擒来. 哎哎哎,有点点可惜的是排序这个功能不支持中文.于是网上查查找找,现在把方法整理一下, ...

  7. TreeMap中文排序,TreeMap倒序输出排列

    1.TreeMap集合倒序排列 import java.util.Comparator; /** * 比较算法的类,比较器 * @author Administrator * */ public cl ...

  8. mysql order by 中文 排序

    mysql order by 中文 排序 1. 在MySQL中,我们经常会对一个字段进行排序查询,但进行中文排序和查找的时候,对汉字的排序和查找结果往往都是错误的. 这种情况在MySQL的很多版本中都 ...

  9. PHP与MYSQL中UTF8 中文排序例子

    1. 需要在php数组中用中文排序,但是一般使用utf8格式的文件,直接用asort排序不行.用gbk和gb2312可以.这跟几种格式的编码有关系.gbk和gb2312本身的编码就是用拼音排序的. 代 ...

随机推荐

  1. golang 并发之协程及通道

    一.概述 在golang中,每个并发执行单元称为goroutine,当程序启动时,main函数在一个单独的goroutine中运行,(main goroutine).新的goroutine会用go语句 ...

  2. 如何实现调用console.log(‘good’.repeat(3))时输出goodgoodgood?

    String.prototype.repeat=function(num){ return (new Array(num+1)).join(this) } console.log('good'.rep ...

  3. Html页面加回滚

    <div class="top-box"> <img src=" class="youlink-img" /><br / ...

  4. SQLite 字符串连接

    对Mysql可以使用CONCAT进行字符串连接, 但使用sqlite时,没有找到相应的方法,后在网上查找后,可以使用||来连接字符串 例: select 'a'||'b'

  5. JQuery的Select操作集合

    jQuery获取Select选择的Text和Value:   语法解释: $("#select_id").change(function(){//code...}); //为Sel ...

  6. Intellij idea workflow 工作流插件安装

    idea提供支持的工作插件名字叫actiBPM,可以在idea中在线安装,但往往会连接不成功安装失败,所以这里提供了硬盘安装的方式: 首先是要去官网下载actiBPM插件,下载地址: http://p ...

  7. 在Linux下使用iconv转换字符串编码

    在Linux下写C程序,尤其是网络通信程序时经常遇到编码转换的问题,这里要用到iconv函数库. iconv函数库有以下三个函数 123456 #include <iconv.h>icon ...

  8. MyBatis good

    命名解析:为了减少输入量,MyBatis 对所有的命名配置元素(包括语句,结果映射,缓存等)使用了如下的命名解析规则. 完全限定名(比如“com.mypackage.MyMapper.selectAl ...

  9. listview 的onitemlongclick阿和onitemclick冲突,item中还有button的点击事件

    listview里面item有button的,button要设置 android:focusable="false"  ,listview里面如果设置了 onitemlongcli ...

  10. was配置oracle RAC集群的数据源

    在WebSphere中配置配置Oracle RAC集群的数据源,假设Oracle RAC双击分别为 HOST1 与 HOST2 , 端口为1521 ,服务名为 orcldbservice,则配置的UR ...