11

所以我正在创建一个 .csv 文件,然后允许用户使用 UIActivityViewController 共享它。

我创建 csv 文件的代码将返回文件的 NSURL:

- (NSURL *)exportToCSV
{
    NSString *docPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)objectAtIndex:0];
    NSString *filePath = [docPath stringByAppendingPathComponent:@"results.csv"];

    if (![[NSFileManager defaultManager] fileExistsAtPath:docPath]) {
        [[NSFileManager defaultManager] createFileAtPath:filePath
                                                contents:nil
                                              attributes:nil];
    }

    NSMutableString *contents = [NSMutableString stringWithCapacity:0];

    //fill contents with data in csv format
    // ...

    NSFileHandle *fileHandle = [NSFileHandle fileHandleForUpdatingAtPath:filePath];
    [fileHandle writeData:[contents dataUsingEncoding:NSUTF8StringEncoding]];
    [fileHandle closeFile];

    return [NSURL fileURLWithPath:filePath];
}

然后我的活动使用该 NSURL 来启动 UIActivityViewController:

- (IBAction)shareButtonPressed:(id)sender {

    NSArray *activityItems = @[@"results.csv", [self.object exportToCSV]];
    UIActivityViewController *shareScreen = [[UIActivityViewController alloc] initWithActivityItems:activityItems applicationActivities:nil];

    [self presentViewController:shareScreen animated:YES completion:nil];
}

当我选择邮件选项时,未附加 csv 文件。它只有文本“results.csv”

我究竟做错了什么?

4

3 回答 3

6

问题似乎在你的fileExistsAtPath行中。您似乎在说“如果文档目录不存在,则创建文件”。这当然不对。

就个人而言,我会失去那些东西并将其更改为

- (NSURL *)exportToCSV
{
    NSString *docPath = [NSSearchPathForDirectoriesInDomains(NSDocumentDirectory, NSUserDomainMask, YES)objectAtIndex:0];
    NSString *filePath = [docPath stringByAppendingPathComponent:@"results.csv"];

    NSMutableString *contents = [NSMutableString stringWithCapacity:0];

    //fill contents with data in csv format
    // ...

    NSError *error;

    [contents writeToFile:filePath
               atomically:YES
                 encoding:NSUTF8StringEncoding
                    error:&error];

    // check for the error

    return [NSURL fileURLWithPath:filePath];
}
于 2012-12-16T23:25:28.657 回答
5

我想分享我的 UIActivityViewController 解决方案并将文本分享为 CSV 文件。此解决方案适用于通过邮件共享,甚至保存到 Dropbox。

@IBAction func shareCsv(sender: AnyObject) {
    //Your CSV text
    let str = self.descriptionText.text!
    filename = getDocumentsDirectory().stringByAppendingPathComponent("file.csv")

    do {
        try str.writeToFile(filename!, atomically: true, encoding: NSUTF8StringEncoding)

        let fileData = NSURL(fileURLWithPath: filename!)

        let objectsToShare = [fileData]
        let activityVC = UIActivityViewController(activityItems: objectsToShare, applicationActivities: nil)

        self.presentViewController(activityVC, animated: true, completion: nil)

    } catch {
        print("cannot write file")
        // failed to write file – bad permissions, bad filename, missing permissions, or more likely it can't be converted to the encoding
    }

}

func getDocumentsDirectory() -> NSString {
    let paths = NSSearchPathForDirectoriesInDomains(.DocumentDirectory, .UserDomainMask, true)
    let documentsDirectory = paths[0]
    return documentsDirectory
}

希望能帮助到你!:)

于 2016-01-03T21:51:30.733 回答
5

这对我来说是 Swift 3 版本,在 Mail 中作为附件工作并保存在 Dropbox 中。

var csvDetailsString = ""

for myObject in myObjectsArray {
    csvDetailsString = csvDetailsString.appending(myObject.someText)
    csvDetailsString = csvDetailsString.appending(",")
    csvDetailsString = csvDetailsString.appending("More Stuff")
    csvDetailsString = csvDetailsString.appending("\n")

}

let fileName = "Output"
let docDirectory = try? FileManager.default.url(for: .documentDirectory, in: .userDomainMask, appropriateFor: nil, create: true)
if let fileURL = docDirectory?.appendingPathComponent(fileName).appendingPathExtension("csv") {
    do {
        try csvDetailsString.write(to: fileURL, atomically: true, encoding: .utf8)

        let objectsToShare = [fileURL]
        let activityVC = UIActivityViewController(activityItems: objectsToShare, applicationActivities: nil)

        activityVC.excludedActivityTypes = [UIActivityType.addToReadingList]
        self.present(activityVC, animated: true, completion: nil)

    } catch let error as NSError {
        print("Failed writing to URL: \(fileURL), Error: " + error.localizedDescription)
    }
}
于 2016-11-14T12:43:40.487 回答