我正在使用 CHCSVParser(由 Dave DeLong 编写)通过邮件编写器将核心数据导出到 csv 中,但问题是它采用的是核心数据表名称而不是行值。
另外,我希望它们按特定顺序排列。例如“下水道编号”、“沙井 1”、“沙井 2”
这是我正在使用的编码:
//从核心数据中获取数据
NSManagedObjectContext *moc = [self managedObjectContext];
NSEntityDescription *entityDescription = [NSEntityDescription
entityForName:@"Input_Details" inManagedObjectContext:moc];
NSFetchRequest *request = [[NSFetchRequest alloc] init];
request.predicate = [NSPredicate predicateWithFormat:@"rs_Input_project.name = %@", self.projectObject.name];
[request setEntity:entityDescription];
request.resultType = NSDictionaryResultType;
NSSortDescriptor *sortDescriptor = [[NSSortDescriptor alloc] initWithKey:@"sewer_No" ascending:YES];
[request setSortDescriptors:@[sortDescriptor]];
NSError *error;
NSArray *fetchedObjects = [moc executeFetchRequest:request error:&error];
//creating a csv CHCSVWriter
NSOutputStream *output = [NSOutputStream outputStreamToMemory];
CHCSVWriter *writer = [[CHCSVWriter alloc] initWithOutputStream:output encoding:NSUTF8StringEncoding delimiter:','];
for (id object in fetchedObjects)
{
if ([object conformsToProtocol:@protocol(NSFastEnumeration)])
{
[writer writeLineOfFields:object];
}
}
[writer closeStream];
NSData *buffer = [output propertyForKey:NSStreamDataWrittenToMemoryStreamKey];
NSString *string = [[NSString alloc] initWithData:buffer encoding:NSUTF8StringEncoding];
NSLog(@"Length of Buffer:%d Error:%@",[buffer length],[error localizedDescription]);
if ( [MFMailComposeViewController canSendMail] )
{
MFMailComposeViewController *mailComposer = [[MFMailComposeViewController alloc] init];
mailComposer.mailComposeDelegate = self;
NSData *myData = [string dataUsingEncoding:NSUTF8StringEncoding];
NSLog(@"myData csv:%@",myData);
NSLog(@"string csv:%@",string);
// Fill out the email body text
NSString *emailBody = @"Sewer_Output";
[mailComposer setMessageBody:emailBody isHTML:NO];
//attaching the data and naming it Sewer_Output
[mailComposer addAttachmentData:myData mimeType:@"text/cvs" fileName:@"Sewer_Output.csv"];
[self presentModalViewController:mailComposer animated:YES];
}