一些swift问题

写得比较快,如果有问题请私信。

序列化和反序列化

反序列化的jsonString2只是给定的任意json字符串

Swift 复制代码
private func p_testDecodeTable() {
    let arr = ["recordID123456", "recordID2"]

    // 序列化[string] -> json data
    let 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 = jsonString
    let 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的数组里。

Swift 复制代码
// 某处定义了这个
static let sUpdateTable = """
update %@ set %@ = ? where id = ?;
"""

// 在处理的地方可以这么写, dbQueue是FMDatabaseQueue(path:)方法创建的
dbQueue.inDatabase { database in
    // 组成字符串
    let sentence1 = sUpdateTable
    let tableName1 = "address"
    let column1 = "detail"
    let str1 = String(format: sentence1, tableName1, column1)
    print(str1)
            
    // 组装成sql语句并且执行
    let value1 = "somePlace"
    let id1 = 30
    if !database.executeUpdate(str1, withArgumentsIn: [value1, id1]) {
    print("error: table \(tableName1) detail \(column1)")
    }
}

得到的数据库语句如下,问号符号在database.executeUpdate语句中会替换成value1和id1的值

字符串裁剪

Swift 复制代码
let title = "sdfjkhdsfashdfkjlhsakdsdfhdgdfg"

// 方法1            
let endIndex = title.index(title.startIndex, offsetBy: 10)
let subtitle = title[..<endIndex]

// 方法2
let subtitle2 = title.truncate(toLength: 20)

字符串和数组的转化

Swift 复制代码
// 为了得到["key3", "key4"]的数组
let string = "#key3#key4"
let arr = string.components(separatedBy: "#")

// 为了得到"#key5#key6"的字符串
let keywordArr = ["key5", "key6"]
let str = keywordArr.joined(separator: "#")

sql语句可以用三个引号

Swift 复制代码
dbQueue.inDatabase { database in
    let sql = """
    insert into marks (titles)
    values (?);
    """

    database.executeUpdate(sql, withArgumentsIn: ["我的标题222"])
}


/// 可以写多个参数, 只要与问号个数以及ArgumentIn数组的值对应起来即可

let sql = """
insert into marks (titles, detail, referenceImage)
values (?, ?, ?);
"""
一些内容在swiftGG文档上说得挺清楚的
相关推荐
假装自己很用心3 天前
iOS 内购接入StoreKit2 及低与iOS 15 版本StoreKit 1 兼容方案实现
ios·swift·storekit·storekit2
大熊猫侯佩5 天前
Swift 趣味开发:查找拼音首字母全部相同的 4 字成语(下)
开发语言·正则表达式·字符串·swift·string·成语·文本解析
Johnny Tong6 天前
ReactiveSwift 简单使用
swift
Swift社区8 天前
LeetCode - #183 Swift 实现查询未下订单的客户
算法·leetcode·swift
大熊猫侯佩9 天前
Swift 趣味开发:查找拼音首字母全部相同的 4 字成语(上)
ai·chatgpt·swift·趣味·拼音·成语·文本解析
来自于狂人9 天前
Openstack持久存储之Swift
云计算·openstack·swift
打工人你好9 天前
Swift UI开发指南:修饰器特性(modifiers)
开发语言·ui·swift
Swift社区10 天前
LeetCode - #182 Swift 实现找出重复的电子邮件
算法·leetcode·swift
货拉拉技术10 天前
货拉拉用户端SwiftUI踩坑之旅
ios·swiftui·swift
来自于狂人12 天前
Openstack持久存储-Swift,Cinder,Manila三者之间的区别
服务器·openstack·swift