iOS_字典数组 按key分组和排序
- int main(int argc, const charchar * argv[]) {
- @autoreleasepool {
- // 1.定义一个测试的字典数组
- NSMutableArray *dictArray = @[
- @{
- @"FEnabled" : [NSNumber numberWithInt:1],
- @"FGroupTag" : [NSNumber numberWithInt:0],
- @"FOrder" : [NSNumber numberWithInt:0],
- @"FName" : @"宝玉"
- },
- @{
- @"FEnabled" : [NSNumber numberWithInt:1],
- @"FGroupTag" : [NSNumber numberWithInt:1],
- @"FOrder" : [NSNumber numberWithInt:0],
- @"FName" : @"黛玉"
- },
- @{
- @"FEnabled" : [NSNumber numberWithInt:0],
- @"FGroupTag" : [NSNumber numberWithInt:1],
- @"FOrder" : [NSNumber numberWithInt:1],
- @"FName" : @"宝钗"
- },
- @{
- @"FEnabled" : [NSNumber numberWithInt:1],
- @"FGroupTag" : [NSNumber numberWithInt:1],
- @"FOrder" : [NSNumber numberWithInt:2],
- @"FName" : @"湘云"
- },
- @{
- @"FEnabled" : [NSNumber numberWithInt:1],
- @"FGroupTag" : [NSNumber numberWithInt:2],
- @"FOrder" : [NSNumber numberWithInt:0],
- @"FName" : @"妙玉"
- },
- @{
- @"FEnabled" : [NSNumber numberWithInt:1],
- @"FGroupTag" : [NSNumber numberWithInt:3],
- @"FOrder" : [NSNumber numberWithInt:0],
- @"FName" : @"晴雯"
- },
- @{
- @"FEnabled" : [NSNumber numberWithInt:1],
- @"FGroupTag" : [NSNumber numberWithInt:3],
- @"FOrder" : [NSNumber numberWithInt:1],
- @"FName" : @"袭人"
- }
- ];
- // NSArray 转成 NSMutableArray
- // 0、对于不启用的,即enabled为0的字典模型,删除掉
- NSMutableArray *dictArr = [NSMutableArray array];
- for (int i = 0; i < dictArray.count; i++) {
- NSDictionary *dict = dictArray[i];
- if ([[dict objectForKey:@"FEnabled"]intValue] == 1) {
- [dictArr addObject:dict];
- }
- }
- // NSLog(@"清除未启用的字典后的数组:%@",dictArr);
- // 1、对数组按GroupTag排序
- NSArray *sortDesc = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"FGroupTag" ascending:YES]];
- NSArray *sortedArr = [dictArr sortedArrayUsingDescriptors:sortDesc];
- // NSLog(@"排序后的数组:%@",sortedArr);
- // 2、对数组进行分组,按GroupTag
- // 遍历,创建组数组,组数组中的每一个元素是一个模型数组
- NSMutableArray *_groupArr = [NSMutableArray array];
- NSMutableArray *currentArr = [NSMutableArray array];
- NSLog(@"class--%@",[currentArr class]);
- // 因为肯定有一个字典返回,先添加一个
- [currentArr addObject:sortedArr[0]];
- [_groupArr addObject:currentArr];
- // 如果不止一个,才要动画添加
- if(sortedArr.count > 1){
- for (int i = 1; i < sortedArr.count; i++) {
- // 先取出组数组中 上一个模型数组的第一个字典模型的groupID
- NSMutableArray *preModelArr = [_groupArr objectAtIndex:_groupArr.count-1];
- int preGroupID = [[[preModelArr objectAtIndex:0] objectForKey:@"FGroupTag"] intValue];
- // 取出当前字典,根据groupID比较,如果相同则添加到同一个模型数组;如果不相同,说明不是同一个组的
- NSDictionary *currentDict = sortedArr[i];
- int groupID = [[currentDict objectForKey:@"FGroupTag"] intValue];
- if (groupID == preGroupID) {
- [currentArr addObject:currentDict];
- }else{
- // 如果不相同,说明 有新的一组,那么创建一个模型数组,并添加到组数组_groupArr
- currentArr = [NSMutableArray array];
- [currentArr addObject:currentDict];
- [_groupArr addObject:currentArr];
- }
- }
- }
- // 3、遍历 对每一组 进行排序
- NSMutableArray *tempGroupArr = [NSMutableArray array];
- for (NSMutableArray *arr in _groupArr) {
- NSArray *sortDesc = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"FOrder" ascending:YES]];
- NSMutableArray *tempArr = [arr sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {
- if([[obj1 objectForKey:@"FOrder"]intValue] < [[obj2 objectForKey:@"FOrder"]intValue]){
- return NSOrderedAscending;
- }
- if([[obj1 objectForKey:@"FOrder"]intValue] > [[obj2 objectForKey:@"FOrder"]intValue]){
- return NSOrderedDescending;
- }
- return NSOrderedSame;
- }];
- [tempGroupArr addObject:tempArr];
- }
- _groupArr = tempGroupArr;
- NSLog(@"封装好的group数组:%@",_groupArr);
- }
- return 0;
- }
iOS_字典数组 按key分组和排序的更多相关文章
- iOS_词典阵列 按key分组和排序
// // main.m // SortGroup // // Created by beyond on 14-10-26. // Copyright (c) 2014年 beyond.com All ...
- python 根据字典中的key,value进行排序
#coding=utf-8 import requests,json,collections,base64,datetime def sort(datas): data=json.dumps(data ...
- NodeJS对象数组Array 根据对象object key的值排序sort
有个js对象数组 var ary=[{id:1,name:”b”},{id:2,name:”b”}] 需求是根据name 或者 id的值来排序,这里有个风骚的函数. /** * 对数组中的对象,按对象 ...
- PHP开发小技巧②—实现二维数组根据key进行排序
在PHP中内置了很多对数组进行处理的函数,有很多时候我们直接使用其内置函数就能达到我们的需求,得到我们所想要的结果:但是,有的时候我们却不能通过使用内置函数实现我们的要求,这就需要我们自己去编写算法来 ...
- python 对字典分别按照key值、value值进行排序
1.sorted函数首先介绍sorted函数,sorted(iterable,key,reverse),sorted一共有iterable,key,reverse这三个参数. 其中iterable表示 ...
- Linq入门演练---(1)基本用法-分组,排序,内连接
这一节大家共同学习下LINQ的基本用法,主要包括LINQ的分组,排序,和内外连接. 1.分组 基本语法: group element by key element 表示查询结果返回的元素,key表示 ...
- php对二维数组进行相关操作(排序、转换、去空白等)
php对二维数组进行相关操作(排序.转换.去空白等) 投稿:lijiao 字体:[增加 减小] 类型:转载 时间:2015-11-04 这篇文章主要介绍了php对二维数组进行相关操作,包括php对 ...
- JS中遍历普通数组和字典数组的区别
// 普通数组 var intArray = new Array(); intArray[0] = "第一个"; intArray[1] = "第二个"; fo ...
- PHP根据数组的值分组
PHP根据数组的值分组,php array中没有自带这个函数但是很常用,今天写了出来记录一下. 代码: $_array = array( array(1,11,'2016-05-18') ...
随机推荐
- (原)Unreal渲染模块 管线 - 程序和场景查询
@author: 白袍小道 查看随意,转载随缘 第一部分: 这里主要关心加速算法,和该阶段相关的UE模块的结构和组件的处理. What-HOW-Why-HOW-What(嘿嘿,老规矩) 1.渲 ...
- ThreadLocal 学习
JDK 1.2版本就已经提供了java.lang.ThreadLocal.其为多线程程序的并发问题提供了一种新的思路.使用该工具类可以简洁地编写出优美的多线程程序. 当使用ThreadLocal维护变 ...
- css深入理解relative
第一讲 relative和absolute相煎关系 同源性 .position:relative .position:absolute 限制作用 1.限制left/top/right/bott ...
- 解决IE浏览器中出现“Resource interpreted as Document but transferred with MIME type application/json”问题
在上传图片时,使用ajax提交,返回的数据格式为json.在测试时发现IE浏览器中,上传图片后,没有显示图片,而是弹出一个提示:是否保存UploadImg.json文件:而在其他浏览器中正常. 在Ch ...
- MPLAB® XC C编译器的Workstation License的获取及安装方法
MPLAB®XC C编译器的Workstation License获取及安装方法如下:首先需要购买获得一个XC C编译器的激活码,然后到以下网页(http://www.microchip.com/rl ...
- 洛谷 P3573 [POI2014]RAJ-Rally 解题报告
P3573 [POI2014]RAJ-Rally 题意: 给定一个\(N\)个点\(M\)条边的有向无环图,每条边长度都是\(1\). 请找到一个点,使得删掉这个点后剩余的图中的最长路径最短. 输入输 ...
- jquerydom对象和字符串之间的转换
字符串转jquery对象:var tmp = $('<div>dd</div>').attr('id','bbq'); //用$符包裹起来即可 jquery对象转字符串: tm ...
- 【TEST】NOI-Linux可用 gedit c++精简配置 附Emacs日常配置
这里是backup的测试随笔,用于测试 CSS / Markdown 效果. 同时也是是本菜鸡考场上一般使用的Gedit配置. 只有6行,挺短的.应该算好记吧. 使用之前记得勾选首选项里的外部工具. ...
- 关于each()、find()、filter()遍历节点的操作方法
关于each().find().filter()遍历节点的操作方法 each语法: each(fn) ; 返回值:jQuery fn:代表对于每个匹配元素所要执行的函数 each()方法共有三种形式 ...
- 设置小于12px的字体
.small-font{ font-size:12px; -webkit-transform-origin-x: 0; -webkit-transfo ...