XML 文件解析
1.XML文件
<Data>
<Movie id="1">
<title>good lucky to you</title>
<box>111</box>
<summary>This is a story</summary>
</Movie>
<Movie id="2">
<title>hello</title>
<box>99</box>
<summary>oh,yes</summary>
</Movie>
<Movie id="3">
<title>Cold</title>
<box>100</box>
<summary>I love cold weather</summary>
</Movie>
</Data>
2,解析
#import "ViewController.h"
//创建模型类
@interface DataModel : NSObject
//Data
@property(nonatomic,copy)NSNumber *id;
@property (nonatomic,copy)NSString*title;
@property (nonatomic,copy)NSString*box;
@property (nonatomic,copy)NSString*summary;
-(instancetype)initWithDict:(NSDictionary*)dict;
+(instancetype)dataWithdict:(NSDictionary*)dict;
@end
@implementation DataModel
-(instancetype)initWithDict:(NSDictionary*)dict
{
if (self=[super init]) {
[self setValuesForKeysWithDictionary:dict];
}
return self;
}
+(instancetype)dataWithdict:(NSDictionary*)dict
{
return [[self alloc]initWithDict:dict];
}
@end
@interface ViewController ()<NSXMLParserDelegate>
@property(nonatomic,strong)NSMutableArray*models;
//主要用于XML标签体中的文本的读取,很多时候标签体内的内容不是一次读取出来的,需要拼接字符串
@property(nonatomic,copy)NSMutableString*str;
@property(nonatomic,strong)DataModel*datamodel;
@end
@implementation ViewController
- (void)viewDidLoad {
[super viewDidLoad];
[self loadDataWithUrl:@"http://127.0.0.1/struts.xml"];
}
//XML解析方法
-(void)loadDataWithUrl:(NSString*)str
{
NSURL *url=[NSURL URLWithString:str];
NSURLRequest *quest=[NSURLRequest requestWithURL:url cachePolicy:1 timeoutInterval:15];
[NSURLConnection sendAsynchronousRequest:quest queue:[NSOperationQueue mainQueue] completionHandler:^(NSURLResponse *response, NSData *data, NSError *connectionError) {
if (!connectionError)
{
NSHTTPURLResponse *resnse=(NSHTTPURLResponse*)response;
if (resnse.statusCode==200) {
NSXMLParser *parser=[[NSXMLParser alloc]initWithData:data];
parser.delegate=self;
//开始解析
[parser parse];
}
}
else
{
NSLog(@"请求出错:%@",connectionError);
}
}];
}
#pragma mark NSXMLParserDelegate XML文档解析五部曲
//开始解析
-(void)parserDidStartDocument:(NSXMLParser *)parser
{
NSLog(@"开始解析!!清除之前的数据");
[self.models removeAllObjects];
}
//开始查找标签元素
-(void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName attributes:(NSDictionary *)attributeDict
{
//elementName 记录标签的名称 attributeDict:记录标签的属
NSLog(@"开始查找标签元素:%@",elementName);
//NSLog(@"elementName:%@,namespaceURI:%@,qName:%@",elementName,namespaceURI,qName);
//排除根节点
self.str=nil;
if ([elementName isEqualToString:@"Movie"]) {
//self.str=nil;
self.datamodel=[DataModel new];
[self.models addObject:self.datamodel];
[attributeDict enumerateKeysAndObjectsUsingBlock:^(id key, id obj, BOOL *stop) {
[self.datamodel setValue:obj forKey:key];
}];
}
}
//查找标签间的内容 可能不止执行一次
-(void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string
{
//NSLog(@"标签之间的内容!!!");
[self.str appendString:string];
}
//标签查找结束
-(void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI qualifiedName:(NSString *)qName
{
//NSLog(@"标签结束:%@ ,%@",elementName,self.str);
if (![elementName isEqualToString:@"Data"]&&![elementName isEqualToString:@"Movie"]) {
[self.datamodel setValue:self.str forKey:elementName];
}
}
//解析结束
-(void)parserDidEndDocument:(NSXMLParser *)parser
{
NSLog(@"解析结束!!");
NSLog(@"%@",self.models);
}
//解析出错
-(void)parser:(NSXMLParser *)parser parseErrorOccurred:(NSError *)parseError
{
NSLog(@"解析出错!!!!!!!!%@",parseError);
}
//懒加载
-(NSMutableString*)str
{
if (!_str) {
_str=[NSMutableString new];
}
return _str;
}
-(NSMutableArray*)models
{
if (!_models) {
_models=[NSMutableArray new];
}
return _models;
}
@end
XML 文件解析的更多相关文章
- 通过正则表达式实现简单xml文件解析
这是我通过正则表达式实现的xml文件解析工具,有些XHTML文件中包含特殊符号,暂时还无法正常使用. 设计思路:常见的xml文件都是单根树结构,工具的目的是通过递归的方式将整个文档树装载进一个Node ...
- 八、Android学习第七天——XML文件解析方法(转)
(转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html) 八.Android学习第七天——XML文件解析方法 XML文件:exten ...
- android基础知识13:AndroidManifest.xml文件解析
注:本文转载于:http://blog.csdn.net/xianming01/article/details/7526987 AndroidManifest.xml文件解析. 1.重要性 Andro ...
- Android之AndroidManifest.xml文件解析
转自:Android学习笔记之AndroidManifest.xml文件解析 一.关于AndroidManifest.xml AndroidManifest.xml 是每个android程序中必须的文 ...
- 9.XML文件解析
一.XML简介 XML(EXtensible Markup Language),可扩展标记语言 特点:XML与操作系统.编程语言的开发平台无关 实现不同系统之间的数据交换 作用:数据交互 配置应用程序 ...
- Python实现XML文件解析
1. XML简介 XML(eXtensible Markup Language)指可扩展标记语言,被设计用来传输和存储数据,已经日趋成为当前许多新生技术的核心,在不同的领域都有着不同的应用.它是web ...
- Python3将xml文件解析为Python对象
一.说明 从最开始写javascript开始,我就很烦感使用getElementById()等函数来获取节点的方法,获取了一个节点要访问其子孙节点要么child半天要么就再来一个getElementB ...
- XML文件解析-DOM4J方式和SAX方式
最近遇到的工作内容都是和xml内容解析相关的. 1图片数据以base64编码的方式保存在xml的一个标签中,xml文件通过接口的方式发送给我,然后我去解析出图片数据,对图片进行进一步处理. 2.xml ...
- java基础之概谈xml文件解析
XML已经成为一种非常通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便. 诸多web应用框架,其可配置的编程方式,给我们的开发带来了非常大程度的便捷,但细细 ...
- XML文件解析之JDOM解析
1.JDOM介绍 JDOM的官方网站是http://www.jdom.org/,JDOM解析用到的jar包可以在http://www.jdom.org/dist/binary/中下载,最新的JDOM2 ...
随机推荐
- POJ 1321
http://poj.org/problem?id=1321 一道深搜的题目,和那个POJ3740有点相类似. 也是到了现在我才知道原来深搜也有几种套路的,以前我的都是用队列来做,那个是不需要记住什么 ...
- ACM/ICPC 之 模拟 (HNUOJ 13391-换瓶模拟)
题意:汽水瓶有三个部分cap+plastic bottle+ label(瓶盖-瓶身-瓶底),给出数据:n为原瓶数,x,y,z为这三个部分可以用相应的数字换取新瓶子,求最大总瓶数. 模拟(暴力) // ...
- 15.SpringMVC和Spring上下文关系(为什么SpringMVC可以调用到Spring)
springmvc上下文继承于spring, 也就是springmvc的上下文可访问spring上下文,在springmvc的上下文中可取得spring bean. spring上下文是spring启 ...
- nyoj17_又做最大递增子序列
单调递增最长子序列 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 求一个字符串的最长递增子序列的长度 如:dabdbf最长递增子序列就是abdf,长度为4 输入 ...
- 【python】lxml处理命名空间
有如下xml <A xmlns="http://This/is/a/namespace"> <B>dataB1</B> <B>dat ...
- mysql TIMESTAMP 报错
[Err] 1293 - Incorrect table definition; there can be only one TIMESTAMP column with CURRENT_TIMESTA ...
- osg设置相机参数,包括初始位置
严重注意!!!以下设置必须在viewer.realize();之后,否则不起作用!!!! 设置相机的位置,可以通过CameraManipulator(一般是osgGA::TrackballManipu ...
- C#封装C++DLL
1.新建一个C#-Windows-类库(用于创建C#类库(.dll)的项目)类型的工程 2.对于普通C++函数 XXXX_API void cppFun(int i); 在cs代码中添加 [DllIm ...
- 《孙子算经》之"物不知数"题:中国剩余定理
1.<孙子算经>之"物不知数"题 今有物不知其数,三三数之剩二,五五数之剩七,七七数之剩二,问物几何? 2.中国剩余定理 定义: 设 a,b,m 都是整数. 如果 m ...
- DB2 SQL Mixed data in character strings
Mixed character data and graphic data are always allowed for Unicode, but for EBCDIC and ASCII, the ...