2012-04-12 16 views
14

Voglio scrivere i dati dal file sql al file csv. Ho raccolto tutti i dati dal file sql in un array e utilizzando per il ciclo sto accodando e scrivendo dati in un file .csv. ma sembra che mostri i dati in una riga solo che non va a una nuova riga per creare una nuova riga. Ho usato this come riferimento. Questo è il mio codice:Crea file csv dalla matrice di dati in iOS

-(NSString *)dataFilePath { 
    NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES); 
    NSString *documentsDirectory = [paths objectAtIndex:0]; 
    return [documentsDirectory stringByAppendingPathComponent:@"myfile.csv"]; 
} 

- (IBAction)saveAsFileAction:(id)sender {  
    if (![[NSFileManager defaultManager] fileExistsAtPath:[self dataFilePath]]) { 
     [[NSFileManager defaultManager] createFileAtPath: [self dataFilePath] contents:nil attributes:nil]; 
     NSLog(@"Route creato");   
    } 

    NSString *writeString;  
    for (int i=0; i<[dataArray count]; i++) {   
     writeString = [NSString stringWithFormat:@"%@, %@, %@, %@, %0.2f,",[[dataArray objectAtIndex:i]dates],[[dataArray objectAtIndex:i] time],[[dataArray objectAtIndex:i] category],[[dataArray objectAtIndex:i]place],[[dataArray objectAtIndex:i] amount]];   
     NSLog(@"writeString :%@",writeString);   
     NSFileHandle *handle; 
     handle = [NSFileHandle fileHandleForWritingAtPath: [self dataFilePath] ]; 
     //say to handle where's the file fo write 
     [handle truncateFileAtOffset:[handle seekToEndOfFile]]; 
     //position handle cursor to the end of file 
     [handle writeData:[writeString dataUsingEncoding:NSUTF8StringEncoding]];  
    }  
} 

risposta

35

Questo scrive solo una linea, perché si riscrive il file ogni volta che si passa attraverso il vostro ciclo. È meglio non writeData sul file fino al completamento del ciclo. Vorrei anche usare un NSMutableString come questo:

- (IBAction)saveAsFileAction:(id)sender { 

    if (![[NSFileManager defaultManager] fileExistsAtPath:[self dataFilePath]]) { 
     [[NSFileManager defaultManager] createFileAtPath: [self dataFilePath] contents:nil attributes:nil]; 
     NSLog(@"Route creato"); 
    } 

    NSMutableString *writeString = [NSMutableString stringWithCapacity:0]; //don't worry about the capacity, it will expand as necessary 

    for (int i=0; i<[dataArray count]; i++) { 
     writeString = [writeString appendString:[NSString stringWithFormat:@"%@, %@, %@, %@, %0.2f, \n",[[dataArray objectAtIndex:i]dates],[[dataArray objectAtIndex:i] time],[[dataArray objectAtIndex:i] category],[[dataArray objectAtIndex:i]place],[[dataArray objectAtIndex:i] amount]]]; //the \n will put a newline in 
     } 
    } 

    //Moved this stuff out of the loop so that you write the complete string once and only once. 
    NSLog(@"writeString :%@",writeString); 

    NSFileHandle *handle; 
    handle = [NSFileHandle fileHandleForWritingAtPath: [self dataFilePath] ]; 
    //say to handle where's the file fo write 
    [handle truncateFileAtOffset:[handle seekToEndOfFile]]; 
    //position handle cursor to the end of file 
    [handle writeData:[writeString dataUsingEncoding:NSUTF8StringEncoding]]; 
}  
+0

Grazie. il codice funziona perfettamente ... grazie. –

+0

Nessun problema, felice di aver aiutato. – sosborn

+0

ehi sai come recuperare gli stessi dati dal file csv? @Prernachavan – iSwaroop

5
NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory , NSUserDomainMask, YES); 
    NSString *documentsDir = [paths objectAtIndex:0]; 
    NSString *root = [documentsDir stringByAppendingPathComponent:@"customers.csv"]; 

    NSString *temp; 

    temp = [NSString stringWithFormat:@"%@", [arrCustomersName objectAtIndex:0]]; 

    for (int i = 1; i < [arrCustomersName count]; i++) { 

     temp = [temp stringByAppendingFormat:@", %@", [arrCustomersName objectAtIndex:i]]; 
    } 

    [temp writeToFile:root atomically:YES encoding:NSUTF8StringEncoding error:NULL]; 
0

Invece di:

NSArray *paths = NSSearchPathForDirectoriesInDomains(NSDocumentDirectory , NSUserDomainMask, YES); 
NSString *documentsDir = [paths objectAtIndex:0]; 
NSString *root = [documentsDir stringByAppendingPathComponent:@"customers.csv"]; 

... basta scrivere:

NSString *root = [NSHomeDirectory() stringByAppendingPathComponent:@"customers.csv"]; 

Esattamente lo stesso risultato per una sola linea corta di codice. ; O)

0
// For CSV File : 
     NSMutableString *stringToWrite = [[NSMutableString alloc] init]; 
[stringToWrite appendString:[NSString stringWithFormat:@"First Name,Last Name,Full Name,Phone Number, Email,Job, organizationName,Note\n\n"]]; 
dispatch_async(dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0), ^{ 
     for(int i = 0 ;i<[Contact count];i++)  { 
      [stringToWrite appendString:[NSString stringWithFormat:@"%@,",[[Contact objectAtIndex:i] valueForKey:@"firstName"] ]]; 
      [stringToWrite appendString:[NSString stringWithFormat:@"%@,",[[Contact objectAtIndex:i] valueForKey:@"lastName"] ]]; 
      [stringToWrite appendString:[NSString stringWithFormat:@"%@,",[[Contact valueForKey:@"userName"] objectAtIndex:i]]]; 
      [stringToWrite appendString:[NSString stringWithFormat:@"%@,",[[Contact objectAtIndex:i] valueForKey:@"phoneNumber"] ]]; 
      [stringToWrite appendString:[NSString stringWithFormat:@"%@,",[[Contact objectAtIndex:i] valueForKey:@"emailAddress"] ]]; 
      [stringToWrite appendString:[NSString stringWithFormat:@"%@,",[[Contact objectAtIndex:i] valueForKey:@"jobTitle"] ]]; 
      [stringToWrite appendString:[NSString stringWithFormat:@"%@,",[[Contact objectAtIndex:i] valueForKey:@"organizationName"] ]]; 
      [stringToWrite appendString:[NSString stringWithFormat:@"%@\n",[[Contact objectAtIndex:i] valueForKey:@"note"] ]]; 
     } 
     dispatch_async(dispatch_get_main_queue(), ^(void) { 
      NSArray *paths=NSSearchPathForDirectoriesInDomains(NSDocumentDirectory,NSUserDomainMask,YES); 
      NSString *documentDirectory=[paths objectAtIndex:0]; 
      NSString *strBackupFileLocation = [NSString stringWithFormat:@"%@/%@", documentDirectory,@"ContactList.csv"]; 
      [stringToWrite writeToFile:strBackupFileLocation atomically:YES encoding:NSUTF8StringEncoding error:nil]; 
     }); 
}); 
+0

Grazie per l'aiuto, ma una risposta è meglio con qualche spiegazione che solo un intero blocco di codice – goto

0

Prova questo si sta lavorando per me,

Se qualcuno desidera creare file .csv in rapida 3

// MARK: CSV file creating 
    func creatCSV() -> Void { 

    let fileName = "Tasks.csv" 

    let path = NSURL(fileURLWithPath: NSTemporaryDirectory()).appendingPathComponent(fileName) 
    var csvText = "Date,Task Name,Time Started,Time Ended\n" 

    for task in taskArr { 
     let newLine = "\(task.date),\(task.name),\(task.startTime),\(task.endTime)\n" 
     csvText.append(newLine) 
    } 

    do { 
     try csvText.write(to: path!, atomically: true, encoding: String.Encoding.utf8) 
    } catch { 
     print("Failed to create file") 
     print("\(error)") 
    } 
    print(path ?? "not found") 
    } 
    } 

Per maggiori dettagli si può fare riferimento Detail Answer

Si spera che questo possa aiutare qualcuno.