Swift框架学习之-数据解析SwiftyJSON

原创 2017-06-07

SwiftyJSON数据解析框架,据ThoughtWorks的周教练说,是由他们中国区的一位同事开发的,在之前我们使用的是OC的解析框架,现在切换到Swift开发,下面就来说一说如何使用该框架。在学习使用之前,你大致需要了解框架如下图几个部分:

集成SwiftyJSON

你可以通过CocoaPods的Podfile来安装你的SwiftyJSON,要求你iOS deployment target 必须在8.0以上

platform :ios, '8.0'

target 'SwiftyJsonDemo' do
  # Comment the next line if you're not using Swift and don't want to use dynamic frameworks
  use_frameworks!
    pod 'SwiftyJSON', '~>3.1.4'
end

用法:

初始化
import SwiftyJSON

这里先准备数据,在你的工程中加入一个文件SwiftyJSON.json文件,并将你的json字符串拷贝至文件(这里我们采用SwiftyJSON官方提供的示例数据)

var jsonData: Data?
if let file = Bundle.main.path(forResource: "SwiftyJSON", ofType: "json") {
    jsonData = try? Data(contentsOf: URL(fileURLWithPath: file))
} else {
    print("Fail")
}

let jsonObject = try JSONSerialization.jsonObject(with: jsonData!, options: .allowFragments) as? [[String: AnyObject]]

let jsonString = String(data: jsonData!, encoding: .utf8)

从上述思维导图给出的,我们可以了解到SwiftyJSON提供了三种初始化JSON方式:

  • 直接通过数据:
let json = JSON(data: jsonData)
  • 通过object: Any初始化:这里需要注意的是参数object必须包含如下属性:NSString/String, NSNumber/Int/Float/Double/Bool, NSArray/Array, NSDictionary/Dictionary, or NSNull;而且这里的JsonString是框架是不会将它转换的你应该通过init(parseJson: String)方式处理,并且所有的dictionary 所包含的keys最好是NSString/String。
let json = JSON(jsonObject as Any)
  • 通过JsonString 初始化:
let json =JSON(parseJSON: jsonString)
通过下标访问

如有如下数据(随意举的一个例子):

[
      {
          "name": {"firstName": "f1", "lastName":"l1"},
          "address":"成都市xxx"
          "mainPage":"http://bit.ly/oauth-dancer",
          "age":23
      }, 
      {
          "name": {"firstName": "f2", "lastName":"l2"},
          "address":"北京市xxx"
          "mainPage":"http://bit.ly/oauth-dancer2",
          "age":25
      }
]
// 数组访问
let student: Dictionary? = json[0].dictionary
let student = json[0].dictionaryValue

// string
let address: String? = student["address"].string
let address = student["address"].stringValue

// int
let age: Int? = student["age"].int
let age = student["age"].intValue

...

从上述你可以看出,SwiftyJSON给我们提供的获取数据包含了Optional 与 Non-Optional两种方式,从源码可以看出各个数据类型各自对应的非可选类型返回的默认值:

fileprivate var rawArray: [Any] = []
fileprivate var rawDictionary: [String : Any] = [:]
fileprivate var rawString: String = ""
fileprivate var rawNumber: NSNumber = 0
fileprivate var rawNull: NSNull = NSNull()
fileprivate var rawBool: Bool = false

sub 访问:SwiftyJSON还提供了一个比较便捷的方式访问,比如你需要访问上述数据中第一个数据的firstName

// 常规方式
let firstName = json[0]["name"]["firstName"].stringValue
// path 访问方式
let firstName = json[0, "name", "first"].stringValue
遍历数据

遍历Dictionary :

for (key, subJSON) : (String, JSON) in json {
    print("key : \(key)   subJson-Type : \(subJSON?.type)")
}

遍历数组Array:

// 在这里需要注意的是:此时的index应该是 0..<json.count的字符串
for (index, subJSON) : (String, JSON) in json {
    print("index : \(index)   subJSON-Type : \(subJSON?.type)")
}

此时的结果应该是:
index : 0  subJSON-Type : dictionary
index : 1  subJSON-Type : dictionary
通过字面量转换
//StringLiteralConvertible
let json: JSON = "I'm a json" 

//DictionaryLiteralConvertible
let json: JSON =  ["I":"am", "a":"json"]

//ArrayLiteralConvertible
let json: JSON =  ["I", "am", "a", "json"]

//Array & Dictionary
var json: JSON =  ["name": "Jack", "age": 25, "list": ["a", "b", "c", ["what": "this"]]]
json["list"][3]["what"] = "that"
json["list",3,"what"] = "that"

json["list",3,"what"] = "that"

...
错误处理

在现有版本3.x中通过Global Variables定义了:

///Error code
public let ErrorUnsupportedType: Int = 999
public let ErrorIndexOutOfBounds: Int = 900
public let ErrorWrongType: Int = 901
public let ErrorNotExist: Int = 500
public let ErrorInvalidJSON: Int = 490

根据Github上的介绍在4.x版本中使用的是SwiftyJSONError:

public enum SwiftyJSONError: Int, Swift.Error {
    case unsupportedType = 999
    case indexOutOfBounds = 900
    case elementTooDeep = 902
    case wrongType = 901
    case notExist = 500
    case invalidJSON = 490
}
其他处理方式
// 将JSON转换为rawData
if let data = json.rawData() {
}

// 将JSON转换为rawString
if let string = json.rawString() {
}

// 判定是否存在
if json["name"].exists() {
    print("exist")
}

SwiftyJSON的基础用法就介绍到这里,更多深入的用法可以到Github查阅,或者阅读源码查看。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,294评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,493评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,790评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,595评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,718评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,906评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,053评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,797评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,250评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,570评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,711评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,388评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,018评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,796评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,023评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,461评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,595评论 2 350

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,633评论 18 139
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,066评论 4 62
  • 这是个旅途 一个叫做命运的茫茫旅途 我们偶然相遇 然后离去 在这条永远不归的路 我们路过高山 我们路过湖泊 我们路...
    小合欢阅读 177评论 0 0
  • 文|阿杰说 很多时候,感觉脑中有千军万马,可是要写到笔下却才思枯竭;想法天马行空,现实中却一筹莫展。 我想这大概就...
    阿杰说阅读 1,625评论 16 39
  • 先从养成一个小的自控力的习惯开始,五分钟的冥想或者用左手来完成一些动作。不要想着马上就能提高自控力。 在运动我们感...
    哇620阅读 280评论 0 0