首页 > 编程知识 正文

iappjson解析源码(iapp解析接口反馈的json)

时间:2023-12-02 21:07:33 阅读:311551 作者:FJFI

本文目录一览:

  • 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返回值时还是挺方便的。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。