如何将xml转换成excel_java 解析xml

如何将xml转换成excel_java 解析xml展开全部/****ExcelXML.java*IBM_Developer_POI(Excel,Word)*/packagecom.wds.excelxml;importjava.io.FileInputStream;importjava.io.FileNotFoundException;importjava.io.FileOutputStream;importjava.io.I…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

展开全部

/**

*

* ExcelXML.java

* IBM_Developer_POI(Excel,Word) */

package com.wds.excelxml;

import java.io.FileInputStream;

import java.io.FileNotFoundException;

import java.io.FileOutputStream;

import java.io.IOException;

import java.text.NumberFormat;

import java.text.ParseException;

import org.apache.poi.hssf.usermodel.HSSFCell;

import org.apache.poi.hssf.usermodel.HSSFCellStyle;

import org.apache.poi.hssf.usermodel.HSSFDataFormat;

import org.apache.poi.hssf.usermodel.HSSFDataFormatter;

import org.apache.poi.hssf.usermodel.HSSFHyperlink;

import org.apache.poi.hssf.usermodel.HSSFRow;

import org.apache.poi.hssf.usermodel.HSSFSheet;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;

import nu.xom.Attribute;

import nu.xom.Document;

import nu.xom.Element;

import nu.xom.Elements;

import nu.xom.Serializer;

public class ExcelXML {

public static void main(String[] args) {

excelXML();

}

/**

* 从Excel到XML

* 从XML到Excel

*/

private static void excelXML(){

/*

* 首先创建一个32313133353236313431303231363533e59b9ee7ad9431333337373665XML文档

* 要创建XML文档,首先创建一个根元素

*/

Element reportRoot=new Element(“sheet”);

Document xmlReport=new Document(reportRoot);

try {

//读取Excel文件

FileInputStream excelFIS=new FileInputStream(“D:\\JavaTest\\Employee_List.xls”);

//创建Excel工作表

HSSFWorkbook excelWB=new HSSFWorkbook(excelFIS);

//获得Excel工作簿

HSSFSheet excelSheet=excelWB.getSheetAt(0);

//获得工作簿的行数

int rows=excelSheet.getPhysicalNumberOfRows();

//遍历工作簿的行

for(int rowIndex=0; rowIndex

HSSFRow oneRow=excelSheet.getRow(rowIndex);

if(oneRow==null){

continue;

}

//在迭代每一行的时候,创建xml的行元素

Element rowElement=new Element(“row”);

//获得当前行的单元格数

int cells=oneRow.getPhysicalNumberOfCells();

//遍历行中的每一个单元格

for(int cellIndex=0;cellIndex

HSSFCell oneCell=oneRow.getCell(cellIndex);

if(oneCell==null){

continue;

}

//设置元素的默认名称

String elementName=”header”;

//获得单元格所在列位置

int cellColumnIndex=oneCell.getColumnIndex();

if(rowIndex>0){

elementName=reportRoot.getFirstChildElement(“row”).getChild(cellColumnIndex).getValue();

}

/*

* 去掉非法字符

*/

elementName = elementName.replaceAll(“[\\P{ASCII}]”,””);

elementName = elementName.replaceAll(” “, “”);

Element cellElement = new Element(elementName);

//添加属性和元素

//String attributeValue=oneCell.getCellStyle().getDataFormatString();

//Attribute dataFormatAttribute=new Attribute(“dataFormat”, attributeValue);

//cellElement.addAttribute(dataFormatAttribute);

/*

* 根据不同的属性添加

*/

Attribute strTypeAttribute=null;

switch (oneCell.getCellType()) {

case HSSFCell.CELL_TYPE_STRING:

strTypeAttribute=new Attribute(“dataType”,”String”);

cellElement.addAttribute(strTypeAttribute);

cellElement.appendChild(oneCell.getStringCellValue());

rowElement.appendChild(cellElement);

break;

case HSSFCell.CELL_TYPE_NUMERIC:

strTypeAttribute=new Attribute(“dataType”,”Numeric”);

cellElement.addAttribute(strTypeAttribute);

HSSFDataFormatter dataFormatter=new HSSFDataFormatter();

String cellFormatted=dataFormatter.formatCellValue(oneCell);

cellElement.appendChild(cellFormatted);

rowElement.appendChild(cellElement);

break;

}

}

if(rowElement.getChildCount()>0){

reportRoot.appendChild(rowElement);

}

//System.out.println(xmlReport.toXML());

}

2Q==

已赞过

已踩过<

你对这个回答的评价是?

评论

收起

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员-用户IM,转载请注明出处:https://javaforall.cn/171931.html原文链接:https://javaforall.cn

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • linux目录结构详解_linux系统配置文件目录

    linux目录结构详解_linux系统配置文件目录前言平常linux系统用的也不少,那么linux下的每个目录都是用来干什么的,小伙伴们有仔细研究过吗?让我们来了解下吧Linux系统目录结构登录系统后,在当前命令窗口下输入命令:[root@

  • Android 系统签名实现的三种方式

    Android 系统签名实现的三种方式在项目开发时,如果需要使应用具有系统权限,例如可以支持静默安装和卸载APK,此时就需要使用系统签名。常用的系统签名方式包括在ubuntu环境下、手动签名和在AndroidStudio环境配置,三种方式中,实现最简单的是通过AndroidStudo方式,该方式的签名实现与正常的APK签名相同,唯一不同的就是签名文件是通过系统生成的。注意,无论采用何种签名方式,如果想实现具有系统权限的应用,在AP…

  • 关于IO流的笔试面试题[通俗易懂]

    关于IO流的笔试面试题[通俗易懂]1.java中有几种类型的流?jdk为每种类型的流提供了一些抽象类以供继承,请说出它们分别是什么?解题思路:了解io流的体系(重要)就可以了从大的方面来分可以分为字节流和字符流.字符流提供了提供了reader和writer;字节流提供了outputstream 和inputstream. 2.字符流和字节流有什么区别?(重要)解题思路:从读写的原理上来进行区分会好记一点(字符流…

  • 数据挖掘应用研究案例精选合集[通俗易懂]

    数据挖掘应用研究案例精选合集[通俗易懂]数据挖掘应用研究案例精选合集数据挖掘(英语:Datamining),掌握数据挖掘技能,金矿就在您的脚下。基于数据挖掘技术的精确智能营销随着大数据、移动应用等的快速发展,已经越来越重要,企业对这方面人才需求缺口也越来越大。本文集主要从数据挖掘应用演讲案例方向介绍了数据挖掘的实际应用,从宏观角度帮助你了解什么是数据挖掘。阅读全文和小伙伴们一起来吐槽

  • 微型计算机的性能主要取决于什么,微型计算机的性能主要取决于什么?

    微型计算机的性能主要取决于什么,微型计算机的性能主要取决于什么?“微型计算机的性能主要取决于什么?”主要看三大件,CPU,主板,内存。1、CPU:其功能主要是解释计算机指令以及处理计算机软件中的数据,他的速度快慢可以代表计算机处理数据的能力的高低。2、内存:它是与CPU进行沟通的桥梁,计算机中所有程序的运行都是在内存中进行的,因此内存的性能对计算机的影响非常大。3、主板:主板在整个微机系统中扮演着举足轻重的角色。主板的类型和档次决定着整个微机系统的类型,主板的…

  • RUST开服教程、常用指令及心得[通俗易懂]

    RUST开服教程、常用指令及心得[通俗易懂]【前言】【开始前你需要了解的事情】①常用网址②更新与删档日期③目前国服环境【服务器硬件的选择】【标准服务器】①下载和更新服务器②制作服务器的启动脚本③选择你的服务器地图④运行服务器【模组服务器】①完成标准服务器的下载和设置②安装Oxide插件平台③下载插件④安装插件⑤调试插件⑥模组服的更新⑦在标准服中使用插件功能【在自己的电脑上运行服务端】①…

发表回复

您的电子邮箱地址不会被公开。

关注全栈程序员社区公众号