使用java解析XML文件的步骤

简介: 使用java解析XML文件的步骤

以前的时候,也解析过,今天又拿出来解析就让忘记怎么解析了,后来在网上查还有自己想,终于解析出来了,下面就是原XML文件:

accp.xml

<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE accp SYSTEM "accp.dtd">
<?xml-stylesheet type="text/css" href="accp.css"?>
<accp>
  <teachers>
    <teacher >
      <name>刘老师</name>
      <age>30</age>
      <degree>硕士</degree>
      <position>Java</position>   
    </teacher>
    <teacher>
      <name>李老师</name>
      <age>28</age>
      <degree>本科</degree>
      <position>.Net</position>   
    </teacher>
  </teachers>
  <students>
    <student>
      <name>高胜寒</name>
      <age>21</age>     
      <grade>Y2</grade>
      <school>北京中心</school>
    </student>
    <student>
      <name>信达雅</name>
      <age>19</age>
      <grade>S2</grade>
      <school>天津中心</school>
    </student>
  </students>
</accp>

还需要一个dtd文件accp.dtd:

<!ELEMENT accp (teachers,students)>
<!ELEMENT teachers (teacher*)>
<!ELEMENT students (student*)>
<!ELEMENT teacher (name,age,degree,position)>
<!ELEMENT student (name,age,grade,school)>
<!ELEMENT name (#PCDATA)>
<!ELEMENT age (#PCDATA)>
<!ELEMENT degree (#PCDATA)>
<!ELEMENT position (#PCDATA)>
<!ELEMENT grade (#PCDATA)>
<!ELEMENT school (#PCDATA)>

最后就是解析的代码了:

//解析xml文件
  public static void Test1(){
     DocumentBuilderFactory dbf = DocumentBuilderFactory.newInstance();
    //从DOM工厂获得DOM解析器
    try {
      DocumentBuilder db = dbf.newDocumentBuilder();
      //解析文档,得到一个dom树
      Document doc = db.parse("accp.xml");
      //得到所有的teacher节点
      NodeList teaList = doc.getElementsByTagName("teacher");
      System.out.println("xml里面共有"+teaList.getLength()+"个老师信息!");
      //循环老师信息
      for (int i = 0; i < teaList.getLength(); i++) {
        Node teacher = teaList.item(i);
        //获取第i个老师的信息的id值并输出
        /*Element element = (Element)teacher;
        String id = element.getAttribute("id");
        System.out.println("id:"+id);*/
        //获取第i个老师元素的所有子元素的名称和值并输出
        for(Node node=teacher.getFirstChild();node!=null;node =node.getNextSibling() ){
          if(node.getNodeType()==Node.ELEMENT_NODE){
            String value = node.getFirstChild().getNodeValue();
            System.out.print("name:"+value+"\t");
          }
        }
        System.out.println();
      }
    } catch (ParserConfigurationException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    } catch (SAXException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    } catch (IOException e) {
      // TODO Auto-generated catch block
      e.printStackTrace();
    }
    
  }

最后看一下运行结果:

目录
相关文章
|
22小时前
|
存储 缓存 Java
Java 文件 & 文件操作
Java 文件 & 文件操作
|
1天前
|
存储 安全 Java
Java顺序表解析与应用
Java顺序表解析与应用
|
1天前
|
存储 Java 数据库连接
从 0 实现一个文件搜索工具 (Java 项目)
从 0 实现一个文件搜索工具 (Java 项目)
27 17
|
1天前
|
Web App开发 Java 测试技术
《手把手教你》系列技巧篇(五十七)-java+ selenium自动化测试-下载文件-下篇(详细教程)
【5月更文挑战第21天】本文介绍了自动化测试中如何实现无弹窗下载文件,特别针对Chrome浏览器。通过设置`download.default_directory`和`profile.default_content_settings.popups`,可以避免下载弹窗并指定下载路径。示例代码展示了如何使用Java和Selenium实现这一功能,包括导入相关库、设置ChromeOptions和执行下载操作。最后,文章提到虽然没有介绍IE浏览器的下载方法,但已有Chrome和Firefox的方法已足够应对大多数需求。
15 0
|
1天前
|
存储 Java 编译器
解析Java中的包装类和泛型
解析Java中的包装类和泛型
|
1天前
|
Java
Java多线程基础-7:wait() 和 notify() 用法解析
这篇内容探讨了Java中的`wait()`和`notify()`方法在多线程编程中的使用。
7 0
|
1天前
|
存储 Java 开发者
深入理解Java虚拟机:JVM内存模型解析
【5月更文挑战第27天】 在Java程序的运行过程中,JVM(Java Virtual Machine)扮演着至关重要的角色。作为Java语言的核心执行环境,JVM不仅负责代码的执行,还管理着程序运行时的内存分配与回收。本文将深入探讨JVM的内存模型,包括其结构、各部分的作用以及它们之间的相互关系。通过对JVM内存模型的剖析,我们能够更好地理解Java程序的性能特征,并针对性地进行调优,从而提升应用的执行效率和稳定性。
|
2天前
|
Java 程序员 API
Java 8新特性深度解析:Stream API和Lambda表达式
【5月更文挑战第27天】 在Java 8中,引入了两个重要的新特性:Stream API和Lambda表达式。这两个特性不仅提高了Java程序员的生产力,也使得Java代码更加简洁易读。本文将深入探讨这两个特性的使用方法和优势,以及如何在实际应用中结合使用它们。
|
2天前
|
XML Web App开发 JavaScript
XML DOM 解析器
浏览器内置XML解析器,用于读取和操作XML。XML解析器将XML转换为JavaScript可访问的DOM对象,提供遍历、增删节点功能。要访问XML文档,需先加载到DOM。以下JS代码示例展示了如何使用XMLHttpRequest加载XML文档&quot;books.xml&quot;:创建XMLHTTP对象,打开并发送请求到服务器,然后将响应转换为DOM对象。
|
2天前
|
Web App开发 Java 测试技术
《手把手教你》系列技巧篇(五十六)-java+ selenium自动化测试-下载文件-上篇(详细教程)
【5月更文挑战第20天】本文介绍了自动化测试中如何实现无弹窗下载文件,主要针对Firefox浏览器。作者指出,通常的下载操作包括点击下载按钮,但这里讨论的是避免下载弹窗直接保存文件的方法。文章详细讲解了通过设置Firefox参数(如`browser.download.dir`、`browser.helperApps.neverAsk.saveToDisk`等)来实现这一功能,并给出了Java Selenium的示例代码,展示了如何创建FirefoxProfile并进行相关设置,以及如何启动浏览器和执行下载操作。
13 0
《手把手教你》系列技巧篇(五十六)-java+ selenium自动化测试-下载文件-上篇(详细教程)

推荐镜像

更多