* 在IOS开发过程中,排序是我们经常遇到的问题,那么如何进行排序呢?

* 在英文状态下,系统中有直接可以调用的方法。

   例如:对数组[sss, aaa, bbb, ppp]进行排序,我们可以直接使用系统方法。

 NSMutableArray * array = [[NSMutableArray alloc]initWithObjects:@"sss",@"aaa",@"bbb",@"ppp",nil];
array = (NSMutableArray *)[array sortedArrayUsingSelector:@selector(compare:)];
NSLog(@"%@",array);

上面代码的运行结果为:aaa, bbb, ppp, sss

* 但是如果上面的数组中出现汉语字符,排序就会出现问题,那么在汉语数组中如何进行排序呢?

    在汉字字符串排序,因为编码问题,不能直接对汉字字符串进行直接排序。

    想要对汉字进行排序,我们需要做一下准备。

    1.将汉字转化成相应的拼音。

    2.根据拼音将汉字排序。

一:汉字转化成相应的拼音:(例如:"编码改变世界"要转化成“bianmagaibianshijie”)

将汉语转化成拼音,有很多方法,有第三方库实现,也有系统自带的方法实现。

第三方转化的比较常用的是由George编写的,使用起来比较方便,这个库转化是将汉字转化成汉字的拼音首字母。有兴趣的同学可以自行搜索这个文件。

将汉字转化成拼音,系统为我们提供了这一个方法,使用起来非常的方便,既然系统有这个方法,何必再找第三方库呢?

下面是将汉字转化成拼音的代码:

 NSMutableString *mutableString = [NSMutableString stringWithString:@"编码改变世界"];
CFStringTransform((CFMutableStringRef)mutableString, NULL, kCFStringTransformToLatin, false);
CFStringTransform((CFMutableStringRef)mutableString, NULL, kCFStringTransformStripDiacritics, false);
NSLog(@"%@",mutableString);

上面代码的运行结果为:bian ma gai bian shi jie

可以看出上面的结果中间中间有很多的空格,我们在排序的过程中需要将中间的空格去掉。代码如下:

 mutableString =(NSMutableString *)[mutableString stringByReplacingOccurrencesOfString:@" " withString:@""];

到此为止我们已经将汉字转化成相应的拼音了,但是如何根据拼音将汉字排序呢?

二.根据汉语拼音将数组排序;例如汉字为[“马云”,“诸葛亮”,“王朝阳”],拼音为:[‘mayun’,'zhugeliang','wangzhaoyang']

我们想要得到的顺序应该是[“马云,”“王朝阳”,“诸葛亮”],这样的顺序,现在我们怎样根据拼音将汉字数组排序呢?

说道此处,我们不得不提一个类,它就是NSSortDescroptor,关于这个类的方法理论在此不具体详述,仅用代码演示它的作用。

首先我们先创建一个新的类:people,他有两个属性,一个Chinese,一个pinYin

分别代表汉字,和拼音。

代码如下:(在此假设汉字已经转化成拼音)

 NSMutableArray *array = [[NSMutableArray alloc]init];
NSArray *arrayChinese = [NSArray arrayWithObjects:@"马云",@"诸葛亮",@"王朝阳", nil];
NSArray *arrayPinyin = [NSArray arrayWithObjects:@"mayun",@"zhugeliang",@"wangzhaoyang", nil];
for (int i = ; i < arrayChinese.count; i ++)
{
people *p = [[people alloc]init];
p.chinese = arrayChinese[i];
p.pinyin = arrayPinyin[i];
[array addObject:p];
}
NSArray *sortDescriptors = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"pinyin" ascending:YES]];
[array sortUsingDescriptors:sortDescriptors];
for (int i = ; i < arrayChinese.count; i ++)
{
people *p = array[i];
NSLog(@"----%@",p.chinese);
}

上述代码运行结果为:马云,王朝阳,诸葛亮

iOS-汉字排序的更多相关文章

  1. Java汉字排序(3)按笔划排序

    对于包含汉字的字符串来说,排序的方式主要有两种:一种是拼音,一种是笔画. 本文就讲述如何实现按笔划排序的比较器(Comparator). 作者:Jeff 发表于:2007年12月21日 11:27 最 ...

  2. Java汉字排序(2)按拼音排序

    对于包含汉字的字符串来说,排序的方式主要有两种:一种是拼音,一种是笔画. 本文就讲述如何实现按拼音排序的比较器(Comparator). 作者:Jeff 发表于:2007年12月21日 11:27 最 ...

  3. php 汉字排序

    <?phpheader("content-type:text/html;charset=utf-8");$array=array('重庆市','上海市','安徽省','吉林省 ...

  4. NSArray利用Cocoa框架进行汉字排序

    NSArray利用Cocoa框架进行汉字排序 在NSString有一个函数localizedCompare:,它的功能是通过自身与给定字符串的比較,返回一个本地化的比較结果.也就是说这个函数是支持汉字 ...

  5. ios 汉字字符串数组拼音排序

    ios没有提供简单的汉字拼音排序方法,在网上看到了oc方法,这里写以下对应的swift方法 var stringCompareBlock: (String,String)->Bool = { ( ...

  6. Jtable 表格按多列排序(支持中文汉字排序)

    这两天公司让做一个Jtable表格的排序,首先按A列排序,在A列相等时按B列排序,B列相等时按C列排序,ABC三列可以任意指定,最多分三列,这样的一个需求.由于我是大神,所以必须做了出来.ok,不自恋 ...

  7. MySQL按照汉字的拼音排序,mysql汉字排序

    按照汉字的拼音排序,用的比较多是在人名的排序中,按照姓氏的拼音字母,从A到Z排序: 如果存储姓名的字段采用的是GBK字符集,那就好办了,因为GBK内码编码时本身就采用了拼音排序的方法(常用一级汉字37 ...

  8. Java汉字排序(1)排序前要了解的知识(数组和list的排序接口)

    对于包含汉字的字符串来说,排序的方式主要有两种:一种是拼音,一种是笔画. 本文就讲述如何实现按拼音排序的比较器(Comparator). 作者:Jeff 发表于:2007年12月21日 11:27 最 ...

  9. [转]IOS 中文排序

    转自:http://www.cnblogs.com/syxchina/archive/2012/10/11/2720257.html 1 原因 Ios默认使用utf-8格式编码,所以中文在IOS中默认 ...

  10. NSArray进行汉字排序

    由于NSArray并不直接支持对汉字的排序,这就要通过将汉字转换成拼音完毕按A~Z的排序,这看起来是个头疼的问题.由于牵扯到汉字转为拼音,kmyhy给出一个较易实现的方法,获取汉字的首字的首字母,如将 ...

随机推荐

  1. python基础之基本数据类型

    1.int 整数 2.bool 布尔 3.str 字符串,一般放小量数据 4.list 列表,可以存放大量的数据 5.dict字典,以key:value的形式存储数据 6.set集合(数学) 7.tu ...

  2. Vue 后台管理

    这里是结合vue和element快速成型的一个demo 里面展示了基本的后台管理界面的大体结构和element的基本操作 GitHub的地址:https://github.com/wwwming/ad ...

  3. Diff Two Arrays-freecodecamp算法题目

    Diff Two Arrays(比较两个数组) 1.要求 比较两个数组,然后返回一个新数组 该数组的元素为两个给定数组中所有独有的数组元素.换言之,返回两个数组的差异. 2.思路 定义一个新数组变量, ...

  4. svn提交报错,提示:locked,需要cleanup

    版权声明:本文为博主原创文章,未经博主允许不得转载. 原文地址: https://www.cnblogs.com/poterliu/p/9285137.html 在使用SVN提交代码或更新代码时经常会 ...

  5. 前端之bootstrap

    一.响应式介绍 众所周知,电脑.平板.手机的屏幕是差距很大的,假如在电脑上写好了一个页面,在电脑上看起来不错,但是如果放到手机上的话,那可能就会乱的一塌糊涂,这时候怎么解决呢?以前,可以再专门为手机定 ...

  6. Ubuntu 15 下 Qt 配置mysql链接及基本操作

    序 最近需要在Linux下做一个unix网络编程项目,选择了Ubuntu 最新版本15.04 : 开发环境:Qt 5 数据库: MySQL 安装Qt 和 MySQL 简要介绍一下软件的安装! 安装Qt ...

  7. FIFO buffer 和普通buffer区别

    1.FIFO可以说一块具体的硬件存储设备,也可以说程序在内存中开辟的一段内存区域.而buffer往往就是一段缓冲的数据区域 2.FIFO的数据是先进先出的,而buffer没有这个限制,可以全局访问 3 ...

  8. nrf开发笔记一开发软件

    nrf52810 的开发环境,比较主流的可以使用keil,iar亦可.sdk中,使用的是pca10040e,s112.虽然开发板共用一个型号(pca10040) keil5中,cmsis 需要4.5. ...

  9. CodeForces - 485D Maximum Value (数学)

    题意: n个数,求出这些数中满足 ai >= aj 的 ai % aj 的最大值. 排序去重,然后对于每一个a[i], 如果找到a[i] 的一个倍数 k*a[i] (k > 1)的位置,那 ...

  10. 线段树:CDOJ1592-An easy problem B (线段树的区间合并)

    An easy problem B Time Limit: 2000/1000MS (Java/Others) Memory Limit: 65535/65535KB (Java/Others) Pr ...