Swift下Data处理全流程:从网络下载,数模转换,本地缓存到页面使用

这篇具有很好参考价值的文章主要介绍了Swift下Data处理全流程:从网络下载,数模转换,本地缓存到页面使用。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Swift下将网络返回json数据转换成struct
假如网络请求返回的数据结构是一个深层嵌套的Json
首先要通过key-value取出这个json中的数据源
// 将返回的json字符串转Dictory
let json = """
{
    "name": "jack",
    "age": 20,
    "description": "A student."
}
""".data(using: .utf8)!
if let jsonData = jsonString.data(using: .utf8) {
    do {
        let json = try JSONSerialization.jsonObject(with: jsonData, options: [])
        if let dictionary = json as? [String: Any],
           let key2 = dictionary["key2"] as? [String: Any],
           let innerKey2 = key2["key2"] as? [String: Any],
           let value = innerKey2["key1"] as? String {
            print(value) // 输出"value3"
        }
    } catch {
        print("解析JSON数据失败:(error)")
    }
}
数模转换
// 定义数据类型,遵守Codable协议
// 注意定义的类型与接口返回对应,否则JSONSerialization时崩溃
// Struct模型可以根据json中的数据关系对应嵌套
struct ContactSimpleModel: Codable {
    var relation: String
    var name: String

    struct ContactSimpleModel1: Codable {
    var relation: String
    var name: String

        struct ContactSimpleModel2: Codable {
        var relation: String
        var name: String
        }

    }
}

 文章来源地址https://www.toymoban.com/news/detail-433639.html

字典与struct互相转换

将字典转换成struct模型
根据网络返回的Dictory,从里面取出数组widgets: Array<[String: Any]>
1.map遍历数组,拿到每一个数组元素字典
2.处理每个元素,先使用JSONSerialization.data(withJSONObject:将字典转成data,
3.再使用JSONDecoder().decode(ContactSimpleModel.self, from: data)将data转成struct结构体。
4.使用struct模型
let decoder = JSONDecoder()
let resList = try widgets.map { (item) -> AdJsonModel in
    let data = try JSONSerialization.data(withJSONObject: item, options: [])
    let res = try decoder.decode(AdJsonModel.self, from: data)
    return res
}
return resList
struct模型转字典
也可以通过给Encodable协议加默认实现,提供便捷Struct转字典方法
// 扩展 Encodable 协议
extension Encodable {
    var dictionary: [String: Any]? {
        if let data = try? JSONEncoder().encode(self) {
            if let dict = try? JSONSerialization.jsonObject(with: data) as? [String: Any] {
                return dict
            }
            return nil
        }
        return nil
    }

}
 
Struct本地缓存
假如没有使用数据库,通过UserDefaults或者Plist文件保存。
使用data进行保存到UserDefaults
struct Person: Codable {
    var name: String
    var age: Int
}

var people = [Person(name: "John", age: 30), Person(name: "Mary", age: 25)]
//转成data保存
let data = try! JSONEncoder().encode(people)
UserDefaults.standard.set(data, forKey: "peopleData")
//取
if let data = UserDefaults.standard.data(forKey: "peopleData") {
    let people = try! JSONDecoder().decode([Person].self, from: data)
}
使用Dictionary保存到Plist文件
本地文件处理
路径判断,创建目录用Url.path
创建目录案例
    lazy var adListDirPath: String? = {
        let documentDic = FileManager.default.urls(for: .documentDirectory, in: .userDomainMask).first
        let adUrl = documentDic?.appendingPathComponent(":ad")
        if let adUrlSub = adUrl {
            var isDic: ObjCBool = ObjCBool(false)
            // 判断adUrlSub.path路径是否存在,如果是文件路径则isDic=false, 如果是目录路径isDic=true
            if FileManager.default.fileExists(atPath: adUrlSub.path, isDirectory: &isDic) && isDic.boolValue {
                return adUrlSub.absoluteString
            }
            
            do {
                // 如果路径不存在,则创建本地路径,withIntermediateDirectories: true表示如果路径中间有未创建的,则把中间的目录也创建
                try FileManager.default.createDirectory(at: adUrlSub, withIntermediateDirectories: true, attributes: nil)
                return adUrlSub.absoluteString
            } catch {
                Logger.error(":adDataManager", content: error.localizedDescription)
                return nil
            }
        }
        return nil
    }()
写文件要用Url.absoluteString
swift中保存plist文件,使用NSDictionary进行保存
1.先删除历史文件
 do {
    try FileManager.default.removeItem(at: filePathUrl)
    return true
} catch {
    Logger.error(":adDataManager", content: error.localizedDescription)
    return false
}
2.保存新文件
NSDictionary(object: adList, forKey: adListRootKey).write(to: filePathUrl, atomically: true)
3.读取本地文件
let dict = try NSDictionary(contentsOf: filePathUrl, error: ())
zip文件解压
  func unzipFile() {
    let zipPath = "/path/to/zip/file"
    let destinationPath = "/path/to/destination/folder"
    do {
        try ZipArchive.unzipFile(atPath: zipPath, toDestination: destinationPath)
    } catch {
        print("Error unzipping file: (error.localizedDescription)")
    }
}

 

先缓存后使用,提高用户体验
SDWebImage的先预下载图片,等启动时直接使用缓存的方法
//0.自定义设置缓存大小
URLCache.shared = URLCache(memoryCapacity: 10 * 1024 * 1024, diskCapacity: 50 * 1024 * 1024, diskPath: nil)
//1.缓存
SDWebImage批量下载图片
SDWebImagePrefetcher.shared().prefetchURLs方法下载的图片本地路径默认是Library/Caches/com.hackemist.SDWebImageCache.default目录下的缓存文件。
可以通过SDWebImageManager.shared().imageCache.diskCachePath方法获取具体路径。
//2.使用
在UIImageView加载图片时,使用AAImageView.sd_setImage(with: url, placeholderImage: nil)进行价值 
//3.删除缓存
SDWebImageManager.shared.imageCache.removeImage(forKey: $0, cacheType: SDImageCacheType.all)

 

 
注意:
对于可选类型的数组,如果没有拆包就map, 那么闭包的入参是拆包的数组
let list = dict[adListRootKey] as? Array<[String: Any]>
if let listSub = list {
    let decoder = JSONDecoder()
    let resList = listSub.map { (item) -> AdJsonModel? in

 

 

 

 

 

到了这里,关于Swift下Data处理全流程:从网络下载,数模转换,本地缓存到页面使用的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • MCU-51:单片机之AD模数转换与DA数模转换

    AD(Analog to Digital):模拟-数字转换,将模拟信号转换为计算机可操作的数字信号 DA(Digital to Analog):数字-模拟转换,将计算机输出的数字信号转换为模拟信号 AD/DA转换打开了计算机与模拟信号的大门,极大的提高了计算机系统的应用范围,也为模拟信号数字化处理提供了

    2023年04月24日
    浏览(32)
  • DAC0832数模转换芯片介绍及使用教程

            DAC0832是采样频率为八位的D/A转换芯片,集成电路内有两级输入寄存器,使DAC0832芯片具备双缓冲、单缓冲和直通三种输入方式。D/A转换结果采用电流形式输出。若需要相应的模拟电压信号,可通过一个高输入阻抗的线性运算放大器实现。运放的反馈电阻可通过RFB端

    2024年02月11日
    浏览(74)
  • HNU-电子测试平台与工具2-数模转换

    数模转换实验 计科XXXX wolf 工程文件我也一并上传了 D级任务 一.实验任务 对74194进行仿真验证,掌握Quartus仿真的基本原则和常规步骤,记录移位寄存器的数据读写,并描述仿真波形,分析结果。 二.实验过程 1.电路连接 2.功能仿真 仿真结果如图所示: 3.波形分析 50ns:s=11,并

    2024年03月17日
    浏览(32)
  • 51单片机入门——数模\模数转换

    要记录一段美妙的音乐,我们至少有两种方式。第一种是使用黑胶唱片,第二种是使用数码文件。 任何一种音乐本质来说,都是一种跟随时间不断变化的信号,如下图(a)所示。它本身具有如下特点: 在时间轴上,信号是连续的,即每一个时刻都对应一个确定的信号。 信号

    2024年02月06日
    浏览(39)
  • LuatOS-SOC接口文档(air780E)--adc - 数模转换

    常量 类型 解释 adc.ADC_RANGE_3_6 number air105的ADC分压电阻开启,范围0~3.76V adc.ADC_RANGE_1_8 number air105的ADC分压电阻关闭,范围0~1.88V adc.ADC_RANGE_3_8 number air780E开启ADC0,1分压电阻,范围0~3.8V adc.ADC_RANGE_1_2 number air780E关闭ADC0,1分压电阻,范围0~1.2V adc.CH_CPU number CPU内部温度的通道id adc.CH

    2024年02月07日
    浏览(37)
  • ARM day7 day8 UART串口、PWM蜂鸣器、WDT看门狗、ADC数模转换

            GPA1_0: RXD2         GPA1_1: TXD2         1)对外设置 (GPIO)             GPA1CON: 0x11400020   3:0-0x2(RXD2)  7:4-0x2(TXD2)         2)对内设置(uart)             ULCON2: 0x13820000   0x3             UCON2:  0x13820004   1:0-01(polling)  3:2-01(polling)             UTRSTAT2: 0-1(r

    2024年02月21日
    浏览(25)
  • 基于FPGA的数据采集、编码、通讯和存储系统设计(即FPGA+RTL8211千兆以太网+SD卡存储+RTC+Uart+AD7606数模转换+电流放大采集等硬件设计与程序验证)

    介绍一个小项目,加强对FPGA相关接口的整体把握。 硬件及软件代码梳理: 硬件系统的主要功能框图,其中FPGA作为处理单元,实现了包括电流和电压的采集、千兆以太网通讯、SD卡本地数据存储和串口通讯等。已经过板级测试,测试包含:千兆网通讯收发测试、AD采集的数据

    2024年04月13日
    浏览(43)
  • LLM Data Pipelines: 解析大语言模型训练数据集处理的复杂流程

    编者按:在训练大语言模型的过程中,构建高质量的训练数据集是非常关键的一步,但关于构建大模型训练所需数据集的通用数据处理流程(Data pipelines)的相关资料极为稀少。 本文主要介绍了基于Common Crawl数据集的数据处理流程。首先,文章概述了Common Crawl的不同数据格式WAR

    2024年02月15日
    浏览(40)
  • 机器学习流程—数据预处理 缩放和转换

    相信机器学习的从业者,一定听到到过“特征缩放”这个术语,它被认为是数据处理周期中不可跳过的部分,因进行相应的操作们可以实现 ML 算法的稳定和快速训练。在本文中,我们将了解在实践中用于执行特征缩放的不同技术。 不同评价指标往往具有不同的 量纲 和量纲单

    2024年03月11日
    浏览(35)
  • Swift的NSClassFromString转换

    在swift 中使用NSClassFromString 从string 转换到 对象,报了Segmentation fault: 11 错误。 正确的写法: NSClassFromString 在Swift中的参数不只是一个单独的类名,而是一个完整的包名加类名组成的字符串,否则会报错: Thread 1: Fatal error: Unexpectedly found nil while unwrapping an Optional value

    2024年02月10日
    浏览(25)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包