编写Java程序,使用 dom4j 解析上一节王者荣耀“英雄”对应的Xml文件数据内容,打印输出,具体格式

本文涉及的产品
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介: 编写Java程序,使用 dom4j 解析上一节王者荣耀“英雄”对应的Xml文件数据内容,打印输出,具体格式

需求说明:


使用 dom4j 解析上一节王者荣耀“英雄”对应的Xml文件数据内容,打印输出,具体格式如图所示


49.png


实现思路:


创建ParseHeroXML用于解析Xml,创建Hero类用于封装解析的英雄对象数据

在ParseHeroXML中定义parse()解析方法,根据讲解SAXReader进行解析Xml文件,获取根节点,定义listNodes递归方法调用,传入根节点

在listNodes方法中,遍历节点信息,分别根据节点名称获取相关节点的属性,遇到hero节点时,代表是一个英雄信息, 创建Hero实体对象,存储至List集合中,然后调用获取子节点信息方法getAttrAndChildNode

getAttrAndChildNode为获取hero子节点下的信息的方法,该方法中,获取属性判断是name或id,存储至Hero对象中,继续遍历子节点递归调用

循环遍历List集合中的Hero对象信息,输出查看


实现代码:


用于解析Xml的ParseHeroXML


import java.io.File;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.dom4j.Attribute;
import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader;
public class ParserHeroXML {
  Document document = null;
  Element rootElement = null;
  Hero hero = null;
  // 用来保存所有的英雄数据
  List<Hero> heros = new ArrayList<>();
  // 解析XML文档
  public void parse() {
    try {
      // 创建saxReader对象
      SAXReader reader = new SAXReader();
      // 通过read方法读取一个文件,转换成Document对象
      document = reader.read(new File("H:/hero.xml"));
      // 获取根节点元素对象
      rootElement = document.getRootElement();
      // 遍历所有的元素节点
      listNodes(rootElement);
    } catch (DocumentException e) {
      e.printStackTrace();
    }
  }
  // 递归遍历节点信息
  public void listNodes(Element element) {
    // 获取节点名称
    String elementName = element.getName();
    // 获取节点的文本
    String elementText = element.getTextTrim();
    // 判断当前的节点名称
    switch (elementName) {
    case "hero":
      hero = new Hero();
      heros.add(hero);
      getAttrAndChildNode(element);
      break;
    case "gender":
      hero.setGender(elementText);
      break;
    case "profession":
      hero.setProfession(elementText);
      break;
    case "nationality":
      hero.setNationality(elementText);
      break;
    case "price":
      hero.setPrice(Double.parseDouble(elementText));
      break;
    case "heroList":
      getAttrAndChildNode(element);
      break;
    default:
      break;
    }
  }
  // 获取节点上的属性值和子节点对象
  public void getAttrAndChildNode(Element element) {
    // 获取节点的所有属性
    List<Attribute> attributes = element.attributes();
    Attribute attr = null;
    String attrValue = null;
    // 循环遍历节点的每个属性
    for (int i = 0; i < attributes.size(); i++) {
      // 获取节点中的每个属性
      attr = attributes.get(i);
      // 获取每个属性所对应的值
      attrValue = attr.getValue();
      // 判断是否是id节点还是name节点
      if ("id".equals(attr.getName())) {
        // 将id的值保存到hero对象内
        hero.setId(Integer.parseInt(attrValue));
      } else if ("name".equals(attr.getName())) {
        // 将name的值保存到hero对象内
        hero.setName(attrValue);
      }
    }
    // 获取当前节点下的所有子节点
    Iterator<Element> eleIterator = element.elementIterator();
    // 判断该节点下是否还有子节点
    while (eleIterator.hasNext()) {
      // 取出子节点
      Element e = eleIterator.next();
      // 递归遍历子节点的信息
      listNodes(e);
    }
  }
  // 遍历保存到集合中的英雄信息
  public void showHeroInfo() {
    for (Hero tempHero : heros) {
      System.out.printf("编号:%d,姓名:%s,性别:%s,职业:%s,国籍:%s,价格:%.2f\n", tempHero.getId(), tempHero.getName(),
          tempHero.getGender(), tempHero.getProfession(), tempHero.getNationality(), tempHero.getPrice());
    }
  }
  public static void main(String[] args) {
    ParserHeroXML parserHeroXML = new ParserHeroXML();
    parserHeroXML.parse();
    parserHeroXML.showHeroInfo();
  }
}


用于封装解析的英雄对象数据Hero


public class Hero {
  private int id;// 英雄编号
  private String name;// 英雄名称
  private String gender;// 英雄性别
  private String profession;// 英雄职业
  private String nationality;// 英雄国籍
  private double price; // 出售价格
  public int getId() {
    return id;
  }
  public void setId(int id) {
    this.id = id;
  }
  public String getName() {
    return name;
  }
  public void setName(String name) {
    this.name = name;
  }
  public String getGender() {
    return gender;
  }
  public void setGender(String gender) {
    this.gender = gender;
  }
  public String getProfession() {
    return profession;
  }
  public void setProfession(String profession) {
    this.profession = profession;
  }
  public String getNationality() {
    return nationality;
  }
  public void setNationality(String nationality) {
    this.nationality = nationality;
  }
  public double getPrice() {
    return price;
  }
  public void setPrice(double price) {
    this.price = price;
  }
}



相关文章
|
2天前
|
Java
jvm复习,深入理解java虚拟机一:运行时数据区域
这篇文章深入探讨了Java虚拟机的运行时数据区域,包括程序计数器、Java虚拟机栈、本地方法栈、Java堆、方法区、元空间和运行时常量池,并讨论了它们的作用、特点以及与垃圾回收的关系。
29 19
jvm复习,深入理解java虚拟机一:运行时数据区域
|
4天前
|
JSON 前端开发 Java
震惊!图文并茂——Java后端如何响应不同格式的数据给前端(带源码)
文章介绍了Java后端如何使用Spring Boot框架响应不同格式的数据给前端,包括返回静态页面、数据、HTML代码片段、JSON对象、设置状态码和响应的Header。
29 1
震惊!图文并茂——Java后端如何响应不同格式的数据给前端(带源码)
|
2天前
|
安全 Java 编译器
Java 泛型深入解析:类型安全与灵活性的平衡
Java 泛型通过参数化类型实现了代码重用和类型安全,提升了代码的可读性和灵活性。本文深入探讨了泛型的基本原理、常见用法及局限性,包括泛型类、方法和接口的使用,以及上界和下界通配符等高级特性。通过理解和运用这些技巧,开发者可以编写更健壮和通用的代码。
|
3天前
|
自然语言处理 Java 数据处理
Java IO流全解析:字节流和字符流的区别与联系!
Java IO流全解析:字节流和字符流的区别与联系!
16 1
|
13天前
|
存储 算法 Java
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
本文介绍了 JVM 的内存区域划分、类加载过程及垃圾回收机制。内存区域包括程序计数器、堆、栈和元数据区,每个区域存储不同类型的数据。类加载过程涉及加载、验证、准备、解析和初始化五个步骤。垃圾回收机制主要在堆内存进行,通过可达性分析识别垃圾对象,并采用标记-清除、复制和标记-整理等算法进行回收。此外,还介绍了 CMS 和 G1 等垃圾回收器的特点。
53 0
深入解析 Java 虚拟机:内存区域、类加载与垃圾回收机制
|
15天前
|
安全 Java 开发者
Java修饰符与封装:理解访问权限、行为控制与数据隐藏的重要性
Java中的修饰符和封装概念是构建健壯、易维护和扩展的Java应用程序的基石。通过合理利用访问权限修饰符和非访问修饰符,开发者能够设计出更加安全、灵活且高效的代码结构。封装不仅是面向对象编程的核心原则之一,也是提高软件项目质量和可维护性的关键策略。
13 1
|
16天前
|
Java 开发者
Java中的异常处理机制深度解析
在Java编程中,异常处理是保证程序稳定性和健壮性的重要手段。本文将深入探讨Java的异常处理机制,包括异常的分类、捕获与处理、自定义异常以及一些最佳实践。通过详细讲解和代码示例,帮助读者更好地理解和应用这一机制,提升代码质量。
16 1
|
2月前
|
XML Java 数据格式
Spring5入门到实战------7、IOC容器-Bean管理XML方式(外部属性文件)
这篇文章是Spring5框架的实战教程,主要介绍了如何在Spring的IOC容器中通过XML配置方式使用外部属性文件来管理Bean,特别是数据库连接池的配置。文章详细讲解了创建属性文件、引入属性文件到Spring配置、以及如何使用属性占位符来引用属性文件中的值。
Spring5入门到实战------7、IOC容器-Bean管理XML方式(外部属性文件)
|
2天前
|
XML JavaScript Java
java与XML文件的读写
java与XML文件的读写
11 3

推荐镜像

更多