Uitableview 使用NSFetchedResultsController进行排序

Uitableview 使用NSFetchedResultsController进行排序,uitableview,nsfetchedresultscontroller,date-sorting,Uitableview,Nsfetchedresultscontroller,Date Sorting,使用XCode 4.6、iOS6、CoreData、UITableViewController、NSFetchesResultsController 我想出了如何将以下日期输入到NSDate变量中: todayDate yesterdayDate thisWeek lastWeek thisMonth lastMonth lastYear 现在,我想使用NSFetchedResultsController根据上述变量中的数据将数据放入节中。我假设我必须做一些日期比较: if ([date1 c

使用XCode 4.6、iOS6、CoreData、UITableViewController、NSFetchesResultsController

我想出了如何将以下日期输入到NSDate变量中:

todayDate
yesterdayDate
thisWeek
lastWeek
thisMonth
lastMonth
lastYear
现在,我想使用NSFetchedResultsController根据上述变量中的数据将数据放入节中。我假设我必须做一些日期比较:

if ([date1 compare:date2] == NSOrderedDescending) {
NSLog(@"date1 is later than date2");        
} else if ([date1 compare:date2] == NSOrderedAscending) {
    NSLog(@"date1 is earlier than date2");
} else {
    NSLog(@"dates are the same");
}
有些用户可能没有某些部分因此,我需要以下方法的帮助,以根据fetchRequest确定节数:

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
我还需要知道如何将数据划分为单元格
numberofrowsin节:
并将其显示为单元格
cellforrowsin索引路径:

一些代码示例会很好!谢谢

编辑

我还没有集成控制器,但下面是获取的代码:

- (void) refreshTable {

    NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
    NSEntityDescription *entity = [NSEntityDescription entityForName:@"Meeting" inManagedObjectContext:self.managedObjectContext];
    [fetchRequest setEntity:entity];

    NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"lastmoddate" ascending:NO];
    NSArray *sortDescriptors = [NSArray arrayWithObjects:sortDescriptor, nil];

    [fetchRequest setSortDescriptors:sortDescriptors];

    [self.managedObjectContext executeFetchRequest:fetchRequest onSuccess:^(NSArray *results) {
        [self.refreshControl endRefreshing];
        self.objects = results;
        [self.tableView reloadData];

    } onFailure:^(NSError *error) {

        [self.refreshControl endRefreshing];
        NSLog(@"An error %@, %@", error, [error userInfo]);
    }];
以下是我获得日期的方式:

   NSCalendar *cal = [NSCalendar currentCalendar];
    NSDateComponents *components = [cal components:( NSHourCalendarUnit | NSMinuteCalendarUnit | NSSecondCalendarUnit ) fromDate:[[NSDate alloc] init]];

    [components setHour:-[components hour]];
    [components setMinute:-[components minute]];
    [components setSecond:-[components second]];
    NSDate *today = [cal dateByAddingComponents:components toDate:[[NSDate alloc] init] options:0]; //This variable should now be pointing at a date object that is the start of today (midnight);

    [components setHour:-24];
    [components setMinute:0];
    [components setSecond:0];
    NSDate *yesterday = [cal dateByAddingComponents:components toDate: today options:0];

    components = [cal components:NSWeekdayCalendarUnit | NSYearCalendarUnit | NSMonthCalendarUnit | NSDayCalendarUnit fromDate:[[NSDate alloc] init]];

    [components setDay:([components day] - ([components weekday] - 1))];
    NSDate *thisWeek  = [cal dateFromComponents:components];

    [components setDay:([components day] - 7)];
    NSDate *lastWeek  = [cal dateFromComponents:components];

    [components setDay:([components day] - ([components day] -1))];
    NSDate *thisMonth = [cal dateFromComponents:components];

    [components setMonth:([components month] - 1)];
    NSDate *lastMonth = [cal dateFromComponents:components];

这就是我要做的。在该模型中创建核心数据模型和“用户”实体。我想你知道怎么做,但如果你不只是评论,我会解释。然后,只需像处理任何其他实体一样,为您的实体创建一个自定义类,并为其提供lastmoddate-NSDate属性,另外我将添加一个creationDate属性,该属性将等于创建实体的确切日期和时间,以便您可以将其用作每个UserEntity的标识符。对于要在UITableView中创建的每个部分,还必须有一个单独的数组。当您向模型中添加用户实体时,请设置属性,然后因为您说某些用户可能没有所有变量,请将用户实体不需要设置为零的任何变量设置为零。初始化数组时,只需将具有适当属性的用户实体添加到一个值。最后,当您实现-(NSInteger)numberOfSectionsInTableView:(UITableView*)tableView时,您所要做的就是对数组进行计数

下面是它的外观:

我将调用表示每个用户的实体“UserEntity”(其NSManagedObject的类将具有相同的名称)

下面的代码出现在标题中,您将使用该标题的任何类来创建和获取实体-它可能与您用于显示UITableView的类相同

@interface Class : UITableViewController {
    NSManagedObjectContext *managedObjectContext;
    NSMutableArray *arrayOfArrays;
}

@property (retain, nonatomic) NSManagedObjectContext   *managedObjectContext;
@property (retain, nonatomic) NSMutableArray   *arrayOfArrays;
下面的代码是在实现中执行的,您将使用该类创建和获取实体-它可能与您用于显示UITableView的类相同

@interface Class : UITableViewController {
    NSManagedObjectContext *managedObjectContext;
    NSMutableArray *arrayOfArrays;
}

@property (retain, nonatomic) NSManagedObjectContext   *managedObjectContext;
@property (retain, nonatomic) NSMutableArray   *arrayOfArrays;
//用于将UserEntity添加到模型(核心数据数据库)并设置其属性

- (UserEntity *)addUserEntityToModel {
     UserEntity *myEnt = (UserEntity *)[NSEntityDescription insertNewObjectForEntityForName:@"UserEntity" inManagedObjectContext:self.managedObjectContext];

   myEnt.creationDate = [NSDate date];
   myEnt. lastmoddate = ...; //replace the '...' with however you get your date
   //add any other values to the appropriate attributes here, any attributes that do not //pertain to the UserEntity simply ignore - they are automatically set to default when they //are created.

    NSError *error = nil;
    if(!managedObjectContext) 
        NSLog(@"managedObejctContext problem at ...");
    else if (![managedObjectContext save:&error]) {
        NSLog(@"context not saved!");;
    } else 
    NSLog(@"context successfully saved.");      
}
//用于获取用户实体的

- (NSMutableArray *)getFetchArray {

        NSFetchRequest *request = [[NSFetchRequest alloc] init];
        if(!managedObjectContext) {
            NSLog(@"There is no managedObjectContext at getFetchArray");
        }
           NSEntityDescription *entity = [NSEntityDescription entityForName:@"UserEntity" inManagedObjectContext:managedObjectContext];

        [request setEntity:entity];

        NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"creationDate" ascending:NO];
        NSArray *sortDescriptors = [[NSArray alloc] initWithObjects:sortDescriptor, nil];
        [request setSortDescriptors:sortDescriptors];
        [sortDescriptors release];
        [sortDescriptor release];

        NSError *error = nil;
        NSMutableArray *mutableFetchResults = [[managedObjectContext executeFetchRequest:request error:&error] mutableCopy];
        if (mutableFetchResults == nil) {
            NSLog(@"mutableFetchResults array is nil");
        } 
        [request release];

        return mutableFetchResults;
    }
//设置阵列射线

-(void)createArrayOfArrays {
 NSMutableArray *fetchArray = [self getFetchArray];
  NSMutableArray *todayDateArray = [[NSMutableArray alloc] init];
  NSMutableArray *yesterdayDateArray = [[NSMutableArray alloc] init];
  NSMutableArray *thisWeekArray = [[NSMutableArray alloc] init];
        //... create an array for each section you want

for (UserEntity *ue in fetchArray) {
       if(ue.lastmoddate) { //if the attribute is not nil
        if(ue.lastmoddate isEqual todayDate)
       [todayDateArray insertObject:ue atIndex:0];
     else if (ue.lastmoddate isEqual yesterdayDate)
       [yesterdayDateArray insertObject:ue atIndex:0];
        // ... do this for every section array 
        }
    }

 arrayOfArrays = [[NSMutableArray alloc] initWithObjects:todayDateArray,yesterdayDateArray,...(the rest of the arrays created for each attribute), nil]



  [todayDateArray release];
    [yesterdayDateArray release];
  //  ... release all the arrays except arrayOfArrays and fetchArray     
 }
//设置managedObjectContext

- (id)init {
    self = [super init];

    if (self) {
    AppDelegate *appDelegate = [[UIApplication sharedApplication] delegate];//what ever //the name of your appDel is.
        NSManagedObjectContext *context = [appDelegate managedObjectContext];
        self.managedObjectContext = context;

       [self createArrayofArrays];//this first creates the arrayOfArrays and will set it //equal to anything that's saved in the database. If you add an entity you will need to update //it.
    }

    return self;
}

- (NSInteger)numberOfSectionsInTableView:(UITableView *)tableView
{
    // Return the number of sections.
    return arrayOfArrays.count;
}

- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section
{
    // Return the number of rows in the section.
    return [[arrayOfArrays objectAtIndex:section] count];
}
//然后在表视图中显示单元格

- (UITableViewCell *)tableView:(UITableView *)tableView cellForRowAtIndexPath:(NSIndexPath *)indexPath
    {
        static NSString *CellIdentifier = @"Cell";

        UITableViewCell *cell = [tableView dequeueReusableCellWithIdentifier:CellIdentifier];
        if (!cell) {
            cell = [[[UITableViewCell alloc] initWithStyle:UITableViewCellStyleSubtitle reuseIdentifier:CellIdentifier] autorelease];
        }


        UserEntity *ent = (UserEntity *)[[arrayOfArrays objectAtIndex:indexPath.section] objectAtIndex:indexPath.row];
        cell.accessoryType = UITableViewCellAccessoryBasic;
        if(ent.lastmoddate) { //if lastmoddate is not nil
        cell.textLabel.text = ent. lastmoddate;
        } else {
            NSLog(@"lastmoddate is nil at tableView: cellForRowAtIndexPath");
        }

        NSLog(@"tableView: cellForRowAtIndexPath called.");
        return cell;
    }

您是如何获得获取请求的?您的数据是如何组织的?我理解你在使用核心数据。您的日期变量是“用户实体”的属性吗?我更新代码。不,变量不是实体的属性。谢谢。那么每个用户是如何连接到日期的呢?另外,您说您需要帮助实现(NSInteger)numberOfSectionsInTableView:(UITableView*)tableView,因为有些用户可能没有某些部分。这是否意味着您将为每个用户分别调用-(NSInteger)numberOfSectionsInTableView:(UITableView*)tableView?好的,下面是背景。我有一个使用CoreData连接的远程数据库。有一个用户实体和两个其他实体。用户和其他实体之间存在一对多关系。用户名身份验证的用户实体。另外两种方法中的一种叫做“会议”。当用户登录时,我将获取“Meeting”实体中的所有对象,并将它们显示在tableViewController中。在“Meeting”实体中,除其他属性(约20个)外,其中一个属性是“lastmoddate”,与该对象的上次修改日期相同。这是用来排序的。因此,我想在“会议”中获取该用户的所有NSManagedObjects“实体并根据'lastmoddate'对其进行排序,并在以下部分中显示:今天、昨天、上周、上月等。当用户在单元格的底部进行选择时,另一个UITableViewController将显示该对象中属性的所有值。噢,哇..在我键入上述注释时,您写了一个详细的回复。让我复习一下。谢谢。哦,好的,我要做些改变。现在是午夜。我马上给你回电话。非常感谢你的帮助。