如何将Core Data导出为CSV

Des*_*ond 5 iphone xcode core-data ios export-to-csv

我想用CHCSVParser我的核心数据导出到CSV.我知道如何从实体获取所有价值,但我不知道如何写入CSV.

任何人都可以教我如何用CSV写入CHCSVParser

// Test listing all Infos from the store
NSFetchRequest *fetchRequest = [[NSFetchRequest alloc] init];
NSEntityDescription *entity = [NSEntityDescription 
                               entityForName:@"NoteLog" inManagedObjectContext:context];
[fetchRequest setEntity:entity];

NSArray *fetchedObjects = [context executeFetchRequest:fetchRequest error:&error];
for (NoteLog *noteInfo in fetchedObjects) {

    NSLog(@"Name: %@", noteInfo.city );
    NSLog(@"Name: %@", noteInfo.country);
    NSLog(@"Name: %@", noteInfo.datetime);
    NSLog(@"Name: %@", noteInfo.notelatitude);
    NSLog(@"Name: %@", noteInfo.notelongtitude);
    NSLog(@"Name: %@", noteInfo.state);
    NSLog(@"Name: %@", noteInfo.text);        
}  
Run Code Online (Sandbox Code Playgroud)

Rya*_*los 8

A CHCSVWriter有几种构造CSV文件的方法:

-writeField:接受一个对象并将其-description(在被正确转义后)写入CSV文件.如有必要,它还会写字段分隔符(,).您可以传递一个空字符串(@"")或nil来写一个空字段.

-writeFields: 接受以逗号分隔且以nil结尾的对象列表,并将每个对象发送到-writeField:.

-writeLine用于终止当前的CSV行.如果不调用-writeLine,则所有CSV字段都将位于一行中.

-writeLineOfFields: 接受以逗号分隔且以nil结尾的对象列表,将每个对象发送到-writeField:,然后调用-writeLine.

-writeLineWithFields: 接受一个对象数组,将每个对象发送到-writeField:,然后调用-writeLine.

-writeCommentLine: 接受一个字符串并将其作为CSV样式的注释写入文件.

除了写入文件外,CHCSVWriter还可以初始化直接写入文件NSString.

像这样的东西对你有用.

CHCSVWriter *writer = [[CHCSVWriter alloc] initForWritingToString];

for (NoteLog *noteInfo in fetchedObjects) {

    [writer writeLineOfFields:noteInfo.city, noteInfo.country, noteInfo.datetime, noteInfo.notelatitude, noteInfo.notelongtitude, noteInfo.state, noteInfo.text, nil];     
}  

NSLog(@"My CSV File: %@",writer.stringValue);
Run Code Online (Sandbox Code Playgroud)

  • 为您的特定情况添加了一些代码.如果您粘贴它,您应该在控制台中获得一个漂亮的CSV输出.从那里我相信你知道如何将它放在一个文件中并用它做任何你想做的事情. (2认同)
  • 很高兴听到:)快乐的编码. (2认同)

Mic*_*Fok 8

上面的答案似乎已被弃用,作者用另一个似乎取代了该方法.这对我有用,希望它有所帮助:

NSOutputStream *stream = [[NSOutputStream alloc] initToMemory];
CHCSVWriter *writer = [[CHCSVWriter alloc] initWithOutputStream:stream encoding:NSUTF8StringEncoding delimiter:','];

for (Type *instance in fetchedResults) {
    [writer writeLineOfFields:@[instance.propertyA, instance.B]];
}
[writer closeStream];

NSData *buffer = [stream propertyForKey:NSStreamDataWrittenToMemoryStreamKey];
NSString *output = [[NSString alloc] initWithData:buffer encoding:NSUTF8StringEncoding];
Run Code Online (Sandbox Code Playgroud)