我在尝试将保存的数据从CoreData导出到CSV文件时遇到问题。我的最终目标是将信息保存为CSV并将其附加到电子邮件中。这是我导出数据的代码:
- (IBAction)exportData
{
mieleWasherAppDelegate *exportObjects = [[mieleWasherAppDelegate alloc] init];
[exportObjects managedObjectContext];
NSFetchRequest * allContacts = [[NSFetchRequest alloc] init];
[allContacts setEntity:[NSEntityDescription entityForName:@"Contacts" inManagedObjectContext: [exportObjects managedObjectContext]]];
// [allContacts setIncludesPropertyValues:YES]; //only fetch the managedObjectID
NSError * error = nil;
NSArray * entries = [[exportObjects managedObjectContext] executeFetchRequest:allContacts error:&error];
[allContacts release];
//error handling goes here
NSMutableArray *array = [[NSMutableArray alloc] init];
for (Contacts * entry in entries)
{
NSLog(@"Salutation: %@", entry.Salutation);
NSLog(@"First Name: %@", entry.FirstName);
NSLog(@"Last Name: %@", entry.LastName);
NSLog(@"Company Name: %@", entry.CompanyName);
NSLog(@"Email Address: %@", entry.EmailAddress);
NSLog(@"Phone Number: %@", entry.PhoneNumber);
[array addObject:entry];
}
NSError *saveError = nil;
[[exportObjects managedObjectContext] save:&saveError];
//more error handling here
// Export to CSV code
NSString *separator = @", ";
NSString *csv = @"";
for (NSArray *entry in entries)
{
csv = [NSString stringWithFormat:@"%@%@%@%@%@\n", csv, [entry Salutation],
separator, [entry FirstName],
separator, [entry LastName],
separator, [entry CompanyName],
separator, [entry EmailAddress],
separator, [entry PhoneNumber]];
}
//If you want to store in a file the CVS
//[csv writeToFile:pathToFile atomically:YES];
//If you want to store in a file the CVS
//[cvs writeToFile:pathToFile atomically:YES];
}
很抱歉,如果格式有点乱,但它会返回以下警告(重复):
NSArray可能无法回应'-Salutation'
等。直到它遍历所有领域。我似乎无法弄清楚它为什么不合作。有什么建议吗?
答案 0 :(得分:2)
在您复制的代码中的第二个for
循环中&粘贴在上面,您将entry
声明为NSArray
对象而不是Contacts
对象。
将NSArray
更改为Contacts
,警告就会消失。