Есть ли какой-нибудь способ экспортировать таблицу таблиц в Excel? - PullRequest
0 голосов
/ 01 апреля 2019

Я использую библиотеку таблиц для отображения таблицы. Есть ли какая-либо функция в TableSorter для экспорта таблицы в Excel?

1 Ответ

0 голосов
/ 01 апреля 2019

// экспорт в Excel и электронная почта

enter code here
@IBAction func exportAction(_ sender: UIButton) {
    // Set the path to the path of wherever you put your Excel file.
    // The path in this demo code is the path to the demo.xlsx file.
    path = Bundle.main.path(forResource: "demo", ofType: "xlsx")!

    // Open the spreadsheet, get the first sheet, first worksheet, and first cell A1.
    // This is solely demoed code to show basics; your actual code would do much more here.
    let spreadsheet: BRAOfficeDocumentPackage = BRAOfficeDocumentPackage.open(path)
    let worksheet: BRAWorksheet = spreadsheet.workbook.worksheets[0] as! BRAWorksheet

    for row in 0..<self.data.count {
        let producerName = self.data[row][0]
        let clientName = self.data[row][1]
        let revenue = self.data[row][2]
        let date = self.data[row][3]
        let aCell = "A" + "\(row+2)"
        let bCell = "B" + "\(row+2)"
        let cCell = "C" + "\(row+2)"
        let dCell = "D" + "\(row+2)"

        worksheet.cell(forCellReference: aCell, shouldCreate: true)?.setStringValue(producerName)
        worksheet.cell(forCellReference: bCell, shouldCreate: true)?.setStringValue(clientName)
        worksheet.cell(forCellReference: cCell, shouldCreate: true)?.setStringValue(revenue)
        worksheet.cell(forCellReference: dCell, shouldCreate: true)?.setStringValue(date)
    }

    // save as demoAs.xlsx excel file
    let paths: Array = NSSearchPathForDirectoriesInDomains(FileManager.SearchPathDirectory.documentDirectory, FileManager.SearchPathDomainMask.userDomainMask, true) as Array
    let appendingStr = "/Report " + self.getTodayDateForExport() + ".xlsx"
    let fullPath: String = (paths[0]).appendingFormat(appendingStr)

    spreadsheet.save(as: fullPath)
    path = fullPath
    // Print some info to show the code works.

    print("")
    let fileURL = NSURL(fileURLWithPath: path!)
    let activityVC = UIActivityViewController(activityItems: [fileURL as Any], applicationActivities: nil)
    activityVC.popoverPresentationController!.sourceView = self.view
    activityVC.completionWithItemsHandler = { activity, success, items, error in
        if success {
            self.view.makeToast("reported!")
        } else {
            self.view.makeToast("cancelled!")
        }
    }
    self.present(activityVC, animated: true, completion: nil)
}
...