java 生成和解析xml
本文主要使用的是Jdom.jar包(包的下载百度一下)实现了生成xml文件和解析xml文件
下面是生成xml的实现
说明:stuLists集合是一个存放着Student对象的集合
- import java.io.File;
- import java.io.FileNotFoundException;
- import java.io.FileOutputStream;
- import java.io.IOException;
- import java.util.ArrayList;
- import org.jdom.Document;
- import org.jdom.Element;
- import org.jdom.input.SAXBuilder;
- import org.jdom.output.Format;
- import org.jdom.output.XMLOutputter;
- public class AddXml {
- public static void main(String[] args) {
- new AddXml().changeXml();
- }
- public void changeXml(){
- Jdbc jdbc = new Jdbc();
- jdbc.addList();
- ArrayList<Student> stuLists = Jdbc.getStuList();
- Document docu = new Document();
- Element root = new Element("root");
- docu.addContent(root);
- for (int i = 0; i < stuLists.size(); i++) {
- // System.out.println(stuLists.get(i));
- Student s = stuLists.get(i);
- Element info = new Element("info");
- Element student = new Element("student");
- Element id = new Element("id");
- Element name = new Element("name");
- Element sex = new Element("sex");
- Element age = new Element("age");
- Element book = new Element("book");
- Element bid = new Element("bid");
- Element bname = new Element("bname");
- Element bprice = new Element("bprice");
- Element bautor = new Element("bautor");
- book.addContent(bid);
- book.addContent(bname);
- book.addContent(bprice);
- book.addContent(bautor);
- student.addContent(id);
- student.addContent(name);
- student.addContent(sex);
- student.addContent(age);
- info.addContent(student);
- info.addContent(book);
- root.addContent(info);
- int a = i+1;
- String No = "000"+a;
- student.setAttribute("No", No);
- id.setText(s.getId());
- name.setText(s.getName());
- sex.setText(s.getSex());
- age.setText(s.getAge());
- String b="0"+a;
- bid.setText(b);
- bname.setText("java核心");
- bprice.setText("1334.0");
- bautor.setText("star");
- }
- //格式化生成的xml文件,如果不进行格式化的话,生成的xml文件将会是很长的一行...
- Format format = Format.getCompactFormat();
- format.setEncoding("utf-8");
- format.setIndent(" ");
- XMLOutputter xo = new XMLOutputter(format);
- try {
- xo.output(docu, new FileOutputStream(new File("e:/io/stu.xml")));
- } catch (FileNotFoundException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- } catch (IOException e) {
- // TODO Auto-generated catch block
- e.printStackTrace();
- }
- System.out.println("生成xml文件成功!!!");
- }
- }
结果如图所示:
下面是用java解析上面所写的xml文件
简写版
- package com.direct.demo;
- import java.io.IOException;
- import java.util.List;
- import org.jdom.Document;
- import org.jdom.Element;
- import org.jdom.JDOMException;
- import org.jdom.input.SAXBuilder;
- public class Saxxml {
- public static void main(String[] args) {
- //解析xml文档
- SAXBuilder builder = new SAXBuilder();
- Document docu = null;
- try {
- docu = builder.build("e:/io/student.xml");
- } catch (JDOMException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
- Element root = docu.getRootElement();//得到根目录
- List stulist = root.getChildren();
- System.out.println(stulist.size()+"-----------");
- System.out.println("------------------读取xml文档的信息---------------------");
- for (int i = 0; i < stulist.size(); i++) {
- Element e = (Element) stulist.get(i);
- String stuid;
- String stuname ;
- String stusex ;
- String stuage;
- /*String stuValues = e.getAttribute("No").getValue();//属性值
- String stuValues1 = e.getAttributeValue("No");
- if (stuValues.equals("102")) {
- //修改姓名
- System.out.println(stuValues);
- e.getChild("stuname").setText("砖石王老五");
- //删除元素
- root.removeContent(e);
- break;
- }*/
- if (i==0) {
- stuid = e.getChildText("stuid");
- stuname = e.getChildText("stuname");
- stusex = e.getChildText("stusex");
- stuage = e.getChildText("stuage");
- }else {
- stuid = e.getChildText("stuid"+i);
- stuname = e.getChildText("stuname"+i);
- stusex = e.getChildText("stusex"+i);
- stuage = e.getChildText("stuage"+i);
- }
- System.out.println("属性:"+e.getAttributeValue("No"));
- System.out.println("学号:"+stuid);
- System.out.println("姓名:"+stuname);
- System.out.println("年龄:"+stuage);
- System.out.println("性别:"+stusex);
- System.out.println("--------------------");
- }
- }
- }
java 生成和解析xml的更多相关文章
- dom4j生成和解析xml文件
dom4j生成和解析xml文件 要生成和解析如下格式的xml文件: <?xml version="1.0" encoding="UTF-8"?> & ...
- DOM4J生成、解析XML实例
import java.io.File; import java.io.FileWriter; import java.io.IOException; import java.util.Iterato ...
- JDOM生成、解析XML实例
import java.io.File; import java.io.FileNotFoundException; import java.io.FileOutputStream; import j ...
- Java用SAX解析XML
要解析的XML文件:myClass.xml <?xml version="1.0" encoding="utf-8"?> <class> ...
- java Document生成和解析xml
转自:https://blog.csdn.net/p812438109/article/details/81807440 Document场景:需要知道文档所有结构 需要把文档一些元素排序 文档中的信 ...
- java使用sax解析xml
目的:解析xml文件,并存入mysql,并且要解析的字段能一一对应.这里解析的是微博的文件,想要利用里面的article和person_id字段. 思路: 为了能得到person_id和article ...
- android 67 生成和解析xml
生成xml: package com.itheima.createxml; import java.io.File; import java.io.FileNotFoundException; imp ...
- Java生成、解析二维码
今天遇到需求,使用Java生成二维码图片,网搜之后,大神们早就做过,个人总结一下. 目标:借助Google提供的ZXing Core工具包,使用Java语言实现二维码的生成和解析. 步骤如下: 1.m ...
- Java中Sax解析XML
SAX基于事件的解析,解析器在一次读取XML文件中根据读取的数据产生相应的事件,由应用程序实现相应的事件处理逻辑,即它是一种“推”的解析方式:这种解析方法速度快.占用内存少,但是它需要应用程序自己处理 ...
随机推荐
- 通过cookie绕过验证码登录
在我们做自动化的时候碰到一些比较难破解的验证码时是非常头疼的,一般来说最好的办法就是让开发屏蔽,这样最有益身心健康. 那么今天我介绍的这个方法也挺简单的,就是通过添加cookie的方式绕过验证码直接登 ...
- P4173 残缺的字符串
题目链接 题意分析 啥 ? ? ? \(FFT\)做字符串匹配 可是就是这样 我们定义匹配函数 我们定义\(A\)是匹配串 \(B\)是被匹配串 我们当前到达\(B\)串的\(x\)位置 \[P(x) ...
- leetcode-747-Largest Number At Least Twice of Others(求vector的最大值和次大值)
题目描述: In a given integer array nums, there is always exactly one largest element. Find whether the l ...
- PHP 数组与CSV文件互转
项目说明 数组导出CSV,ZIP文件,CSV,ZIP文件还原数组(Array export file,file restore array)适用于导入导出会员,商品信息注意:读取中文文件名文件.数据时 ...
- watch深度监测
假设有如下代码: <div> <p>FullName: {{fullName}}</p> <p>FirstName: <input type=&q ...
- Vue.js路由跳转带参数到模板组件。
从SalesOrderQuery组件跳到SalesOrder组件,并且通过params属性携带数据. handleClick(row) { //alert(row.FSaleName);//获取该行F ...
- 【中间件】Struts2系列漏洞POC小结
#Struts2-045 ''' CVE-2017-5638 影响范围:Struts 2.3.5 – Struts 2.3.31,Struts 2.5 – Struts 2.5.10 触发条件:基于J ...
- sklearn的train_test_split
train_test_split函数用于将矩阵随机划分为训练子集和测试子集,并返回划分好的训练集测试集样本和训练集测试集标签. 格式: X_train,X_test, y_train, y_test ...
- iview 之 穿梭框 transfer
概述 双栏穿梭选择框,常用于将多个项目从一边移动到另一边. 说明 Transfer 组件主要基于以下四个 API 来使用: :data:总体数据,数组,每项为一个对象,且必须含有 key 值,组件基于 ...
- Docker - 故障排查指南
这阵子开始捣鼓 Docker,遇到过不少问题,下面记录下问题以及解决方案 一.Docker 报 Failed to start Docker Application Container Engine ...