解析JSON Swift TableView

时间:2015-10-24 15:38:52

标签: ios json swift parsing tableview

我想提取“事件”,“Hasta”和&来自此JSON URL(https://www.kimonolabs.com/api/7flcy3qm?apikey=gNq3hB1j0NtBdAvXJLEFx8JaqtDG8y6Y)的“位置”,但我正在努力解决这个问题?谁能帮我?这是我的代码......我想用这3个填充tableview。

override func viewDidLoad() {
    super.viewDidLoad()

    splitViewController!.preferredDisplayMode = UISplitViewControllerDisplayMode.AllVisible

    UINavigationBar.appearance().barTintColor = UIColor(red: 52.0/255.0, green: 170.0/255.0, blue: 220.0/255.0, alpha: 1.0)
    UINavigationBar.appearance().tintColor = UIColor.whiteColor()
    UINavigationBar.appearance().titleTextAttributes = [NSForegroundColorAttributeName : UIColor.whiteColor()]

    let url = NSURL(string:"https://www.kimonolabs.com/api/7flcy3qm?apikey=gNq3hB1j0NtBdAvXJLEFx8JaqtDG8y6Y")!
    let session = NSURLSession.sharedSession()

    let task = session.dataTaskWithURL(url) { (data, response, error) -> Void in
        if error != nil {
            print(error)
        } else {
            if let data = data {
                do {
                    let jsonResult = try NSJSONSerialization.JSONObjectWithData(data, options: NSJSONReadingOptions.MutableContainers) as? NSDictionary
                    if jsonResult!.count > 0 {
                        if let results = jsonResult!["results"] as? NSDictionary, collection2 = results["collection2"] as? NSArray {
                            for entry in collection2 {
                                if let dict = entry["Event"] as? NSDictionary {
                                    print(dict)
                                }

                                else if let array = entry as? NSArray {

                                } else {

                                }
                            }

                            if let items = jsonResult?["Date"] as? NSArray {
                                print(items)

                            }
                        }
                    }
                } catch {
                    print("In catch block")
                }
            }
        }
    }
    task.resume()
}

2 个答案:

答案 0 :(得分:1)

用Swift解析JSON是地狱。您可以使用SwiftyJSON轻松完成此操作。

使用您的JSON:

// Get content of json url
let jsonString = try NSString.init(contentsOfURL: url!, encoding: NSUTF8StringEncoding)

// Create JSON object from data
let json = JSON(data: jsonString.dataUsingEncoding(NSUTF8StringEncoding, allowLossyConversion: false)!)

// Check if array for key "collection2" exists
if let collection2 = json["results"]["collection2"].array {
    // Create JSON array from it and loop for each object
    for (key, subJson):(String, JSON) in JSON(collection2) {
        // Check if dictionary for key "Event" exists
        if let event = subJson["Event"].dictionary {
             print(event)
        }

        // Check if string for key "Hasta" exists
        if let hasta = subJson["Hasta"].string {
             print(hasta)
        }

        // Check if string for key "Location" exists
        if let location = subJson["Location"].string {
             print(location)
        }
    }
}

答案 1 :(得分:0)

我创建了这个在线实用程序(http://www.json4swift.com),它将您的json转换为可以像这样轻松操作的快速可表示模型:

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

    var cell = tableView.dequeueReusableCellWithIdentifier("YourCellIdentifier")

    if cell == nil {
        cell = UITableViewCell()
    }

    //Assuming you have responseModel instantiated earlier
    let collection2 = responseModel?.results!.collection2!

    //Get the n'th object from collection 2
    let object = collection2[indexPath.row]

    //Populate the cell the event and hesta
    cell.textLabel?.text =  object?.event?.text
    cell.detailTextLabel?.text = object?.hasta

    return cell
}

如果是tableview,你将实现委托方法cellForRowAtIndexPath

def fib(n):
    a, b = 0, 1
    for _ in xrange(n):
        yield a
        a, b = b, a + b

print list(fib(8)) #prints: [0, 1, 1, 2, 3, 5, 8, 13]

免责声明:将上述内容视为更多的伪代码,并未经过实际测试,但会为您提供有关处理的想法。