objective-c – 核心数据按日期排序使用FetchedResultsController分段

前端之家收集整理的这篇文章主要介绍了objective-c – 核心数据按日期排序使用FetchedResultsController分段前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我目前有一个类中有一个日期对象.此日期对象包含时间和日期.所有这些信息都通过NSFetchedResultsController加载到UITableViewCell中.我需要将日期排序为每个部分是没有时间的日期的部分.我还需要按时间对每个部分进行自我排序.这是我当前的_fetchedResultsController的样子:
[self.managedObjectContext lock];
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription
                               entityForName:@"Entity" inManagedObjectContext:self.managedObjectContext];
[fetchRequest setEntity:entity];

NSSortDescriptor *sort = [[NSSortDescriptor alloc]
                          initWithKey:@"due" ascending:YES];
[fetchRequest setSortDescriptors:[NSArray arrayWithObject:sort]];

[fetchRequest setFetchBatchSize:20];

NSFetchedResultsController *theFetchedResultsController =
[[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest
                                    managedObjectContext:self.managedObjectContext sectionNameKeyPath:nil
                                               cacheName:@"Root"];
theFetchedResultsController.delegate = sender;
[self.managedObjectContext unlock];
return theFetchedResultsController;

我需要排序的属性是Entity.due属性.

解决方法

您可能需要查看名为“DateSectionTitles”的核心数据示例以获得更多信息,我正在强调它的基础知识.

要根据日期创建部分,您需要先按标准化(或简化)日期排序.请尝试以下方法

在核心数据模型编辑器中为您的实体添加瞬态属性.确保它的类型是NSDate并检查它的瞬态属性.通过将属性添加为强NSDate来更新NSManagedObject类文件.称之为“simplifiedDate”.还要在.h文件添加另一个属性,将其命名为“primitiveSimplifiedDate”.让它变得强大.

在.m中,使用@dynamic作为simplifiedDate和primitiveSimplifiedDate.此瞬态属性应使用返回已标准化为午夜的NSDate.此级别设置所有内容并允许您建立部分.我已经使用了以下代码

-(NSDate *)simplifiedDate{
     // Create and cache the section identifier on demand.

    [self willAccessValueForKey:@"simplifiedDate"];
    NSDate *tmp = [self primitiveSimplifiedDate];
    [self didAccessValueForKey:@"simplifiedDate"];

    if (!tmp) {
        tmp=[self simplifiedDateForDate: [self due]];
        [self setPrimitiveSimplifiedDate: tmp];
    }

    return tmp;
}


-(NSDate *)simplifiedDateForDate:(NSDate *)date {

    if (!date) {
        return nil;
    }

    static NSCalendar *gregorian = nil;

    gregorian=[[NSCalendar alloc] initWithCalendarIdentifier:NSGregorianCalendar];
    NSDateComponents *newDateComponents=[gregorian components:(NSYearCalendarUnit | NSMonthCalendarUnit| NSDayCalendarUnit) fromDate:date];

    return [gregorian dateFromComponents:newDateComponents];
 }

如果您愿意,这也可以是在设置实际日期时计算和存储的实际属性.

接下来,您将有两个排序描述符.第一个排序描述符将是上面的瞬态属性“simplifiedDate”.第二个属性是“due”属性. “simplifiedDate”,只要在下一步中正确设置了NSFetchedResultsController,就会根据该部分对所有内容进行排序.

最后,您需要在分配/初始化NSFetchedResultsController时提供节键名.在这种情况下,它将是“简化日期”.像这样:

NSFetchedResultsController *theFetchedResultsController = [[NSFetchedResultsController alloc] initWithFetchRequest:fetchRequest
                                managedObjectContext:self.managedObjectContext sectionNameKeyPath:@"simplifiedDate"cacheName:@"Root"];

希望这可以帮助.

Ť

原文链接:/c/239675.html

猜你在找的C&C++相关文章