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') ...
随机推荐
- sources-t.list
deb http://debian.ustc.edu.cn/ubuntu/ trusty main multiverse restricted universe deb http://debian.u ...
- C++ 11 智能指针 lamda 以及一个 围棋程序
lamda表达式使用 char* p = "Hello world"; ,nl = ; for_each(p,p+, [&](char i){ if(i=='e') ne+ ...
- 九宫重排_康拓展开_bfs
历届试题 九宫重排 时间限制:1.0s 内存限制:256.0MB 问题描述 如下面第一个图的九宫格中,放着 1~8 的数字卡片,还有一个格子空着.与空格子相邻的格子中的卡片可 ...
- LeetCode -- Construct Binary Tree from Preorder and Inorder
Question: Given preorder and inorder traversal of a tree, construct the binary tree. Note:You may as ...
- 简单的FreeBSD 的内核编译
简单的FreeBSD 的内核编译 删除并重新下载内核源码 删除自带的内核源码rm -rf /usr/src 下载内核源码wget https://download.freebsd.org/ftp/re ...
- HITOJ 2739 The Chinese Postman Problem(欧拉回路+最小费用流)
The Chinese Postman Problem My Tags (Edit) Source : bin3 Time limit : 1 sec Memory limit : 6 ...
- 决策树与随机森林Adaboost算法
一. 决策树 决策树(Decision Tree)及其变种是另一类将输入空间分成不同的区域,每个区域有独立参数的算法.决策树分类算法是一种基于实例的归纳学习方法,它能从给定的无序的训练样本中,提炼出树 ...
- linux系统初始化——文件系统初始化步骤
linux文件系统初始化步骤 System V init启动过程 概括地讲,Linux/Unix系统一般有两种不同的初始化启动方式. 1) BSD system init 2) System V in ...
- Gcd反应堆 (pgcd)
Gcd反应堆 (pgcd) 题目描述 不知什么时候起,TA突然对gcd产生了浓厚的兴趣,于是他为此编写了个程序,输入分别不大于m,n (1<m,n<=10^7)的两个数,就能得出gcd(m ...
- Access-Control-Allow-Origin设置多个域名
Access-Control-Allow-Origin只能返回一个. 所以用以下方法实现多个白名单域名:创建一个数据,获取请求中origin,如果在数组里,就返回该origin,如果不在,就返回一个默 ...