使用NSXMLParser解析xml文件

前端之家收集整理的这篇文章主要介绍了使用NSXMLParser解析xml文件前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
1. 设置委托对象,开始解析 @H_502_0@ NSXMLParser *parser = [[NSXMLParser alloc] initWithData:data]; //或者也可以使用initWithContentsOfURL直接下载文件,但是有一个原因不这么做:
@H_502_0@ // It's also possible to have NSXMLParser download the data,by passing it a URL,but this is not desirable
@H_502_0@ // because it gives less control over the network,particularly in responding to connection errors.
@H_502_0@ [parser setDelegate:self];
@H_502_0@ [parser parse];
@H_502_0@
@H_502_0@ 2. 常用的委托方法
@H_502_0@ - (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName @H_502_0@ namespaceURI:(NSString *)namespaceURI @H_502_0@ qualifiedName:(NSString *)qName @H_502_0@ attributes:(NSDictionary *)attributeDict; @H_502_0@ - (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName @H_502_0@ namespaceURI:(NSString *)namespaceURI @H_502_0@ qualifiedName:(NSString *)qName; @H_502_0@ - (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string; @H_502_0@ - (void)parser:(NSXMLParser *)parser parseErrorOccurred:(NSError *)parseError; @H_502_0@ @H_502_0@ static NSString *FeedURLString = @"http://www.yifeiyang.net/test/test.xml"; @H_502_0@ @H_502_0@ 3. 应用举例 @H_502_0@ - (void)parseXMLFileAtURL:(NSURL *)URL parseError:(NSError **)error @H_502_0@ { @H_502_0@ NSXMLParser *parser = [[NSXMLParser alloc] initWithContentsOfURL:URL]; @H_502_0@ [parser setDelegate:self]; @H_502_0@ [parser setShouldProcessNamespaces:NO]; @H_502_0@ [parser setShouldReportNamespacePrefixes:NO]; @H_502_0@ [parser setShouldResolveExternalEntities:NO]; @H_502_0@ [parser parse]; @H_502_0@ NSError *parseError = [parser parserError]; @H_502_0@ if (parseError && error) { @H_502_0@ *error = parseError; @H_502_0@ } @H_502_0@ [parser release]; @H_502_0@ } @H_502_0@ @H_502_0@ - (void)parser:(NSXMLParser *)parser didStartElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI @H_502_0@ qualifiedName:(NSString*)qName attributes:(NSDictionary *)attributeDict{ @H_502_0@ // 元素开始句柄 @H_502_0@ if (qName) { @H_502_0@ elementName = qName; @H_502_0@ } @H_502_0@ if ([elementName isEqualToString:@"user"]) { @H_502_0@ // 输出属性值 @H_502_0@ NSLog(@"Name is %@,Age is %@",[attributeDict objectForKey:@"name"],[attributeDict objectForKey:@"age"]); @H_502_0@ } @H_502_0@ } @H_502_0@ @H_502_0@ - (void)parser:(NSXMLParser *)parser didEndElement:(NSString *)elementName namespaceURI:(NSString *)namespaceURI @H_502_0@ qualifiedName:(NSString *)qName @H_502_0@ { @H_502_0@ // 元素终了句柄 @H_502_0@ if (qName) { @H_502_0@ elementName = qName; @H_502_0@ } @H_502_0@ } @H_502_0@ @H_502_0@ - (void)parser:(NSXMLParser *)parser foundCharacters:(NSString *)string @H_502_0@ { @H_502_0@ // 取得元素的text @H_502_0@ } @H_502_0@ @H_502_0@ NSError *parseError = nil; @H_502_0@ [self parseXMLFileAtURL:[NSURL URLWithString:FeedURLString] parseError:&parseError]; @H_502_0@ @H_502_0@ @H_502_0@ 使用NSOperation和NSOperationQueue启动多线程 @H_502_0@ @H_502_0@ @H_502_0@ 在app store中的很多应用程序非常的笨重,他们有好的界面,但操作性很差,比如说当程序从网上或本地载入数据的时候,界面被冻结了,用户只能等程序完全载入数据之后才能进行操作。 @H_502_0@ 当打开一个应用程序时,iphone会产生一个包含main方法的线程,所用程序中的界面都是运行在这个线程之中的(table views,tab bars,alerts…),有时候我们会用数据填充这些view,现在问 题是如何有效的载入数据,并且用户还能自如的操作程序。方法是启动新的线程,专门用于数据的下载,而主线程不会因为下载数据被阻塞。 @H_502_0@ 不管使用任何编程语言,在实现多线程时都是一件很麻烦的事情。更糟糕的是,一旦出错,这种错误通常相当糟糕。然而,幸运的是apple从os x10.5在这方面做了很多的改进,NSThread的引入,使得开发多线程应用程序容易多了。除此之外,它们还引入了两个全新的类,NSOperation和NSOperationQueue。 @H_502_0@ 接下来我们通过一个实例来剖析如何使用这两个类实现多线程。这里指示展示这两个类的基本用法,当然这不是使用他们的唯一办法。 @H_502_0@ 如果你熟悉java或者它的别的变种语言的话 ,你会发现NSOperation对象很像java.lang.Runnable接口,就像java.lang.Runnable接口那样,NSOperation类也被设计为可扩展的,而且只有一个需要重写的方法。它就是-(void)main。使用NSOperation的最简单的方式就是把一个NSOperation对象加入到NSOperationQueue队列中,一旦这个对象被加入到队列,队列就开始处理这个对象,直到这个对象的所有操作完成。然后它被队列释放。 @H_502_0@ 下面的例子中,使用一个获取网页,并对其解析程NSXMLDocument,最后将解析得到的NSXMLDocument返回给主线程。 @H_502_0@ @H_502_0@ PageLoadOperation.h@interface PageLoadOperation : NSOperation { @H_502_0@ NSURL *targetURL;} @H_502_0@ @property(retain) NSURL *targetURL; @H_502_0@ - (id)initWithURL:(NSURL*)url;@end @H_502_0@ @H_502_0@ PageLoadOperation.m @H_502_0@ #import "PageLoadOperation.h"#import "AppDelegate.h"@implementation PageLoadOperation@synthesize targetURL;- (id)initWithURL:(NSURL*)url;{ @H_502_0@ if (![super init]) return nil; @H_502_0@ [self setTargetURL:url]; @H_502_0@ return self;}- (void)dealloc { @H_502_0@ [targetURL release],targetURL = nil; @H_502_0@ [super dealloc]; @H_502_0@ } @H_502_0@ - (void)main @H_502_0@ { @H_502_0@ NSString *webpageString = [[[NSString alloc] @H_502_0@ initWithContentsOfURL:[self targetURL]] autorelease]; @H_502_0@ NSError *error = nil; @H_502_0@ NSXMLDocument *document = [[NSXMLDocument alloc] @H_502_0@ initWithXMLString:webpageString @H_502_0@ options:NSXMLDocumentTidyHTML error:&error]; @H_502_0@ if (!document) { @H_502_0@ NSLog(@"%s Error loading document (%@): %@", @H_502_0@ _cmd,[[self targetURL] absoluteString],error); @H_502_0@ return; @H_502_0@ } @H_502_0@ [[AppDelegate shared] @H_502_0@ performSelectorOnMainThread:@selector(pageLoaded:) @H_502_0@ withObject:document waitUntilDone:YES]; @H_502_0@ [document release]; @H_502_0@ } @H_502_0@ @end @H_502_0@ 正如我们所看到的那样,这个类相当的简单,在它的init方法中接受一个url并保存起来,当main函数调用的时候,它使用这个保存的url创建一个字符串,并将这个字符串传递给NSXMLDocumentinit方法。如果加载的xml数据没有出错,数据会被传递给AppDelegate,它处于主线程中。到此,这个线程的任务就完成了。在主线程中注销操作队列的时候,会将这个NSOperation对象释放。 @H_502_0@ AppDelegate.h @H_502_0@ @interface AppDelegate : NSObject { @H_502_0@ NSOperationQueue *queue; @H_502_0@ }+ (id)shared;- (void)pageLoaded:(NSXMLDocument*)document;@endAppDelegate.m #import "AppDelegate.h"#import "PageLoadOperation.h"@implementation AppDelegate @H_502_0@ static AppDelegate *shared; @H_502_0@ static NSArray *urlArray; @H_502_0@ - (id)init @H_502_0@ { @H_502_0@ if (shared) @H_502_0@ { @H_502_0@ [self autorelease]; @H_502_0@ return shared; @H_502_0@ } @H_502_0@ if (![super init]) return nil; NSMutableArray *array = [[NSMutableArray alloc] init];[array addObject:@"http://www.google.com"];[array addObject:@"http://www.apple.com"];[array addObject:@"http://www.yahoo.com"];[array addObject:@"http://www.zarrastudios.com"];[array addObject:@"http://www.macosxhints.com"];urlArray = array; queue = [[NSOperationQueue alloc] init];shared = self;return self; @H_502_0@ } @H_502_0@ • (void)applicationDidFinishLaunching: @H_502_0@ (NSNotification *)aNotification @H_502_0@ { @H_502_0@ for (NSString *urlString in urlArray) @H_502_0@ { @H_502_0@ NSURL *url = @H_502_0@ [NSURL URLWithString:urlString]; PageLoadOperation *plo = @H_502_0@ [[PageLoadOperation alloc] initWithURL:url]; @H_502_0@ [queue addOperation:plo]; @H_502_0@ [plo release]; @H_502_0@ } @H_502_0@ } @H_502_0@ - (void)dealloc @H_502_0@ { @H_502_0@ [queue release],queue = nil; @H_502_0@ [super dealloc]; @H_502_0@ } @H_502_0@ + (id)shared; @H_502_0@ { @H_502_0@ if (!shared) { @H_502_0@ [[AppDelegate alloc] init]; @H_502_0@ } @H_502_0@ return shared; @H_502_0@ } @H_502_0@ - (void)pageLoaded:(NSXMLDocument*)document; @H_502_0@ { @H_502_0@ NSLog(@"%s Do something with the XMLDocument: %@", @H_502_0@ _cmd,document); @H_502_0@ } @H_502_0@ @end @H_502_0@ @H_502_0@ NSOperationQueue的并行控制(NSOperationQueue Concurrency) @H_502_0@ 在上面这个简单的例子中,我们很难看出这些操作是并行运行的,然而,如果你你的操作花费的时间远远比这里的要长,你将会发现,队列是同时执行这些操作的。幸运的是,如果你想要为队列限制同时只能运行几个操作,你可以使用NSOperationQueue的setMaxConcurrentOperationCount:方法。例如,[queue setMaxConcurrentOperationCount:2]; 原文链接:https://www.f2er.com/xml/299770.html

猜你在找的XML相关文章