java中用jaxp解析xml

简介:
废话就不说了,先写一个简单的xml.取名为test.xml(正式xml文件要遵循xml命名规范)
<?xml version="1.0"?>
<students>
   <student>
      <id>001</id>
      <name>xhinker</name>
   </student>
   <student>
      <id>002</id>
      <name>thinker</name>
   </student>
</students>
 
接下来在同一个文件夹下写解析这个xml的java文件 XMLReader.java
import javax.xml.parsers.*;
import org.w3c.dom.*;
import org.xml.sax.SAXException;
import java.io.File;
import java.io.IOException;
public class XMLReader{
   public static void main(String[] args){//为简单起见直接写到main里面
      DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
                                                         //建立解析工厂对象
      try {
            DocumentBuilder db=dbf.newDocumentBuilder();//创建解析者
            File file=new File("test.xml");
            Document doc=db.parse(file);//解析xml文件
            NodeList nl=doc.getElementsByTagName("customer");
            int len=nl.getLength();//取得nodelist的长度
            for(int i=0;i<len;i++){
                Element customer=(Element)nl.item(i);
                Node id=customer.getElementsByTagName("id").item(0);
                Node name=customer.getElementsByTagName("name").item(0);
                String newid=id.getFirstChild().getNodeValue();
                String newname=name.getFirstChild().getNodeValue();
                System.out.print("id号:");
                System.out.println(newid);
                System.out.print("名字:");
                System.out.println(newname);
            }
      } catch (Exception e) {//避免复杂,详细例外省略}
   }
}
最后结果为
id号:001
名字:xhinker
id号:002
名字:thinker



本文转自 xhinkerx 51CTO博客,原文链接:http://blog.51cto.com/xhinker/133072,如需转载请自行联系原作者
目录
相关文章
|
存储 Java 文件存储
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— logback.xml 配置文件解析
本文解析了 `logback.xml` 配置文件的详细内容,包括日志输出格式、存储路径、控制台输出及日志级别等关键配置。通过定义 `LOG_PATTERN` 和 `FILE_PATH`,设置日志格式与存储路径;利用 `&lt;appender&gt;` 节点配置控制台和文件输出,支持日志滚动策略(如文件大小限制和保存时长);最后通过 `&lt;logger&gt;` 和 `&lt;root&gt;` 定义日志级别与输出方式。此配置适用于精细化管理日志输出,满足不同场景需求。
3212 1
|
Java 开发者
重学Java基础篇—Java类加载顺序深度解析
本文全面解析Java类的生命周期与加载顺序,涵盖从加载到卸载的七个阶段,并深入探讨初始化阶段的执行规则。通过单类、继承体系的实例分析,明确静态与实例初始化的顺序。同时,列举六种触发初始化的场景及特殊场景处理(如接口初始化)。提供类加载完整流程图与记忆口诀,助于理解复杂初始化逻辑。此外,针对空指针异常等问题提出排查方案,并给出最佳实践建议,帮助开发者优化程序设计、定位BUG及理解框架机制。最后扩展讲解类加载器层次与双亲委派机制,为深入研究奠定基础。
541 0
|
8月前
|
XML 数据采集 API
用Lxml高效解析XML格式数据:以天气API为例
免费Python教程:实战解析中国天气网XML数据,详解Lxml库高效解析技巧、XPath用法、流式处理大文件及IP封禁应对策略,助你构建稳定数据采集系统。
421 0
|
存储 设计模式 Java
重学Java基础篇—ThreadLocal深度解析与最佳实践
ThreadLocal 是一种实现线程隔离的机制,为每个线程创建独立变量副本,适用于数据库连接管理、用户会话信息存储等场景。
526 5
|
存储 监控 安全
重学Java基础篇—类的生命周期深度解析
本文全面解析了Java类的生命周期,涵盖加载、验证、准备、解析、初始化、使用及卸载七个关键阶段。通过分阶段执行机制详解(如加载阶段的触发条件与技术实现),结合方法调用机制、内存回收保护等使用阶段特性,以及卸载条件和特殊场景处理,帮助开发者深入理解JVM运作原理。同时,文章探讨了性能优化建议、典型异常处理及新一代JVM特性(如元空间与模块化系统)。总结中强调安全优先、延迟加载与动态扩展的设计思想,并提供开发建议与进阶方向,助力解决性能调优、内存泄漏排查及框架设计等问题。
645 5
|
机器学习/深度学习 人工智能 Java
Java机器学习实战:基于DJL框架的手写数字识别全解析
在人工智能蓬勃发展的今天,Python凭借丰富的生态库(如TensorFlow、PyTorch)成为AI开发的首选语言。但Java作为企业级应用的基石,其在生产环境部署、性能优化和工程化方面的优势不容忽视。DJL(Deep Java Library)的出现完美填补了Java在深度学习领域的空白,它提供了一套统一的API,允许开发者无缝对接主流深度学习框架,将AI模型高效部署到Java生态中。本文将通过手写数字识别的完整流程,深入解析DJL框架的核心机制与应用实践。
951 3
|
安全 IDE Java
重学Java基础篇—Java Object类常用方法深度解析
Java中,Object类作为所有类的超类,提供了多个核心方法以支持对象的基本行为。其中,`toString()`用于对象的字符串表示,重写时应包含关键信息;`equals()`与`hashCode()`需成对重写,确保对象等价判断的一致性;`getClass()`用于运行时类型识别;`clone()`实现对象复制,需区分浅拷贝与深拷贝;`wait()/notify()`支持线程协作。此外,`finalize()`已过时,建议使用更安全的资源管理方式。合理运用这些方法,并遵循最佳实践,可提升代码质量与健壮性。
518 1
|
XML JavaScript Java
详解Java解析XML的四种方法
详解Java解析XML的四种方法
746 1
|
XML Java 数据格式
java之DocumentBuilderFactory解析xml(2)
java之DocumentBuilderFactory解析xml(2)
431 0

推荐镜像

更多
  • DNS