XML解析Bookxml

#import "ViewController.h"

//导入XML解析的头文件GDataXMLNode.h
#import "GDataXMLNode.h"

@interface ViewController ()

@end

@implementation ViewController

- (void)viewDidLoad {
    [super viewDidLoad];
    
    // 获取xml文件的路径
    NSString *xmlPath = [[NSBundle mainBundle] pathForResource:@"book" ofType:@"xml"];
    
    //获取xml文件的二进制数据
    NSData *xmlData = [NSData dataWithContentsOfFile:xmlPath];
    
    //获取xml文件的字符串数据
    NSString *xmlString = [NSString stringWithContentsOfFile:xmlPath encoding:NSUTF8StringEncoding error:nil];
    
    
    //开始解析XML数据
    //创建xml解析器,通过传入xml二进制
//    GDataXMLDocument *xmlDocument = [[GDataXMLDocument alloc] initWithData:xmlData options:0 error:nil];
    
    //创建xml解析器,通过传入xml字符串
    GDataXMLDocument *xmlDocument = [[GDataXMLDocument alloc] initWithXMLString:xmlString options:0 error:nil];
    
    //获取根节点
    GDataXMLElement *rootElement = xmlDocument.rootElement;
    NSLog(@"rootElement.name: %@", rootElement.name); //节点名称
    
    //获取所有子节点
    NSArray *children = rootElement.children;
    //遍历所有子节点
    for (GDataXMLElement *childElement in children) {
        //子节点的名称
        NSLog(@"childElement.name:%@", childElement.name);
    }
    
    //获取所有book节点
    NSArray *books = [rootElement elementsForName:@"book"];
    //遍历
    for (GDataXMLElement *bookElement in books) {
        NSLog(@"bookElement.name: %@", bookElement.name);
        
        //取出book节点的子节点title
        GDataXMLElement *titleElement = [[bookElement elementsForName:@"title"] firstObject];
        
        //取出author节点
        GDataXMLElement *authorElement = [[bookElement elementsForName:@"author"] firstObject];
        
        //取出title节点的内容
        NSString *titleValue = [titleElement stringValue];
        NSLog(@"titleValue:%@", titleValue); //打印title节点的内容
        NSLog(@"author:%@", [authorElement stringValue]); //打印author节点的内容
        
        //取出title节点的属性lang
        NSString *langString = [[titleElement attributeForName:@"lang"] stringValue];
        NSLog(@"langString:%@", langString);
        
    }
    
    //通过路径获取所有的title节点
    NSArray *titles = [xmlDocument nodesForXPath:@"/bookstore/book/title" error:nil];
    //遍历
    for (GDataXMLElement *titleElement in titles) {
        NSLog(@"titleElement stringValue: %@", [titleElement stringValue]);
    }
    
    
}

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于使用Java开发的项目,我们经常使用Jackson和XML解析器来处理JSON和XML数据。 Jackson是一个流行的Java库,用于将JSON数据与Java对象之间进行转换。它提供了一组简单易用的API,可以将JSON字符串转换为Java对象,或将Java对象转换为JSON字符串。Jackson还提供了一些高级功能,例如对日期、枚举和多态类型的支持。 在使用Jackson时,你需要添加相应的依赖到你的项目。例如使用Maven构建项目,你可以在pom.xml文件添加以下依赖: ```xml <dependency> <groupId>com.fasterxml.jackson.core</groupId> <artifactId>jackson-databind</artifactId> <version>2.12.1</version> </dependency> ``` 使用Jackson解析JSON数据的基本步骤如下: 1. 创建一个`ObjectMapper`对象,它是Jackson库的核心类,用于执行JSON序列化和反序列化操作。 2. 调用`readValue()`方法将JSON字符串转换为Java对象,或调用`writeValueAsString()`方法将Java对象转换为JSON字符串。 下面是一个使用Jackson解析JSON的示例代码: ```java import com.fasterxml.jackson.databind.ObjectMapper; public class JsonParser { public static void main(String[] args) { String json = "{\"name\":\"John\",\"age\":30}"; try { ObjectMapper objectMapper = new ObjectMapper(); Person person = objectMapper.readValue(json, Person.class); System.out.println("Name: " + person.getName()); System.out.println("Age: " + person.getAge()); } catch (Exception e) { e.printStackTrace(); } } } class Person { private String name; private int age; // getters and setters } ``` 在上述示例,我们将一个JSON字符串`{"name":"John","age":30}`转换为一个名为`Person`的Java对象,然后输出对象的属性值。 对于XML解析,Java提供了多种选择,例如DOM、SAX和StAX等。其,DOM和SAX是最常用的两种方式。 DOM解析器将整个XML文档加载到内存,以树形结构表示,可以进行随机访问和修改。而SAX解析器则是基于事件驱动的,逐行解析XML文档,适用于处理大型XML文件。 如果你更喜欢使用DOM解析器,可以使用Java内置的`javax.xml.parsers.DocumentBuilder`类。如果更喜欢SAX解析器,可以使用`org.xml.sax.helpers.DefaultHandler`类。 以下是一个使用DOM解析器解析XML的示例代码: ```java import javax.xml.parsers.DocumentBuilder; import javax.xml.parsers.DocumentBuilderFactory; import org.w3c.dom.Document; import org.w3c.dom.Element; import org.w3c.dom.NodeList; public class XmlParser { public static void main(String[] args) { try { DocumentBuilderFactory factory = DocumentBuilderFactory.newInstance(); DocumentBuilder builder = factory.newDocumentBuilder(); Document document = builder.parse("data.xml"); Element root = document.getDocumentElement(); NodeList nodeList = root.getElementsByTagName("book"); for (int i = 0; i < nodeList.getLength(); i++) { Element book = (Element) nodeList.item(i); String title = book.getElementsByTagName("title").item(0).getTextContent(); String author = book.getElementsByTagName("author").item(0).getTextContent(); System.out.println("Title: " + title); System.out.println("Author: " + author); } } catch (Exception e) { e.printStackTrace(); } } } ``` 在上述示例,我们使用DOM解析器解析名为`data.xml`的XML文件。然后,我们根据XML的标签结构提取了书籍的标题和作者信息,并进行了输出。 希望这些示例代码可以帮助你开始使用Jackson和XML解析器进行JSON和XML数据的处理。如有任何疑问,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值