Java中使用sax进行xml文档的解析和生成

2024-05-12 22:32

本文主要是介绍Java中使用sax进行xml文档的解析和生成,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

java中基本的使用sax进行xml的解析和生成;
在这里插入图片描述
初始xml里面的内容,进行一个基本的编写;

首先进行导入sax包;
下载地址:https://download.csdn.net/download/u010374999/12528242

进行xml的解析
1.进行sax的启动:

package cn.biboom.xml;import java.io.IOException;import javax.xml.parsers.ParserConfigurationException;
import javax.xml.parsers.SAXParser;
import javax.xml.parsers.SAXParserFactory;import org.xml.sax.SAXException;import cn.biboom.handlehelper.HandleHelper;public class SAXParse {public static void main(String[] args) throws ParserConfigurationException, SAXException, IOException {// SAX进行解析器进行解析xmlSAXParserFactory factory = SAXParserFactory.newInstance();//创建xml解析器SAXParser parse = factory.newSAXParser();//开始解析xml文件parse.parse("J://test.xml", new HandleHelper());}}

2.进行事件的解析:
需要在sources里面导入几个包,一个是识别字符串,一个是识别主标签,一个是识别文档;

package cn.biboom.handlehelper;import org.xml.sax.Attributes;
import org.xml.sax.SAXException;
import org.xml.sax.helpers.DefaultHandler;public class HandleHelper extends DefaultHandler {//定义一个变量来存储当前正在处理的TAGprivate String Tag;//每次处理文本的时候激活;@Overridepublic void startDocument() throws SAXException {// 解析文档开始System.out.println("解析文档开始;");}@Overridepublic void endDocument() throws SAXException {// 解析文档结束时触发System.out.println("解析文档结束!");}@Overridepublic void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {//开始处理元素System.out.println("开始处理元素:"+qName);//拿到标签名字Tag = qName;if(attributes.getLength() > 0){System.out.println("<"+Tag+">解析元素如下:");for(int i = 0;i < attributes.getLength(); i ++){System.out.println(attributes.getQName(i) + "-------->" + attributes.getValue(i));}}}@Overridepublic void endElement(String uri, String localName, String qName) throws SAXException {// 解析元素结束的时候触发System.out.println("解析元素结束:"+qName);//解析该标签元素结束}@Overridepublic void characters(char[] ch, int start, int length) throws SAXException {//解析文本时触发String content = new String(ch,start,length);if(content.trim().length() > 0){//有内容的时候进行处理System.out.print("<"+Tag+">元素的值是:"+ content);}}}

实现结果如下:

	解析文档开始;开始处理元素:书籍列表开始处理元素:计算机书籍开始处理元素:书名<书名>元素的值是:java入门解析元素结束:书名开始处理元素:价格<价格>元素的值是:79.9解析元素结束:价格解析元素结束:计算机书籍开始处理元素:计算机书籍开始处理元素:书名<书名>元素的值是:spring解析元素结束:书名开始处理元素:价格<价格>元素的值是:39.9解析元素结束:价格解析元素结束:计算机书籍解析元素结束:书籍列表解析文档结束!

进行一个操作,进行一个xml的生成:

package cn.biboom.xml;import java.io.File;import javax.xml.transform.OutputKeys;
import javax.xml.transform.Result;
import javax.xml.transform.Transformer;
import javax.xml.transform.TransformerConfigurationException;
import javax.xml.transform.sax.SAXTransformerFactory;
import javax.xml.transform.sax.TransformerHandler;
import javax.xml.transform.stream.StreamResult;import org.xml.sax.helpers.AttributesImpl;public class BuildXmlMain {public static void main(String[] args) throws Exception {// TODO 进行XML文档的生成//创建xml的结果流对象Result resultXml = new StreamResult(new File("J://test2.xml"));//获取sax生成工厂实例SAXTransformerFactory stffy = (SAXTransformerFactory) SAXTransformerFactory.newInstance();//获取sax生成处理这对象实例TransformerHandler tfhd = stffy.newTransformerHandler();tfhd.setResult(resultXml);//获取sax生成器Transformer tf = tfhd.getTransformer();tf.setOutputProperty(OutputKeys.INDENT,"yes");//用来标识是否允许空格//进行生成,从生成文档头部开始tfhd.startDocument();AttributesImpl attimp = new AttributesImpl();//进行属性赋值,如果有属性的 话  attimp.addAttribute(uri, localName, qName, type, value);tfhd.startElement("", "", "书籍列表", attimp);//子标签开始tfhd.startElement("", "", "计算机书籍", attimp);tfhd.startElement("","","书名",attimp);tfhd.characters("JAVA编程".toCharArray(), 0, "JAVA编程".length());tfhd.endElement("", "", "书名");tfhd.startElement("","","作者",attimp);tfhd.characters("RaveyXie".toCharArray(), 0, "RaveyXie".length());tfhd.endElement("", "", "作者");tfhd.startElement("","","价格",attimp);tfhd.characters("79.9".toCharArray(), 0, "79.9".length());tfhd.endElement("", "", "价格");tfhd.endElement("", "", "计算机书籍");//子标签结束tfhd.endElement("", "", "书籍列表");//声明文档生成结束tfhd.endDocument();System.out.println("文档生成成功!");}}

在这里插入图片描述

这个就是基本进行xml的操作;

这篇关于Java中使用sax进行xml文档的解析和生成的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/983918

相关文章

Agent开发核心技术解析以及现代Agent架构设计

《Agent开发核心技术解析以及现代Agent架构设计》在人工智能领域,Agent并非一个全新的概念,但在大模型时代,它被赋予了全新的生命力,简单来说,Agent是一个能够自主感知环境、理解任务、制定... 目录一、回归本源:到底什么是Agent?二、核心链路拆解:Agent的"大脑"与"四肢"1. 规划模

SpringBoot简单整合ElasticSearch实践

《SpringBoot简单整合ElasticSearch实践》Elasticsearch支持结构化和非结构化数据检索,通过索引创建和倒排索引文档,提高搜索效率,它基于Lucene封装,分为索引库、类型... 目录一:ElasticSearch支持对结构化和非结构化的数据进行检索二:ES的核心概念Index:

Python数据验证神器Pydantic库的使用和实践中的避坑指南

《Python数据验证神器Pydantic库的使用和实践中的避坑指南》Pydantic是一个用于数据验证和设置的库,可以显著简化API接口开发,文章通过一个实际案例,展示了Pydantic如何在生产环... 目录1️⃣ 崩溃时刻:当你的API接口又双叒崩了!2️⃣ 神兵天降:3行代码解决验证难题3️⃣ 深度

Linux内核定时器使用及说明

《Linux内核定时器使用及说明》文章详细介绍了Linux内核定时器的特性、核心数据结构、时间相关转换函数以及操作API,通过示例展示了如何编写和使用定时器,包括按键消抖的应用... 目录1.linux内核定时器特征2.Linux内核定时器核心数据结构3.Linux内核时间相关转换函数4.Linux内核定时

C#借助Spire.XLS for .NET实现在Excel中添加文档属性

《C#借助Spire.XLSfor.NET实现在Excel中添加文档属性》在日常的数据处理和项目管理中,Excel文档扮演着举足轻重的角色,本文将深入探讨如何在C#中借助强大的第三方库Spire.... 目录为什么需要程序化添加Excel文档属性使用Spire.XLS for .NET库实现文档属性管理Sp

Java方法重载与重写之同名方法的双面魔法(最新整理)

《Java方法重载与重写之同名方法的双面魔法(最新整理)》文章介绍了Java中的方法重载Overloading和方法重写Overriding的区别联系,方法重载是指在同一个类中,允许存在多个方法名相同... 目录Java方法重载与重写:同名方法的双面魔法方法重载(Overloading):同门师兄弟的不同绝

MySQL字符串转数值的方法全解析

《MySQL字符串转数值的方法全解析》在MySQL开发中,字符串与数值的转换是高频操作,本文从隐式转换原理、显式转换方法、典型场景案例、风险防控四个维度系统梳理,助您精准掌握这一核心技能,需要的朋友可... 目录一、隐式转换:自动但需警惕的&ld编程quo;双刃剑”二、显式转换:三大核心方法详解三、典型场景

python中的flask_sqlalchemy的使用及示例详解

《python中的flask_sqlalchemy的使用及示例详解》文章主要介绍了在使用SQLAlchemy创建模型实例时,通过元类动态创建实例的方式,并说明了如何在实例化时执行__init__方法,... 目录@orm.reconstructorSQLAlchemy的回滚关联其他模型数据库基本操作将数据添

Spring配置扩展之JavaConfig的使用小结

《Spring配置扩展之JavaConfig的使用小结》JavaConfig是Spring框架中基于纯Java代码的配置方式,用于替代传统的XML配置,通过注解(如@Bean)定义Spring容器的组... 目录JavaConfig 的概念什么是JavaConfig?为什么使用 JavaConfig?Jav

Java数组动态扩容的实现示例

《Java数组动态扩容的实现示例》本文主要介绍了Java数组动态扩容的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧... 目录1 问题2 方法3 结语1 问题实现动态的给数组添加元素效果,实现对数组扩容,原始数组使用静态分配