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

时间: 2024-09-30 10:23:12

XML 文件解析的相关文章

android基础知识13:AndroidManifest.xml文件解析

1.重要性 AndroidManifest.xml是Android应用程序中最重要的文件之一.它是Android程序的全局配置文件,是每个 android程序中必须的文件.它位于我们开发的应用程序的根目录下,描述了package中的全局数据,包括package中暴露的组件 (activities, services, 等等),以及他们各自的实现类,各种能被处理的数据和启动位置等重要信息. 因此,该文件提供了Android系统所需要的关于该应用程序的必要信息,即在该应用程序的任何代码运行之前系统所

XML文件解析之JDOM解析

1.JDOM介绍 JDOM的官方网站是http://www.jdom.org/,JDOM解析用到的jar包可以在http://www.jdom.org/dist/binary/中下载,最新的JDOM2的版本是2.0.5,JDOM1的版本是1.1.3,根据官网中的介绍可以知道.JDOM是一个在基于内存的XML模型,它用于读写创建修改XML文档.JDOM和DOM相似因为他们都提供了内存XML文档模型,但是DOM被设计用于很多种语言(C,C++,ECMSctipr,Java,JScript,Lingo

java基础之概谈xml文件解析

XML已经成为一种很通用的数据交换格式,它的平台无关性,语言无关性,系统无关性,给数据集成与交互带来了极大的方便.诸多web应用框架,其可配置的编程方式,给我们的开发带来了很大程度的便捷,但细细想来,它们的应用无一不是java bean与xml之间的转换解析.本文将对xml的两种操作标准DOM和SAX,从它们各自的特点.适用范围等方面进行简单介绍. DOM (Document Object Model) :DOM标准中,采用W3C标准表示XML,有多重语言支持,因此其跨平台性很好.采用DOM规范

XML文件解析【安卓7】——SAX解析

XML文件解析 XML解析:XML技术是Android平台的应用基础,  Android提供了多种解析XML的方式:SAX解析.DOM解析.PULL解析 SAX解析 SAX --Simple  API  forXML  (XML简单的API) --解析速度快.占用内存少 --提供一组简单的API用于解析XML文件 --SAX在解析XML文件前,先指定一个解析事件处理器(Handler),SAX会对XML文档进行简单的顺序扫描,当扫描到[文档(Document)的开始和结束.元素(Element)

XML文件解析器TXml

前几天看了开源的XML文件解析器TinyXml,它是怎么实现解析的没怎么看懂,于是决定自己实现一个,反正最近不忙.先命名为TXml.现在完成了解析和查询功能,全部代码加起来不到1000行,将会继续完善它.源码必共享 先简单说一下我的思路: 1:读取XML文件信息,并存入一个字符数组中: 2:遍历数组,将数组解析成一棵树: 3:以路径的方式查询和按属性查询: 这个解析器最麻烦的地方就在怎么将字符数组解析成一颗树.我们先看一下一个简单XML文件,他包括文件头.节点.节点名称及节点值.属性名称及属性值

八、Android学习第七天——XML文件解析方法(转)

(转自:http://wenku.baidu.com/view/af39b3164431b90d6c85c72f.html) 八.Android学习第七天——XML文件解析方法 XML文件:extensible markup language 定义:用于标记电子文件使其具有结构性的标记语言,可以用来标记数据.定义数据类型,是一种允许用户对自己的标记语言进行定义的源语言. 解析XML的方式: SAX——Simple API for XML,既是一种接口,也是一个软件包采用的是事件驱动,也就是它解析

Win10系列:VC++ XML文件解析

XML文件按照元素标记来存储数据,通过遍历这些元素标记可以得到XML文件中所保存的数据.在C++/CX的类库中并未定义用于解析XML文件的类,但C++提供了能解析XML文件的框架和类库,如msxml4.libxml.IXMLDOM和TinyXML等,在使用C++/CX编写应用程序时可以通过C++提供的框架和类库来解析XML文件.TinyXML是一个轻量级解析XML的框架,本节将介绍如何使用此框架来解析一个XML文件. TinyXML框架包含了以下的类和函数,通过使用这些类和函数可以方便地读取一个

通过正则表达式实现简单xml文件解析

这是我通过正则表达式实现的xml文件解析工具,有些XHTML文件中包含特殊符号,暂时还无法正常使用. 设计思路:常见的xml文件都是单根树结构,工具的目的是通过递归的方式将整个文档树装载进一个Node对象.xml文档树上的每一个节点都是一个Node对象,对象拥有title.attribute和text三个自身变量以及一个childrenNode集合. 一.编写Node类 import java.io.Serializable; import java.util.HashMap; import j

JAVA之XML文件解析

在Java.Android开发中,xml文件的解析很重要.本人使用过的xml文件解析的方式有两种,一种是DOM文档解析.还有一种是SAX. DOM是基于文档树结构的.SAX是基于事件驱动的.SAX则是遇到标签则触发工作的.当解析器发现元素开始.元素结束.文本.文档的开始或结束等时,发送事件,程序员编写响应这些事件的代码,保存数据.优缺点很明显:DOM对于大型文件的操作不好(因为它要先读入整个文档到内存中),SAX为了解决这样问题.不用事先调入整个文档,占用资源少:SAX解析器代码比DOM解析器代

dtd与schema的区别&amp;XML文件解析常用方式

Schema和DTD 都是用来定义各种文件中XML标记的使用规范.Schema是标准的XML文件,而DTD则使用自己的特殊语法,因此,只需要知道XML的语法规则就可以编写Schema了,不需要再学习其它语法规则.可以使用相同的处理器来解读,Schema利用命名空间将文件中特殊的节点与Schema说明相联系,一个XML文件可以有多个对应的Schema,若是DTD的话,一个XML文件只能有一个相对应的DTD文件.Schema的内容模型是开放的,可以随意扩充,而DTD则无法解读扩充的内容.DTD只能把