微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

swift 3.1如何从CSV获取数组或字典

我怎样才能在这种CSV文件中使用数据?或者我如何打印“内部”列的第2行值并将其分配给属性/实体?

我有这种从excel文件转换为Numbers的文件,我想抓取每列的数据并使用它们.

原始CSV文件以数字打开:

我得到的控制台输出

使用这种方法

func readDataFromCSV(fileName:String,fileType: String)-> String!{
        guard let filepath = Bundle.main.path(forResource: fileName,ofType: fileType)
            else {
                return nil
        }
        do {
            var contents = try String(contentsOfFile: filepath,encoding: .utf8)
            contents = cleanRows(file: contents)
            return contents
        } catch {
            print("File Read Error for file \(filepath)")
            return nil
        }
    }


func cleanRows(file:String)->String{
    var cleanFile = file
    cleanFile = cleanFile.replacingOccurrences(of: "\r",with: "\n")
    cleanFile = cleanFile.replacingOccurrences(of: "\n\n",with: "\n")
    //        cleanFile = cleanFile.replacingOccurrences(of: ";;",with: "")
    //        cleanFile = cleanFile.replacingOccurrences(of: ";\n",with: "")
    return cleanFile
}

解决方案感谢Jens Meder

运用

func csv(data: String) -> [[String]] {
        var result: [[String]] = []
        let rows = data.components(separatedBy: "\n")
        for row in rows {
            let columns = row.components(separatedBy: ";")
            result.append(columns)
        }
        return result
    }

在viewDidLoad中

var data = readDataFromCSV(fileName: kCSVFileName,fileType: kCSVFileExtension)
    data = cleanRows(file: data!)
    let csvRows = csv(data: data!)
    print(csvRows[1][1]) // UXM n. 166/167
你想要做的是将字符串分成行然后分成列(基本上是字符串的二维数组). Swift已经为String结构提供了 components方法.
func csv(data: String) -> [[String]] {
    var result: [[String]] = []
    let rows = data.components(separatedBy: "\n")
    for row in rows {
        let columns = row.components(separatedBy: ";")
        result.append(columns)
    }
    return result
}

然后您可以通过以下方式访问任何值

var data = readDataFromCSV(fileName: kCSVFileName,fileType: kCSVFileExtension)
data = cleanRows(file: data)
let csvRows = csv(data: data)
print(csvRows[1][1]) //UXM n. 166/167.

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐