我如何使用SwiftyJSON解析特定格式的json?
问题描述:
在我的swift
应用程序中,我从webservice获取评论。传入的JSON的一般格式为:我如何使用SwiftyJSON解析特定格式的json?
comments = (
{
"_id" = 57e460a4d9f58eb150470a0a;
content = "fsagsd";
"sent_at" = "2016-09-22T22:52:20.061Z";
"username" = kamil;
},
{
"_id" = 57e460c0d9f58eb150470a0b;
content = "hfdhfd";
"sent_at" = "2016-09-22T22:52:48.682Z";
"username" = kamil;
}
);
这是一个实际的结果:print(response.result.value)
整个查询(用alamofire
)如下所示:
Alamofire.request(.GET, "\(serverURL)/get/\(case_id)/comments/"/*, headers: headers*/)
.validate()
.responseJSON { response in
switch response.result {
case .Success:
print("success")
if let jsonData = response.result.value as? [[String: AnyObject]] {
for myJSON in jsonData {
if let myTest = SingleComment.fromJSON(JSON(myJSON)){
self.items.addObject(myJSON)
self.myTable.reloadData()
}
}
}
但因为评论是嵌入在我的json中的comments
- 我从未达到self.items.addObject(myJSON)
。我想,如果传入的JSON看起来像它的工作:
{
"_id" = 57e460a4d9f58eb150470a0a;
content = "fsagsd";
"sent_at" = "2016-09-22T22:52:20.061Z";
"username" = kamil;
},
{
"_id" = 57e460c0d9f58eb150470a0b;
content = "hfdhfd";
"sent_at" = "2016-09-22T22:52:48.682Z";
"username" = kamil;
}
,因为我不能改变传入的JSON - 可以请你帮我调整我的SWIFT代码?另外
一个信息 - fromJSON
功能如下:
class func fromJSON(json: JSON) -> SingleComment? {
print("single comment from json")
let dateFormatter = NSDateFormatter()
dateFormatter.dateFormat = "yyyy-MM-dd'T'HH:mm:ss.SSSZ"
let username = json["username"].string
let content = json["content"].string
let sent_at = json["sent_at"].string
let id = json["_id"].string
let upd = dateFormatter.dateFromString(sent_at!)
return SingleComment(username: username!, content: content!, sent_at: upd!, id: id!)
}
答
尝试在.Success块这段代码。希望它能帮助你。
if let value = response.result.value {
let data = JSON(value)
if let responseDictionary = data.dictionary {
if let commentsArray = responseDictionary["comments"]?.array {
for commentObject in commentsArray {
if let myTest = SingleComment.fromJSON(commentObject){
self.items.addObject(myJSON)
}
}
self.myTable.reloadData()
}
}
}
答
您的回复似乎不是一个正确的json数据。
首先,json属性应该分开:
而不是=
。在你的例子中,"_id" = 57e460c0d9f58eb150470a0b;
应该是"_id" : 57e460c0d9f58eb150470a0b;
。
其次,响应数据似乎是jsonp格式,因为它包含变量和分号。但是json格式仍然不正确。所以我认为你的解决方案不是调整你的算法来适应这种奇怪的数据,你必须问你的服务器,为什么它提供了这样一个奇怪的数据。
谢谢你的男人,它现在的作品! – user3766930