一些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文档上说得挺清楚的
相关推荐
@大迁世界2 天前
Swift、Flutter 还是 React Native:2026 年你该学哪个
开发语言·flutter·react native·ios·swift
Swift社区3 天前
在Swift中实现允许重复的O(1)随机集合
开发语言·ios·swift
初级代码游戏4 天前
iOS开发 SwiftUI 8:NavigationView 导航
ios·swiftui·swift
虹少侠4 天前
基于 WebKit 构建 macOS 多浮窗视频播放的技术实践(含完整产品落地)
前端·macos·swift·webkit
开开心心_Every6 天前
文件数量统计工具:支持多层文件夹数量统计
游戏·微信·pdf·excel·语音识别·swift·lisp
core5128 天前
使用 `ms-swift` 微调 Qwen3-VL-2B 详细指南
lora·微调·swift·qwen·qwen3·vl
core5129 天前
Swift SFT Qwen-VL LoRA 微调指令详解
lora·微调·swift·qwen·vl
Swift社区10 天前
LeetCode 375 - 猜数字大小 II
算法·leetcode·swift
Swift社区10 天前
使用 MetricKit 监控应用性能
ios·swiftui·swift
Swift社区11 天前
LeetCode 374 猜数字大小 - Swift 题解
算法·leetcode·swift