java对xml全面解析,增,删,改,以及将java对象重新编组为xml文件

本文涉及的产品
云解析 DNS,旗舰版 1个月
全局流量管理 GTM,标准版 1个月
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
简介:
写了一个jaxp用dom处理xml的代码,具体例外省略,自己看吧,希望对你有帮助。
如果这里的格式不习惯可以看我在csdn的博客
[url]http://blog.csdn.net/xhinker/archive/2007/03/16/1531717.aspx[/url]
被解析的xml文件名为AnewXMLfile.xml
<?xml version="1.0" encoding="UTF-8"?>
<!--
    Document   : AnewXMLfile.xml
    Created on : 2007年3月13日, 下午3:36
    Author     : xhinker
-->
<customers>
  <customer>
    <id>001</id>
    <name>xhinker</name>
    <address>harbin</address>
  </customer>
  <customer>
    <id>002</id>
    <name>Car</name>
    <address>Suzhou</address>
  </customer>
  <customer>
    <id>003</id>
    <name>Jimmy</name>
    <address>ChengDu</address>
  </customer>
  <customer>
    <id>004</id>
    <name>Henry</name>
    <address>Xi'an</address>
  </customer>
</customers>
下面是用于解析这个xml文件的java代码,文件名为XMLfileReader.java
import javax.xml.parsers.*;
import org.w3c.dom.*;
import java.io.File;
import javax.xml.transform.dom.DOMSource;
import org.xml.sax.*;
import javax.xml.transform.stream.StreamResult;
import javax.xml.transform.*;
/**
 * @author xhinker
 */
public class XMLfileReader {
    /**
     *解组xml,使之成为Document对象
     */
    public Document XMLParse(){
        //建立解析器工厂
        DocumentBuilderFactory dbf=DocumentBuilderFactory.newInstance();
        Document doc=null;
        try {
            DocumentBuilder db=dbf.newDocumentBuilder();
            File file=new File("AnewXMLfile.xml");
            doc=db.parse(file);//解析xml文件
        } catch (Exception e) {}
        return doc;
    }
    /**
     *显示Docuument对象里的内容
     */
    public void XMLreader(Document doc){     
        try {
            System.out.println("haha");
            NodeList nl=doc.getElementsByTagName("customer");
            int len=nl.getLength();
            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);
                Node address=customer.getElementsByTagName("address").item(0);
                String newid=id.getFirstChild().getNodeValue();
                String newname=name.getFirstChild().getNodeValue();
                String newAddress=address.getFirstChild().getNodeValue();
                System.out.print("id\u53F7:");
                System.out.println(newid);
                System.out.print("\u540D\u5B57:");
                System.out.println(newname);
                System.out.print("\u5730\u5740");
                System.out.println(newAddress);    
            }
        } catch (Exception e) {}
    }
    /**
     *为Document对象里添加内容
     *@param doc Document类型对象
     */
    public void add(Document doc){
        try {
            Element customer=doc.createElement("customer");
            Element id=doc.createElement("id");
            Element name=doc.createElement("name");
            Element address=doc.createElement("address");
           
            Text textId=doc.createTextNode("005");
            Text textName=doc.createTextNode("zhushudong");
            Text textAddress=doc.createTextNode("haerbin");
           
            id.appendChild(textId);
            name.appendChild(textName);
            address.appendChild(textAddress);
           
            customer.appendChild(id);
            customer.appendChild(name);
            customer.appendChild(address);
           
            Element root=doc.getDocumentElement();
            root.appendChild(customer);          
        } catch (Exception e) {}
    }
    /**
     *删除结点
     *@param doc Document对象
     *@param i 用于指示要删除结点位置
     */
    public void delete(Document doc,int i){
        NodeList nl=doc.getElementsByTagName("customer");
        Node nodeDel=nl.item(i);
        nodeDel.getParentNode().removeChild(nodeDel);
    }
    /**
     *改变节点的值
     *@param doc 传入的对象
     *@param i 用于指示要修改结点位置
     *@param attr 要修改节点的标记
     *@param newValue 修改后的值
     */
    public void change(Document doc,int i,String attr,String newValue){
        NodeList nl=doc.getElementsByTagName("customer");
        Element cha=(Element)nl.item(i);
        Node nodeForCha=cha.getElementsByTagName(attr).item(0);
        nodeForCha.getFirstChild().setNodeValue(newValue);
    }
    /**
     *将java对象转化成xml文件
     *@param doc 要转化的java对象
     */
    public void ObjectToXML(Document doc)throws TransformerConfigurationException{
        try {
            //利用文档节点创建一个DOM输入源
            DOMSource source=new DOMSource(doc);
            //以newXMLfile.xml创建一个StreamResult对象
            StreamResult result=new StreamResult(new File("newXMLfile.xml"));
            //创建转换器工厂对象
            TransformerFactory tff=TransformerFactory.newInstance();
            //创建转换器对象
            Transformer tf=tff.newTransformer();
            //进行转换
            tf.transform(source, result);
        } catch (Exception e) {}
    }
    public static void main(String[] args){   
        XMLfileReader xmlReader=new XMLfileReader();
        Document newdoc=xmlReader.XMLParse();
        System.out.println("-----display------");
        xmlReader.XMLreader(newdoc);
        xmlReader.add(newdoc);
        System.out.println("-------add to last--------");
        xmlReader.XMLreader(newdoc);
        xmlReader.delete(newdoc, 0);
        System.out.println("-----delete the first node-------");
        xmlReader.XMLreader(newdoc);
        xmlReader.change(newdoc,0,new String("name"),new String("zhushudong2"));
        System.out.println("-----change the first node-------");
        xmlReader.XMLreader(newdoc);
        try {
            xmlReader.ObjectToXML(newdoc);
        } catch (Exception e) {}
    }
}



本文转自 xhinkerx 51CTO博客,原文链接:http://blog.51cto.com/xhinker/133071,如需转载请自行联系原作者
目录
相关文章
|
4天前
|
存储 Java 文件存储
微服务——SpringBoot使用归纳——Spring Boot使用slf4j进行日志记录—— logback.xml 配置文件解析
本文解析了 `logback.xml` 配置文件的详细内容,包括日志输出格式、存储路径、控制台输出及日志级别等关键配置。通过定义 `LOG_PATTERN` 和 `FILE_PATH`,设置日志格式与存储路径;利用 `&lt;appender&gt;` 节点配置控制台和文件输出,支持日志滚动策略(如文件大小限制和保存时长);最后通过 `&lt;logger&gt;` 和 `&lt;root&gt;` 定义日志级别与输出方式。此配置适用于精细化管理日志输出,满足不同场景需求。
36 1
|
7天前
|
Java 开发者
重学Java基础篇—Java类加载顺序深度解析
本文全面解析Java类的生命周期与加载顺序,涵盖从加载到卸载的七个阶段,并深入探讨初始化阶段的执行规则。通过单类、继承体系的实例分析,明确静态与实例初始化的顺序。同时,列举六种触发初始化的场景及特殊场景处理(如接口初始化)。提供类加载完整流程图与记忆口诀,助于理解复杂初始化逻辑。此外,针对空指针异常等问题提出排查方案,并给出最佳实践建议,帮助开发者优化程序设计、定位BUG及理解框架机制。最后扩展讲解类加载器层次与双亲委派机制,为深入研究奠定基础。
27 0
|
6天前
|
存储 设计模式 Java
重学Java基础篇—ThreadLocal深度解析与最佳实践
ThreadLocal 是一种实现线程隔离的机制,为每个线程创建独立变量副本,适用于数据库连接管理、用户会话信息存储等场景。
36 5
|
7天前
|
存储 监控 安全
重学Java基础篇—类的生命周期深度解析
本文全面解析了Java类的生命周期,涵盖加载、验证、准备、解析、初始化、使用及卸载七个关键阶段。通过分阶段执行机制详解(如加载阶段的触发条件与技术实现),结合方法调用机制、内存回收保护等使用阶段特性,以及卸载条件和特殊场景处理,帮助开发者深入理解JVM运作原理。同时,文章探讨了性能优化建议、典型异常处理及新一代JVM特性(如元空间与模块化系统)。总结中强调安全优先、延迟加载与动态扩展的设计思想,并提供开发建议与进阶方向,助力解决性能调优、内存泄漏排查及框架设计等问题。
27 5
|
6天前
|
机器学习/深度学习 人工智能 Java
Java机器学习实战:基于DJL框架的手写数字识别全解析
在人工智能蓬勃发展的今天,Python凭借丰富的生态库(如TensorFlow、PyTorch)成为AI开发的首选语言。但Java作为企业级应用的基石,其在生产环境部署、性能优化和工程化方面的优势不容忽视。DJL(Deep Java Library)的出现完美填补了Java在深度学习领域的空白,它提供了一套统一的API,允许开发者无缝对接主流深度学习框架,将AI模型高效部署到Java生态中。本文将通过手写数字识别的完整流程,深入解析DJL框架的核心机制与应用实践。
26 2
|
7天前
|
设计模式 缓存 Java
重学Java基础篇—Java对象创建的7种核心方式详解
本文全面解析了Java中对象的创建方式,涵盖基础到高级技术。包括`new关键字`直接实例化、反射机制动态创建、克隆与反序列化复用对象,以及工厂方法和建造者模式等设计模式的应用。同时探讨了Spring IOC容器等框架级创建方式,并对比各类方法的适用场景与优缺点。此外,还深入分析了动态代理、Unsafe类等扩展知识及注意事项。最后总结最佳实践,建议根据业务需求选择合适方式,在灵活性与性能间取得平衡。
47 3
|
7天前
|
安全 IDE Java
重学Java基础篇—Java Object类常用方法深度解析
Java中,Object类作为所有类的超类,提供了多个核心方法以支持对象的基本行为。其中,`toString()`用于对象的字符串表示,重写时应包含关键信息;`equals()`与`hashCode()`需成对重写,确保对象等价判断的一致性;`getClass()`用于运行时类型识别;`clone()`实现对象复制,需区分浅拷贝与深拷贝;`wait()/notify()`支持线程协作。此外,`finalize()`已过时,建议使用更安全的资源管理方式。合理运用这些方法,并遵循最佳实践,可提升代码质量与健壮性。
18 1
|
12天前
|
算法 测试技术 C语言
深入理解HTTP/2:nghttp2库源码解析及客户端实现示例
通过解析nghttp2库的源码和实现一个简单的HTTP/2客户端示例,本文详细介绍了HTTP/2的关键特性和nghttp2的核心实现。了解这些内容可以帮助开发者更好地理解HTTP/2协议,提高Web应用的性能和用户体验。对于实际开发中的应用,可以根据需要进一步优化和扩展代码,以满足具体需求。
62 29
|
9天前
|
前端开发 数据安全/隐私保护 CDN
二次元聚合短视频解析去水印系统源码
二次元聚合短视频解析去水印系统源码
27 3
|
11天前
|
JavaScript 算法 前端开发
JS数组操作方法全景图,全网最全构建完整知识网络!js数组操作方法全集(实现筛选转换、随机排序洗牌算法、复杂数据处理统计等情景详解,附大量源码和易错点解析)
这些方法提供了对数组的全面操作,包括搜索、遍历、转换和聚合等。通过分为原地操作方法、非原地操作方法和其他方法便于您理解和记忆,并熟悉他们各自的使用方法与使用范围。详细的案例与进阶使用,方便您理解数组操作的底层原理。链式调用的几个案例,让您玩转数组操作。 只有锻炼思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~

推荐镜像

更多