如何将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)
blank

相关推荐

发表回复

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

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