本文目錄一覽:
- 1、iOS開發問題:已經獲得了json字符串,怎麼解析並顯示到tableview上
- 2、誰會用iapp源碼,求教。
- 3、jquery解析json怎麼解析
- 4、開源Json處理工具是如何幫我們解析Json的
iOS開發問題:已經獲得了json字符串,怎麼解析並顯示到tableview上
作為一種輕量級的數據交換格式,json正在逐步取代xml,成為網絡數據的通用格式。
有的json代碼格式比較混亂,可以使用此“”網站來進行JSON格式化校驗(點擊打開鏈接)。此網站不僅可以檢測Json代碼中的錯誤,而且可以以視圖形式顯示json中的數據內容,很是方便。
從IOS5開始,APPLE提供了對json的原生支持(NSJSONSerialization),但是為了兼容以前的ios版本,可以使用第三方庫來解析Json。
本文將介紹TouchJson、 SBJson 、JSONKit 和 iOS5所支持的原生的json方法,解析國家氣象局API,TouchJson和SBJson需要下載他們的庫
TouchJson包下載:
SBJson 包下載:
JSONKit包下載:
下面的完整程序源碼包下載:
PS:
國家氣象局提供的天氣預報接口
接口地址有三個:
第三接口信息較為詳細,提供的是6天的天氣,關於API所返回的信息請見開源免費天氣預報接口API以及全國所有地區代碼!!(國家氣象局提供),全國各城市對應這一個id號,根據改變id好我們就可以解析出來各個城市對應天氣;
下面介紹四種方法解析JSON:
首先建立一個新的工程,(注意不要選擇ARC機制)添加如下控件:
如上圖所示。下面展出程序代碼:
文件 ViewController.h 中:
[cpp] view plaincopy
#import UIKit/UIKit.h
@interface ViewController : UIViewController
@property (retain, nonatomic) IBOutlet UITextView *txtView;
– (IBAction)btnPressTouchJson:(id)sender;
– (IBAction)btnPressSBJson:(id)sender;
– (IBAction)btnPressIOS5Json:(id)sender;
– (IBAction)btnPressJsonKit:(id)sender;
@end
文件ViewController.m中主要代碼:
(1)使用TouchJSon解析方法:(需導入包:#import “TouchJson/JSON/CJSONDeserializer.h”)
[cpp] view plaincopy
//使用TouchJson來解析北京的天氣
– (IBAction)btnPressTouchJson:(id)sender {
//獲取API接口
NSURL *url = [NSURL URLWithString:@””];
//定義一個NSError對象,用於捕獲錯誤信息
NSError *error;
NSString *jsonString = [NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:error];
NSLog(@”jsonString—%@”,jsonString);
//將解析得到的內容存放字典中,編碼格式為UTF8,防止取值的時候發生亂碼
NSDictionary *rootDic = [[CJSONDeserializer deserializer] deserialize:[jsonString dataUsingEncoding:NSUTF8StringEncoding] error:error];
//因為返回的Json文件有兩層,去第二層內容放到字典中去
NSDictionary *weatherInfo = [rootDic objectForKey:@”weatherinfo”];
NSLog(@”weatherInfo—%@”,weatherInfo);
//取值打印
txtView.text = [NSString stringWithFormat:@”今天是 %@ %@ %@ 的天氣狀況是:%@ %@ “,[weatherInfo objectForKey:@”date_y”],[weatherInfo objectForKey:@”week”],[weatherInfo objectForKey:@”city”], [weatherInfo objectForKey:@”weather1″], [weatherInfo objectForKey:@”temp1″]];
}
(2)使用SBJson解析方法:(需導入包:#import “SBJson/SBJson.h”)
[cpp] view plaincopy
//使用SBJson解析南陽的天氣
– (IBAction)btnPressSBJson:(id)sender {
NSURL *url = [NSURL URLWithString:@””];
NSError *error = nil;
NSString *jsonString = [NSString stringWithContentsOfURL:url encoding:NSUTF8StringEncoding error:error];
SBJsonParser *parser = [[SBJsonParser alloc] init];
NSDictionary *rootDic = [parser objectWithString:jsonString error:error];
NSDictionary *weatherInfo = [rootDic objectForKey:@”weatherinfo”];
txtView.text = [NSString stringWithFormat:@”今天是 %@ %@ %@ 的天氣狀況是:%@ %@ “,[weatherInfo objectForKey:@”date_y”],[weatherInfo objectForKey:@”week”],[weatherInfo objectForKey:@”city”], [weatherInfo objectForKey:@”weather1″], [weatherInfo objectForKey:@”temp1″]];
}
(3)使用IOS5自帶解析類NSJSONSerialization方法解析:(無需導入包,IOS5支持,低版本IOS不支持)
[cpp] view plaincopy
– (IBAction)btnPressIOS5Json:(id)sender {
NSError *error;
//加載一個NSURL對象
NSURLRequest *request = [NSURLRequest requestWithURL:[NSURL URLWithString:@””]];
//將請求的url數據放到NSData對象中
NSData *response = [NSURLConnection sendSynchronousRequest:request returningResponse:nil error:nil];
//IOS5自帶解析類NSJSONSerialization從response中解析出數據放到字典中
NSDictionary *weatherDic = [NSJSONSerialization JSONObjectWithData:response options:NSJSONReadingMutableLeaves error:error];
NSDictionary *weatherInfo = [weatherDic objectForKey:@”weatherinfo”];
txtView.text = [NSString stringWithFormat:@”今天是 %@ %@ %@ 的天氣狀況是:%@ %@ “,[weatherInfo objectForKey:@”date_y”],[weatherInfo objectForKey:@”week”],[weatherInfo objectForKey:@”city”], [weatherInfo objectForKey:@”weather1″], [weatherInfo objectForKey:@”temp1″]];
NSLog(@”weatherInfo字典裡面的內容為–》%@”, weatherDic );
}
(4)使用JSONKit的解析方法:(需導入包:#import “JSONKit/JSONKit.h”)
[cpp] view plaincopy
– (IBAction)btnPressJsonKit:(id)sender {
//如果json是“單層”的,即value都是字符串、數字,可以使用objectFromJSONString
NSString *json1 = @”{\”a\”:123, \”b\”:\”abc\”}”;
NSLog(@”json1:%@”,json1);
NSDictionary *data1 = [json1 objectFromJSONString];
NSLog(@”json1.a:%@”,[data1 objectForKey:@”a”]);
NSLog(@”json1.b:%@”,[data1 objectForKey:@”b”]);
[json1 release];
//如果json有嵌套,即value里有array、object,如果再使用objectFromJSONString,程序可能會報錯(測試結果表明:使用由網絡或得到的php/json_encode生成的json時會報錯,但使用NSString定義的json字符串時,解析成功),最好使用objectFromJSONStringWithParseOptions:
NSString *json2 = @”{\”a\”:123, \”b\”:\”abc\”, \”c\”:[456, \”hello\”], \”d\”:{\”name\”:\”張三\”, \”age\”:\”32\”}}”;
NSLog(@”json2:%@”, json2);
NSDictionary *data2 = [json2 objectFromJSONStringWithParseOptions:JKParseOptionLooseUnicode];
NSLog(@”json2.c:%@”, [data2 objectForKey:@”c”]);
NSLog(@”json2.d:%@”, [data2 objectForKey:@”d”]);
[json2 release];
}
另外,由於iOS5新增了JSON解析的API,我們將其和其他五個開源的JSON解析庫進行了解析速度的測試,下面是測試的結果。
我們選擇的測試對象包含下面的這幾個框架,其中NSJSONSerialization是iOS5系統新增的JSON解析的API,需要iOS5的環境,如果您在更低的版本進行測試,應該屏蔽相應的代碼調用。
– [SBJSON (json-framework)]()
– [TouchJSON (from touchcode)]()
– [YAJL (objective-C bindings)]()
– [JSONKit]()
– [NextiveJson]()
-[NSJSONSerialization]()
我們選擇了四個包含json格式的數據的文件進行測試。每一個文件進行100的解析動作,對解析的時間進行比較。
…..
測試的結果顯示,系統的API的解析速度最快,我們在工程項目中選擇使用,也是應用較為廣泛的SBJSON的解析速度為倒數第二差,令我大跌眼鏡。
與系統API較為接近的應該是JSONKit。
這裡沒有對API的開放接口和使用方式進行比較,若單純基於以上解析速度的測試:
1:iOS5應該選擇系統的API進行
2:不能使用系統API的應該選擇JSONKit
解決方案來源於網絡,但是我看了,沒有問題。還是建議採用第三種蘋果自帶方法解決這個問題。
參考:
誰會用iapp源碼,求教。
你要下載eclipse和adt在配好環境,才能導入運行,app只是個程序!
jquery解析json怎麼解析
json數據是我們常用的一種小型的數據實時交換的一個東西,他可以利用jquery或js進行解析,下面我來介紹jquery解析json字符串方法。
一、jQuery解析Json數據格式:
使用這種方法,你必須在Ajax請求中設置參數:
1 dataType: “json”
獲取通過回調函數返回的數據並解析得到我們想要的值,看源碼:
複製代碼 代碼如下:
jQuery.ajax({
url: full_url,
dataType: “json”,
success: function(results) {
alert(result.name);
} });
通常情況下,你可以從後台返回JSON數據,前台就交給jQuery啦,哈哈!!
jquery異步請求將type(一般為這個配置屬性)設為“json”,或者利用$.getJSON()方法獲得服務器返回,那麼就不
需要eval()方法了,因為這時候得到的結果已經是json對象了,只需直接調用該對象即可,這裡以$.getJSON方法為
例說
例1
代碼如下:
複製代碼 代碼如下:
var data=”
{
root:
[
{name:’1′,value:’0′},
{name:’6101′,value:’北京市’},
{name:’6102′,value:’天津市’},
{name:’6103′,value:’上海市’},
{name:’6104′,value:’重慶市’},
{name:’6105′,value:’渭南市’},
{name:’6106′,value:’延安市’},
{name:’6107′,value:’漢中市’},
{name:’6108′,value:’榆林市’},
{name:’6109′,value:’安康市’},
{name:’6110′,value:’商洛市’}
]
}”;
jquery
複製代碼 代碼如下:
$.getJSON(“”,{param:”sanic”},function(data){
//此處返回的data已經是json對象
//以下其他操作同第一種情況
$.each(data.root,function(idx,item){
if(idx==0){
return true;//同countinue,返回false同break
}
alert(“name:”+item.name+”,value:”+item.value);
});
});
二、jQuery解析Json對象:
jQuery提供了另一種方法“parseJSON”,這需要一個標準的JSON字符串,並返回生成的JavaScript對象。讓我們來看
看語法:
data = $.parseJSON(string);
看看它是如何運用的到實際開發中的:
複製代碼 代碼如下:
jQuery.ajax({
url: dataURL, success: function(results) {
var parsedJson = jQuery.parseJSON(results);
alert(parsedJson.name);
}
});
開源Json處理工具是如何幫我們解析Json的
我用過的有jackson,谷歌的gson,阿里的fastjson fastjson在遍歷JSONObject的時候順序不是有序的,想要有序還得改源碼,比較麻煩,序列化對象時屬性的順序也不能保證,是我放棄使用的主要原因 gson是用起來是最痛快的,一句話就能解決 12 String string = new Gson().toJson(user);User user = new Gson().fromeJson(string, User.class); 特點是不報錯,如果輸入的json字符串和Java Bean的屬性對應不上,相應屬性會為null或默認值這是優點還是缺點就見仁見智了,至少我在轉換一些不太規則的API返回值時還是挺方便的。
原創文章,作者:小藍,如若轉載,請註明出處:https://www.506064.com/zh-hant/n/239607.html