说明:适合数据库导出为xml时转成Excel

本工具将上传至GitHub:https://github.com/xiaostudy/xiaostudyAPI3

doc4j的maven依赖

 <!--xml解析的dom4j-->
<!-- https://mvnrepository.com/artifact/dom4j/dom4j -->
<dependency>
<groupId>dom4j</groupId>
<artifactId>dom4j</artifactId>
<version>1.6.1</version>
</dependency>

主要代码

package com.xiaostudy.util;

import org.dom4j.Document;
import org.dom4j.DocumentException;
import org.dom4j.Element;
import org.dom4j.io.SAXReader; import java.io.File;
import java.util.ArrayList;
import java.util.List; /**
* XML工具类
* @author xiaostudy
* @date 2019.4.26
* @version 1.0.0
*/
public class XmlUtil { public static void main(String[] args) {
Boolean aBoolean = Xml2ExcelFile("C:\\Users\\Administrator\\Desktop\\test.xml", "C:\\Users\\Administrator\\Desktop\\test2.xlsx");
System.out.println(aBoolean);
} /**
* Xml转Excel文件
* @param strXmlFilePath Xml文件路径
* @param strExcleFilePath Excel文件存放路径
* @return
*/
public static Boolean Xml2ExcelFile(String strXmlFilePath, String strExcleFilePath) {
if(StringUtil.isTrimNull(strXmlFilePath) || StringUtil.isTrimNull(strExcleFilePath)) {
return false;
} List<List<String>> listList = readXml(strXmlFilePath);
if(null == listList || listList.isEmpty()) {
return false;
} return ExcelUtil.createExcelFile(strExcleFilePath, listList);
} /**
* 读取Xml文件,以List<List<String>>形式返回
* @param strFile
* @return
*/
public static List<List<String>> readXml(String strFile) {
if(StringUtil.isTrimNull(strFile)) {
return null;
} SAXReader reader = new SAXReader();
File file = new File(strFile);
if(!file.exists() || !file.isFile()) {
return null;
} Document document = null;
try {
document = reader.read(file);
} catch (DocumentException e) {
e.printStackTrace();
}
List<List<String>> listList = new ArrayList<>(); if (null != document) {
Element root = document.getRootElement();
List<Element> childElements = root.elements();
List<String> titleList = new ArrayList<>();
listList.add(titleList);
boolean flag = true;
for (Element child : childElements) {
List<String> list = new ArrayList<>(); List<Element> elementList = child.elements();
for (Element ele : elementList) {
if(flag) {
titleList.add(ele.getName());
}
list.add(ele.getText());
}
flag = false; listList.add(list); System.out.println();
}
} return listList;
}
}

依赖的工具类GitHub上有https://github.com/xiaostudy/xiaostudyAPI3

StringUtil.isTrimNull

 public static boolean isTrimNull(Object obj) {
if (null != obj) {
return isNull(obj.toString().trim());
} else {
return true;
}
}

Excel.createExcelFile

 public static <T> Boolean createExcelFile(String fileName, List<List<T>> list) {
logger.debug(">>>>>" + CLASSNAME + ".createExcelFile()...");
logger.debug("fileName: " + fileName);
logger.debug("list: " + list); FileOutputStream fileOut = null;
try {
if(StringUtil.isTrimNull(fileName)) {
return false;
} File file = new File(fileName);
if(file.exists()) {
System.out.println("文件已存在!");
logger.debug("文件已存在!");
return false;
} Workbook workbook = null;
String excelType = null;
if(FileUtil.isFileNameEndsWith(fileName, ".xls")) {
excelType = "xls";
workbook = new HSSFWorkbook();
} else if(FileUtil.isFileNameEndsWith(fileName, ".xlsx")) {
excelType = "xlsx";
workbook = new XSSFWorkbook();
} else {
return false;
} fileOut = new FileOutputStream(fileName);
workbook.write(fileOut);
fileOut.close(); FileInputStream is = new FileInputStream(file);
if("xls".equals(excelType)) {
POIFSFileSystem fs = new POIFSFileSystem(is);
workbook = new HSSFWorkbook(fs);
} else if("xlsx".equals(excelType)) {
workbook = new XSSFWorkbook(is);
} Sheet sheet = workbook.createSheet();
sheet = setSheetValue(sheet , list); fileOut = new FileOutputStream(fileName);
workbook.write(fileOut);
} catch (Exception e) {
e.printStackTrace();
} finally {
if(fileOut != null) {
try {
fileOut.close();
} catch (IOException e) {
e.printStackTrace();
}
}
logger.debug("<<<<<" + CLASSNAME + ".createExcelFile().");
return true;
}
}

【java工具类】java做的一个xml转Excel工具,基于maven工程的更多相关文章

  1. 获取Spring容器中Bean实例的工具类(Java泛型方法实现)

    在使用Spring做IoC容器的时候,有的类不方便直接注入bean,需要手动获得一个类型的bean. 因此,实现一个获得bean实例的工具类,就很有必要. 以前,写了一个根据bean的名称和类型获取b ...

  2. JavaSE-基础语法(二)-系统类(java.lang.*)和工具类(java.util.*)

    系统类(java.lang.*)和工具类(java.util.*) 一.系统类(java.lang.*) 这个包下包含java语言的核心类,如String.Math.System和Thread类等,使 ...

  3. 我做了一个 HTML 可视化编辑工具,有前途吗?

    疫情在家的这段时间,我做了一个 HTML 可视化编辑工具,做的时候信心满满,差不多完成了,现在反而不如以前信心足了,这玩意有用吗?代码地址: https://github.com/vularsoft/ ...

  4. java使用注解和反射打造一个简单的jdbc工具类

    a simple jdbc tools 如有转载和引用,请注明出处,谢谢 1. 定义我们需要的注解 要想实现对数据库的操作,我们必须知道数据表名以及表中的字段名称以及类型,正如hibernate 使用 ...

  5. Redis 工具类 java 实现的redis 工具类

    最近了解了一下非关系型数据库 redis 会使用简单的命令 在自己本地电脑 使用时必须先启动服务器端 在启动客户端 redis 简介 Redis是一个开源的使用ANSI C语言编写.支持网络.可基于内 ...

  6. 005-guava 集合-集合工具类-java.util.Collections中未包含的集合工具[Maps,Lists,Sets],Iterables、Multisets、Multimaps、Tables

    一.概述 工具类与特定集合接口的对应关系归纳如下: 集合接口 属于JDK还是Guava 对应的Guava工具类 Collection JDK Collections2:不要和java.util.Col ...

  7. 加密解密工具类(Java,DES)

    一个Java版的DES加密工具类,能够用来进行网络传输数据加密,保存password的时候进行加密. import java.security.Key; import java.security.sp ...

  8. java工具类——java将一串数据按照gzip方式压缩和解压缩

    我要整理在工作中用到的工具类分享出来,也方便自己以后查阅使用,这些工具类都是我自己实际工作中使用的 import java.io.ByteArrayInputStream; import java.i ...

  9. Http请求工具类(Java原生Form+Json)

    package com.tzx.cc.common.constant.util; import java.io.IOException; import java.io.InputStream; imp ...

随机推荐

  1. /etc/issue 查看系统版本号

    查看系统版本号 [root@mysql bin]# cat /etc/issue CentOS release 6.4 (Final) Kernel \r on an \m

  2. linux 常用清理或备份文件命令

    find /data/tmp/confluence/backups/ -type f -mtime +7 -exec rm -f {} \; ##查找创建超过7天的文件并强制删除 cp /data/a ...

  3. 对比jQuery和AngularJS的不同思维模式

    jQuery是dom驱动,AngularJS是数据驱动,这里有一篇文章阐述的非常好,建议看看 本文来自StackOverFlow上How do I “think in AngularJS” if I ...

  4. RNN实现字符级语言模型 - 恐龙岛(自己写RNN前向后向版本+keras版本)

    问题描述:样本为所有恐龙名字,为了构建字符级语言模型来生成新的名称,你的模型将学习不同的名称模式,并随机生成新的名字. 在这里你将学习到: 如何存储文本数据以便使用rnn进行处理. 如何合成数据,通过 ...

  5. unity3d-绘制贴图

    准备贴图 在屏幕在绘制一张静态贴图,需要用到GUI.DrawTexture()方法, 该方法可以设定图片的显示位置.缩放比例和渲染混合等 /* Rect position:表示图片的绘制区域 * Te ...

  6. memset函数使用方法

    将s所指向的某一块内存中的每个字节的内容全部设置为ch指定的ASCII值, 块的大小由第三个参数指定,这个函数通常为新申请的内存做初始化工作, 其返回值为指向S的指针. 需要的头文件 在C中 < ...

  7. 【介绍+安装】Nginx的介绍和安装详解

    == 介绍和安装 == Nginx是一个自由.开源.高性能及轻量级的HTTP服务器及反转代理服务器, 其性能与IMAP/POP3代理服务器相当.Nginx以其高性能.稳定.功能丰富.配置简单及占用系统 ...

  8. 7.MySQL必知必会之用通配符进行过滤-like

    用通配符进行过滤-like 1. like操作符 先说两个概念:

  9. django登录功能(简单在POST请求)

    第一  先在templates中创立index.html !DOCTYPE html> <head> <meta charset="UTF-8"> & ...

  10. 功能测试三剑客:测试框架、bug预防、探索性测试

    功能测试有一套框架来实现完整的覆盖测试的各个维度 测试框架: 参加本人之前的博客测试框架(包括总体的框架.web测试框架.PC客户端.手机客户端.服务器端.接口测试)六部分,罗列了各个领域的测试覆盖考 ...