SwiftyJSON的使用方法

描述:SwiftyJSON是一個(gè)swift編寫的對(duì)json數(shù)據(jù)進(jìn)行解析的類庫,SwiftyJSON的使用極其方便,而且不用擔(dān)心數(shù)組越界等問題

GitHub地址:https://github.com/SwiftyJSON/SwiftyJSON

在本文寫作時(shí),SwiftyJSON在GitHub上的star已經(jīng)達(dá)到了14899,光看star就知道,這個(gè)庫,還是比較值得用的。

1.cocoapods導(dǎo)入并安裝

pod "SwiftyJSON" 

2.在使用的文件中導(dǎo)入頭文件

import SwiftyJSON

3.獲取要解析的數(shù)據(jù)(此時(shí)為寫死的假數(shù)據(jù),實(shí)際使用的應(yīng)該是通過API獲取的數(shù)據(jù)或者其他途徑獲取的數(shù)據(jù),此數(shù)據(jù)的結(jié)構(gòu)為真實(shí)項(xiàng)目的數(shù)據(jù)結(jié)構(gòu),所以,解析方式也會(huì)以該項(xiàng)目的后續(xù)解析方式進(jìn)行解析,基本能滿足一般的項(xiàng)目的數(shù)據(jù)解析需求)

var jsonData: [String: Any] = [:]
jsonData["code"] = 200
jsonData["result"] = true
jsonData["message"] = "數(shù)據(jù)加載成功"
jsonData["data"] = [["id"           : "資訊1_id",
                     "title"        : "資訊1_標(biāo)題",
                     "pictrueUrl"   : "資訊1_圖片",
                     "description"  : "資訊1_描述",
                     "categoryTitle": "資訊1_分類標(biāo)題",
                     "tagArray"     : [["id":"yyy0bb1d82beb084718bbd88d45c39710d8","title":".net1"],
                                       ["id":"eee0bb1d82beb084718bbd88d45c39710d8","title":".net1"]],
                     "shareNumber"  : 1,
                     "clickNumber"  : 1],
                            
                     ["id"           : "資訊2_id",
                      "title"        : "資訊2_標(biāo)題",
                      "pictrueUrl"   : "資訊2_圖片",
                      "description"  : "資訊2_描述",
                      "categoryTitle": "資訊2_分類標(biāo)題",
                      "tagArray"     : [["id":"yyy0bb1d82beb084718bbd88d45c39710d8","title":".net2"],
                                        ["id":"eee0bb1d82beb084718bbd88d45c39710d8","title":".net2"]],
                      "shareNumber"  : 2,
                      "clickNumber"  : 2]]

4.創(chuàng)建JSON對(duì)象

let jsonObj = JSON.init(jsonData)

5.先判斷code與result


if jsonObj["result"].boolValue == false {
    print("獲取失敗")
    return
}
if jsonObj["code"].intValue != 200 {
/// 此處應(yīng)該是根據(jù)服務(wù)器返回的code值進(jìn)行判斷然后進(jìn)行后續(xù)操作,現(xiàn)在只是簡單的打印服務(wù)器返回的message
    print(jsonObj["message"].stringValue)
    return
}

6.解析數(shù)據(jù)主體,暫時(shí)將解析的數(shù)據(jù)均打印出來,實(shí)際使用中會(huì)對(duì)數(shù)據(jù)進(jìn)行其他操作

for dic in jsonObj["data"].arrayValue {
    print("id: ", dic["id"].stringValue)
    print("title: ", dic["title"].stringValue)
    print("pictrueUrl: ", dic["pictrueUrl"].stringValue)
    print("description: ", dic["description"].stringValue)
    print("categoryTitle: ", dic["categoryTitle"].stringValue)
    print("shareNumber: ", dic["shareNumber"].intValue)
    print("clickNumber: ", dic["clickNumber"].intValue)
            
    print("tagArray: ", dic["tagArray1"].arrayValue)
    for arr in dic["tagArray"].arrayValue {
        print("\t\ttagid: ", arr["id2"].stringValue)
        print("\t\ttitle: ", arr["title"].stringValue)
    }
}

7.打印的結(jié)果


打印結(jié)果

8.總結(jié)
SwiftyJSON的使用很簡單
首先根據(jù)要解析的數(shù)據(jù)進(jìn)行創(chuàng)建對(duì)象,然后解析數(shù)據(jù)

創(chuàng)建JSON對(duì)象的方式有很多,如下

/**
    方法一: 使用data數(shù)據(jù)創(chuàng)建一個(gè)JSON對(duì)象

     - parameter data:  用來解析的數(shù)據(jù),data類型
     - parameter opt:   JSON解析的選項(xiàng). 默認(rèn)`.AllowFragments`.
     - parameter error: 用來返回錯(cuò)誤的NSErrorPointer. 默認(rèn)為`nil`.
     - returns: 創(chuàng)建的JSON對(duì)象
     */
    public init(data:Data, options opt: JSONSerialization.ReadingOptions = .allowFragments, error: NSErrorPointer = nil)

    /**
     方法二:使用json字符串創(chuàng)建一個(gè)JSON對(duì)象

     - parameter string: 一個(gè)正常的json字符串,例如 '{"a":"b"}'
     - returns: 創(chuàng)建的JSON對(duì)象
     */
    public static func parse(_ string:String) -> JSON

    /**
     方法三:使用一個(gè)對(duì)象創(chuàng)建一個(gè)JSON對(duì)象

     - parameter object:  這個(gè)對(duì)象必須有以下特性: 所有的對(duì)象是 NSString/String, NSNumber/Int/Float/Double/Bool, NSArray/Array, NSDictionary/Dictionary, 或 NSNull; 所有的字典的鍵是 NSStrings/String; NSNumbers 不允許是 NaN 或者 infinity.
     - returns: 創(chuàng)建的JSON對(duì)象
     */
    public init(_ object: Any)

    /**
     方法四:用一個(gè)JSON對(duì)象的數(shù)組創(chuàng)建一個(gè)JSON對(duì)象

     - parameter jsonArray: 一個(gè)Swift數(shù)組,數(shù)組的元素為JSON對(duì)象

     - returns: 創(chuàng)建的JSON對(duì)象
     */
    public init(_ jsonArray:[JSON])

    /**
     方法五:用一個(gè)值為JSON對(duì)象的字典創(chuàng)建一個(gè)JSON對(duì)象

     - parameter jsonDictionary: 一個(gè)Swif字典,字典的值是JSON對(duì)象

     - returns: 創(chuàng)建的JSON對(duì)象
     */
    public init(_ jsonDictionary:[String: JSON])

解析的數(shù)據(jù)類型包括(除了URL與null,其余的每種數(shù)據(jù)類型都包括有可選值和默認(rèn)值,如果需要自定義默認(rèn)值,可以使用解析結(jié)果為可選的類型,如果不需要,可以直接使用默認(rèn)值,所有帶有默認(rèn)值的類型,都是在以Value為后綴。例如,string獲取的就是可選的字符串,而stringValue獲取的就是帶有默認(rèn)值的字符串,非可選):

public var double: Double?
public var doubleValue: Double
public var float: Float?
public var floatValue: Float
public var int: Int?
public var intValue: Int
public var uInt: UInt?
public var uIntValue: UInt
public var int8: Int8?
public var int8Value: Int8
public var uInt8: UInt8?
public var uInt8Value: UInt8
public var int16: Int16?
public var int16Value: Int16
public var uInt16: UInt16?
public var uInt16Value: UInt16
public var int32: Int32?
public var int32Value: Int32
public var uInt32: UInt32?
public var uInt32Value: UInt32
public var int64: Int64?
public var int64Value: Int64
public var uInt64: UInt64?
public var uInt64Value: UInt64

public var URL: URL?

public var null: NSNull?

public var numberValue: NSNumber
public var number: NSNumber?

public var stringValue: String
public var string: String?

public var boolValue: Bool
public var bool: Bool?

public var dictionaryObject: [String : Any]?
public var dictionaryValue: [String : JSON]
public var dictionary: [String : JSON]?

public var arrayObject: [Any]?
public var arrayValue: [JSON]
public var array: [JSON]?

結(jié)束:
在文章的結(jié)束,放上一段我練習(xí)用的代碼,基本就是把上面的步驟結(jié)合在一起


import UIKit
import SwiftyJSON

class SwiftyJSONViewController: UIViewController {

    override func viewDidLoad() {
        super.viewDidLoad()
        view.backgroundColor = UIColor.white
        title = "SwiftyJSON"
    }
    
    private var jsonData: [String: Any] = [:]
    
    @IBAction func prepareJsonData(_ sender: UIButton) {
        
        jsonData["code"] = 200
        jsonData["result"] = true
        jsonData["message"] = "數(shù)據(jù)加載成功"
        jsonData["data"] = [["id"           : "資訊1_id",
                             "title"        : "資訊1_標(biāo)題",
                             "pictrueUrl"   : "資訊1_圖片",
                             "description"  : "資訊1_描述",
                             "categoryTitle": "資訊1_分類標(biāo)題",
                             "tagArray"     : [["id":"yyy0bb1d82beb084718bbd88d45c39710d8","title":".net1"],
                                               ["id":"eee0bb1d82beb084718bbd88d45c39710d8","title":".net1"]],
                             "shareNumber"  : 1,
                             "clickNumber"  : 1],
                            
                            ["id"           : "資訊2_id",
                             "title"        : "資訊2_標(biāo)題",
                             "pictrueUrl"   : "資訊2_圖片",
                             "description"  : "資訊2_描述",
                             "categoryTitle": "資訊2_分類標(biāo)題",
                             "tagArray"     : [["id":"yyy0bb1d82beb084718bbd88d45c39710d8","title":".net2"],
                                               ["id":"eee0bb1d82beb084718bbd88d45c39710d8","title":".net2"]],
                             "shareNumber"  : 2,
                             "clickNumber"  : 2]]
    }
    
    
    @IBAction func analysisJsonData(_ sender: UIButton) {
        
        let jsonObj = JSON.init(jsonData)
        
        if jsonObj["result"].boolValue == false {
            print("獲取失敗")
            return
        }
        if jsonObj["code"].intValue != 200 {
            print(jsonObj["message"].stringValue)
            return
        }
        
        print(jsonObj["message"].stringValue)
        
        for dic in jsonObj["data"].arrayValue {
            print("id: ", dic["id"].stringValue)
            print("title: ", dic["title"].stringValue)
            print("pictrueUrl: ", dic["pictrueUrl"].stringValue)
            print("description: ", dic["description"].stringValue)
            print("categoryTitle: ", dic["categoryTitle"].stringValue)
            print("shareNumber: ", dic["shareNumber"].intValue)
            print("clickNumber: ", dic["clickNumber"].intValue)
            
            print("tagArray: ", dic["tagArray1"].arrayValue)
            for arr in dic["tagArray"].arrayValue {
                print("\t\ttagid: ", arr["id2"].stringValue)
                print("\t\ttitle: ", arr["title"].stringValue)
            }
        }
    }
}

各位,別人為我們?cè)炝溯喿?,我們可以直接拿來用,但是,我們不?yīng)該只是會(huì)拿來用,在自己不忙的時(shí)候,研究一下別人寫的好代碼,嘗試著寫一點(diǎn)自己的輪子,我相信,那會(huì)比學(xué)會(huì)使用輪子更讓人興奮?。?!

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,555評(píng)論 19 139
  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 15,316評(píng)論 4 61
  • 本文詳細(xì)講解了 Gitbook 生成電子書的完整過程,內(nèi)容包括:安裝、命令、配置、文檔結(jié)構(gòu)、生成電子書、部署。限于...
    靜默虛空閱讀 11,474評(píng)論 9 138
  • 基礎(chǔ)太差,從頭再來!從http到socket。 http請(qǐng)求解析 請(qǐng)求報(bào)文分為三部分:請(qǐng)求行、請(qǐng)求頭、請(qǐng)求體 如圖...
    咸魚而已閱讀 596評(píng)論 0 0
  • 先有意義,再有條理!【51】 “反思”如何將想法轉(zhuǎn)化為行動(dòng),以及反思的3個(gè)問句。想法和雜事,是不可以被管理的,我們...
    朱進(jìn)偉西農(nóng)閱讀 973評(píng)論 0 2

友情鏈接更多精彩內(nèi)容