一些swift问题
写得比较快,如果有问题请私信。
序列化和反序列化
反序列化的jsonString2只是给定的任意json字符串
private func p_testDecodeTable() {let arr = ["recordID123456", "recordID2"]// 序列化[string] -> json datalet jsonData = try? JSONEncoder().encode(arr)print("data:")print(String(describing: jsonData))let jsonString = String(data: jsonData!, encoding: .utf8)print("jsonString:")print(jsonString!)// 反序列化, json data -> [string]let jsonString2 = jsonStringlet jsondata2 = jsonString2!.data(using: .utf8)print("decode data:\(jsondata2!)")if let decodeArr = try? JSONDecoder().decode([String].self, from: jsondata2!) {print("decode arr:")decodeArr.forEach {print($0)}}
}
字符串插值和数据库sql语句结合
参考下面代码,需要注意String(format:)是多参数的形式, 不需要放数组里, 有多少个参数都可以直接写入。
database.executeUpdate则是需要把参数都放withArgumentsIn的数组里。
// 某处定义了这个
static let sUpdateTable = """
update %@ set %@ = ? where id = ?;
"""// 在处理的地方可以这么写, dbQueue是FMDatabaseQueue(path:)方法创建的
dbQueue.inDatabase { database in// 组成字符串let sentence1 = sUpdateTablelet tableName1 = "address"let column1 = "detail"let str1 = String(format: sentence1, tableName1, column1)print(str1)// 组装成sql语句并且执行let value1 = "somePlace"let id1 = 30if !database.executeUpdate(str1, withArgumentsIn: [value1, id1]) {print("error: table \(tableName1) detail \(column1)")}
}
得到的数据库语句如下,问号符号在database.executeUpdate语句中会替换成value1和id1的值
字符串裁剪
let title = "sdfjkhdsfashdfkjlhsakdsdfhdgdfg"// 方法1
let endIndex = title.index(title.startIndex, offsetBy: 10)
let subtitle = title[..<endIndex]// 方法2
let subtitle2 = title.truncate(toLength: 20)
字符串和数组的转化
// 为了得到["key3", "key4"]的数组
let string = "#key3#key4"
let arr = string.components(separatedBy: "#")// 为了得到"#key5#key6"的字符串
let keywordArr = ["key5", "key6"]
let str = keywordArr.joined(separator: "#")
sql语句可以用三个引号
dbQueue.inDatabase { database inlet sql = """insert into marks (titles)values (?);"""database.executeUpdate(sql, withArgumentsIn: ["我的标题222"])
}/// 可以写多个参数, 只要与问号个数以及ArgumentIn数组的值对应起来即可let sql = """
insert into marks (titles, detail, referenceImage)
values (?, ?, ?);
"""
一些内容在swiftGG文档上说得挺清楚的