1. int main(int argc, const charchar * argv[]) {
  2. @autoreleasepool {
  3. // 1.定义一个测试的字典数组
  4. NSMutableArray *dictArray = @[
  5. @{
  6. @"FEnabled" : [NSNumber numberWithInt:1],
  7. @"FGroupTag" : [NSNumber numberWithInt:0],
  8. @"FOrder" : [NSNumber numberWithInt:0],
  9. @"FName" : @"宝玉"
  10. },
  11. @{
  12. @"FEnabled" : [NSNumber numberWithInt:1],
  13. @"FGroupTag" : [NSNumber numberWithInt:1],
  14. @"FOrder" : [NSNumber numberWithInt:0],
  15. @"FName" : @"黛玉"
  16. },
  17. @{
  18. @"FEnabled" : [NSNumber numberWithInt:0],
  19. @"FGroupTag" : [NSNumber numberWithInt:1],
  20. @"FOrder" : [NSNumber numberWithInt:1],
  21. @"FName" : @"宝钗"
  22. },
  23. @{
  24. @"FEnabled" : [NSNumber numberWithInt:1],
  25. @"FGroupTag" : [NSNumber numberWithInt:1],
  26. @"FOrder" : [NSNumber numberWithInt:2],
  27. @"FName" : @"湘云"
  28. },
  29. @{
  30. @"FEnabled" : [NSNumber numberWithInt:1],
  31. @"FGroupTag" : [NSNumber numberWithInt:2],
  32. @"FOrder" : [NSNumber numberWithInt:0],
  33. @"FName" : @"妙玉"
  34. },
  35. @{
  36. @"FEnabled" : [NSNumber numberWithInt:1],
  37. @"FGroupTag" : [NSNumber numberWithInt:3],
  38. @"FOrder" : [NSNumber numberWithInt:0],
  39. @"FName" : @"晴雯"
  40. },
  41. @{
  42. @"FEnabled" : [NSNumber numberWithInt:1],
  43. @"FGroupTag" : [NSNumber numberWithInt:3],
  44. @"FOrder" : [NSNumber numberWithInt:1],
  45. @"FName" : @"袭人"
  46. }
  47. ];
  48. // NSArray 转成 NSMutableArray
  49. // 0、对于不启用的,即enabled为0的字典模型,删除掉
  50. NSMutableArray *dictArr = [NSMutableArray array];
  51. for (int i = 0; i < dictArray.count; i++) {
  52. NSDictionary *dict = dictArray[i];
  53. if ([[dict objectForKey:@"FEnabled"]intValue] == 1) {
  54. [dictArr addObject:dict];
  55. }
  56. }
  57. // NSLog(@"清除未启用的字典后的数组:%@",dictArr);
  58. // 1、对数组按GroupTag排序
  59. NSArray *sortDesc = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"FGroupTag" ascending:YES]];
  60. NSArray *sortedArr = [dictArr sortedArrayUsingDescriptors:sortDesc];
  61. // NSLog(@"排序后的数组:%@",sortedArr);
  62. // 2、对数组进行分组,按GroupTag
  63. // 遍历,创建组数组,组数组中的每一个元素是一个模型数组
  64. NSMutableArray *_groupArr = [NSMutableArray array];
  65. NSMutableArray *currentArr = [NSMutableArray array];
  66. NSLog(@"class--%@",[currentArr class]);
  67. // 因为肯定有一个字典返回,先添加一个
  68. [currentArr addObject:sortedArr[0]];
  69. [_groupArr addObject:currentArr];
  70. // 如果不止一个,才要动画添加
  71. if(sortedArr.count > 1){
  72. for (int i = 1; i < sortedArr.count; i++) {
  73. // 先取出组数组中  上一个模型数组的第一个字典模型的groupID
  74. NSMutableArray *preModelArr = [_groupArr objectAtIndex:_groupArr.count-1];
  75. int preGroupID = [[[preModelArr objectAtIndex:0] objectForKey:@"FGroupTag"] intValue];
  76. // 取出当前字典,根据groupID比较,如果相同则添加到同一个模型数组;如果不相同,说明不是同一个组的
  77. NSDictionary *currentDict = sortedArr[i];
  78. int groupID = [[currentDict objectForKey:@"FGroupTag"] intValue];
  79. if (groupID == preGroupID) {
  80. [currentArr addObject:currentDict];
  81. }else{
  82. // 如果不相同,说明 有新的一组,那么创建一个模型数组,并添加到组数组_groupArr
  83. currentArr = [NSMutableArray array];
  84. [currentArr addObject:currentDict];
  85. [_groupArr addObject:currentArr];
  86. }
  87. }
  88. }
  89. // 3、遍历 对每一组 进行排序
  90. NSMutableArray *tempGroupArr = [NSMutableArray array];
  91. for (NSMutableArray *arr in _groupArr) {
  92. NSArray *sortDesc = [NSArray arrayWithObject:[NSSortDescriptor sortDescriptorWithKey:@"FOrder" ascending:YES]];
  93. NSMutableArray *tempArr = [arr sortedArrayUsingComparator:^NSComparisonResult(id obj1, id obj2) {
  94. if([[obj1 objectForKey:@"FOrder"]intValue] < [[obj2 objectForKey:@"FOrder"]intValue]){
  95. return NSOrderedAscending;
  96. }
  97. if([[obj1 objectForKey:@"FOrder"]intValue] > [[obj2 objectForKey:@"FOrder"]intValue]){
  98. return NSOrderedDescending;
  99. }
  100. return NSOrderedSame;
  101. }];
  102. [tempGroupArr addObject:tempArr];
  103. }
  104. _groupArr = tempGroupArr;
  105. NSLog(@"封装好的group数组:%@",_groupArr);
  106. }
  107. return 0;
  108. }

iOS_字典数组 按key分组和排序的更多相关文章

  1. iOS_词典阵列 按key分组和排序

    // // main.m // SortGroup // // Created by beyond on 14-10-26. // Copyright (c) 2014年 beyond.com All ...

  2. python 根据字典中的key,value进行排序

    #coding=utf-8 import requests,json,collections,base64,datetime def sort(datas): data=json.dumps(data ...

  3. NodeJS对象数组Array 根据对象object key的值排序sort

    有个js对象数组 var ary=[{id:1,name:”b”},{id:2,name:”b”}] 需求是根据name 或者 id的值来排序,这里有个风骚的函数. /** * 对数组中的对象,按对象 ...

  4. PHP开发小技巧②—实现二维数组根据key进行排序

    在PHP中内置了很多对数组进行处理的函数,有很多时候我们直接使用其内置函数就能达到我们的需求,得到我们所想要的结果:但是,有的时候我们却不能通过使用内置函数实现我们的要求,这就需要我们自己去编写算法来 ...

  5. python 对字典分别按照key值、value值进行排序

    1.sorted函数首先介绍sorted函数,sorted(iterable,key,reverse),sorted一共有iterable,key,reverse这三个参数. 其中iterable表示 ...

  6. Linq入门演练---(1)基本用法-分组,排序,内连接

    这一节大家共同学习下LINQ的基本用法,主要包括LINQ的分组,排序,和内外连接. 1.分组 基本语法:  group element by key element 表示查询结果返回的元素,key表示 ...

  7. php对二维数组进行相关操作(排序、转换、去空白等)

    php对二维数组进行相关操作(排序.转换.去空白等) 投稿:lijiao 字体:[增加 减小] 类型:转载 时间:2015-11-04   这篇文章主要介绍了php对二维数组进行相关操作,包括php对 ...

  8. JS中遍历普通数组和字典数组的区别

    // 普通数组 var intArray = new Array(); intArray[0] = "第一个"; intArray[1] = "第二个"; fo ...

  9. PHP根据数组的值分组

    PHP根据数组的值分组,php array中没有自带这个函数但是很常用,今天写了出来记录一下. 代码: $_array = array(        array(1,11,'2016-05-18') ...

随机推荐

  1. sources-t.list

    deb http://debian.ustc.edu.cn/ubuntu/ trusty main multiverse restricted universe deb http://debian.u ...

  2. C++ 11 智能指针 lamda 以及一个 围棋程序

    lamda表达式使用 char* p = "Hello world"; ,nl = ; for_each(p,p+, [&](char i){ if(i=='e') ne+ ...

  3. 九宫重排_康拓展开_bfs

      历届试题 九宫重排   时间限制:1.0s   内存限制:256.0MB        问题描述 如下面第一个图的九宫格中,放着 1~8 的数字卡片,还有一个格子空着.与空格子相邻的格子中的卡片可 ...

  4. 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 ...

  5. 简单的FreeBSD 的内核编译

    简单的FreeBSD 的内核编译 删除并重新下载内核源码 删除自带的内核源码rm -rf /usr/src 下载内核源码wget https://download.freebsd.org/ftp/re ...

  6. HITOJ 2739 The Chinese Postman Problem(欧拉回路+最小费用流)

    The Chinese Postman Problem My Tags   (Edit)   Source : bin3   Time limit : 1 sec   Memory limit : 6 ...

  7. 决策树与随机森林Adaboost算法

    一. 决策树 决策树(Decision Tree)及其变种是另一类将输入空间分成不同的区域,每个区域有独立参数的算法.决策树分类算法是一种基于实例的归纳学习方法,它能从给定的无序的训练样本中,提炼出树 ...

  8. linux系统初始化——文件系统初始化步骤

    linux文件系统初始化步骤 System V init启动过程 概括地讲,Linux/Unix系统一般有两种不同的初始化启动方式. 1) BSD system init 2) System V in ...

  9. Gcd反应堆 (pgcd)

    Gcd反应堆 (pgcd) 题目描述 不知什么时候起,TA突然对gcd产生了浓厚的兴趣,于是他为此编写了个程序,输入分别不大于m,n (1<m,n<=10^7)的两个数,就能得出gcd(m ...

  10. Access-Control-Allow-Origin设置多个域名

    Access-Control-Allow-Origin只能返回一个. 所以用以下方法实现多个白名单域名:创建一个数据,获取请求中origin,如果在数组里,就返回该origin,如果不在,就返回一个默 ...