XML的解析 DOM解析

参考上一篇的XML数据,上次我们使用的SAX解析。
http://blog.csdn.net/lee727n/article/details/73271916
这次我们通过DOM解析。
这里写图片描述
软件结构与上一篇一样,需要引入TBXML第三方类。用来做DOM解析
核心代码BookXMLParser.m中的逻辑

+(NSArray *)parseBookWithFileName:(NSString *)name{

    NSMutableArray *books = [NSMutableArray array];

    TBXML *tbXML = [[TBXML alloc]initWithXMLFile:name fileExtension:@"xml" error:nil];

    TBXMLElement *booksEle = tbXML.rootXMLElement;

    TBXMLElement *bookEle = [TBXML childElementNamed:@"book" parentElement:booksEle];

    while (bookEle) {

        Book *book = [Book new];
        book.bookID = [TBXML valueOfAttributeNamed:@"bookID" forElement:bookEle];

        TBXMLElement *titleEle = [TBXML childElementNamed:@"title" parentElement:bookEle];
        TBXMLElement *pageEle = [TBXML childElementNamed:@"page" parentElement:bookEle];
        TBXMLElement *authorEle = [TBXML childElementNamed:@"author" parentElement:bookEle];
        TBXMLElement *priceEle = [TBXML childElementNamed:@"price" parentElement:bookEle];

        book.price = [TBXML textForElement:priceEle];
        book.title = [TBXML textForElement:titleEle];
        book.page = [TBXML textForElement:pageEle];
        book.author = [TBXML textForElement:authorEle];

        [books addObject:book];

        //查找下一个兄弟标签
        bookEle = [TBXML nextSiblingNamed:@"book" searchFromElement:bookEle];
    }
    return books;
}

相对于上一种方式是不是显得更高效,代码更简洁。这就是DOM解析,将所有数据拿到内存中组成树形结构再解析。效率高。只是消耗内存

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值