网站推荐、资源下载等 | 个人网站

【java工具类】java做的一个xml转Excel工具,基于maven工程

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

 

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

doc4j的maven依赖

1 <!--xml解析的dom4j-->
2         <!-- https://mvnrepository.com/artifact/dom4j/dom4j -->
3         <dependency>
4             <groupId>dom4j</groupId>
5             <artifactId>dom4j</artifactId>
6             <version>1.6.1</version>
7         </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

1 public static boolean isTrimNull(Object obj) {
2         if (null != obj) {
3             return isNull(obj.toString().trim());
4         } else {
5             return true;
6         }
7     }

 

Excel.createExcelFile

 1 public static <T> Boolean createExcelFile(String fileName, List<List<T>> list) {
 2         logger.debug(">>>>>" + CLASSNAME + ".createExcelFile()...");
 3         logger.debug("fileName: " + fileName);
 4         logger.debug("list: " + list);
 5 
 6         FileOutputStream fileOut = null;
 7         try {
 8             if(StringUtil.isTrimNull(fileName)) {
 9                 return false;
10             }
11 
12             File file = new File(fileName);
13             if(file.exists()) {
14                 System.out.println("文件已存在!");
15                 logger.debug("文件已存在!");
16                 return false;
17             }
18 
19             Workbook workbook = null;
20             String excelType = null;
21             if(FileUtil.isFileNameEndsWith(fileName, ".xls")) {
22                 excelType = "xls";
23                 workbook = new HSSFWorkbook();
24             } else if(FileUtil.isFileNameEndsWith(fileName, ".xlsx")) {
25                 excelType = "xlsx";
26                 workbook = new XSSFWorkbook();
27             } else {
28                 return false;
29             }
30 
31             fileOut = new FileOutputStream(fileName);
32             workbook.write(fileOut);
33             fileOut.close();
34 
35             FileInputStream is = new FileInputStream(file);
36             if("xls".equals(excelType)) {
37                 POIFSFileSystem fs = new POIFSFileSystem(is);
38                 workbook = new HSSFWorkbook(fs);
39             } else if("xlsx".equals(excelType)) {
40                 workbook = new XSSFWorkbook(is);
41             }
42 
43             Sheet sheet = workbook.createSheet();
44             sheet = setSheetValue(sheet , list);
45 
46             fileOut = new FileOutputStream(fileName);
47             workbook.write(fileOut);
48         } catch (Exception e) {
49             e.printStackTrace();
50         } finally {
51             if(fileOut != null) {
52                 try {
53                     fileOut.close();
54                 } catch (IOException e) {
55                     e.printStackTrace();
56                 }
57             }
58             logger.debug("<<<<<" + CLASSNAME + ".createExcelFile().");
59             return true;
60         }
61     }

 

posted @ 2019-04-26 22:50  xiaostudy  阅读(4090)  评论(3编辑  收藏  举报
网站推荐
[理工最爱]小时百科 |  GitHub |  Gitee |  开源中国社区 |  牛客网 |  不学网论坛 |  r2coding |  冷熊简历 |  爱盘 |  零散坑 |  bootstrap中文网 |  vue.js官网教程 |  源码分享站 |  maven仓库 |  楼教主网站 |  廖雪峰网站 |  w3cschool |  在线API |  代码在线运行 |  [不学网]代码在线运行 |  JS在线运行 |  PHP中文网 |  深度开源eclipse插件 |  文字在线加密解密 |  菜鸟教程 |  慕课网 |  千图网 |  手册网 |  素材兔 |  盘多多 |  悦书PDF |  sumatra PDF |  calibre PDF |  Snipaste截图 |  shareX截图 |  vlc-media-player播放器 |  MCMusic player |  IDM下载器 |  格式工厂 |  插件网 |  谷歌浏览器插件 |  Crx搜搜 |  懒人在线计算器 |  leetcode算法题库 |  layer官网 |  layui官网 |  formSelects官网 |  Fly社区 |  程序员客栈 |  融云 |  华为云 |  阿里云 |  ztree官网API |  teamviewer官网 |  sonarlint官网 |  editormd |  pcmark10官网 |  crx4chrome官网 |  apipost官网 |  花生壳官网 |  serv-u官网 |  杀毒eset官网 |  分流抢票bypass官网 |  懒猴子CG代码生成器官网 |  IT猿网 |  natapp[内网穿透] |  ngrok[内网穿透] |  深蓝穿透[内网穿透] |  WakeMeOnLan[查看ip] |  iis7 |  [漏洞扫描]Dependency_Check官网 |  [图标UI]fontawesome官网 |  idea插件官网 |  路过图床官网 |  sha256在线解密 |  在线正则表达式测试 |  在线文件扫毒 |  KuangStudy | 
资源下载
电脑相关: Windows原装下载msdn我告诉你 |  U盘制作微PE工具官网下载 |  Linux_CentOS官网下载 |  Linux_Ubuntu官网下载 |  Linux_OpenSUSE官网下载 |  IE浏览器官网下载 |  firefox浏览器官网下载 |  百分浏览器官网下载 |  谷歌google浏览器历史版本下载 |  深度deepin系统官网下载 |  中兴新支点操作系统官网下载 |  文件对比工具Beyond Compare官网下载 |  开机启动程序startup-delayer官网下载 |  openoffice官网下载 |  utorrent官网下载 |  qbittorrent官网下载 |  cpu-z官网下载 |  蜘蛛校色仪displaycal官网下载 |  单文件制作greenone下载 |  win清理工具Advanced SystemCare官网下载 |  解压bandizip官网下载 |  内存检测工具memtest官网下载 |  磁盘坏道检测与修复DiskGenius官网下载 |  磁盘占用可视化SpaceSniffer官网下载 |  [磁盘可视化]WizTree官网下载 |  win快速定位文件Everything官网下载 |  文件定位listary官网下载 |  动图gifcam官网下载 |  7-Zip官网下载 |  磁盘分区工具diskgenius官网下载 |  CEB文件查看工具Apabi Reader官网下载 |  罗技鼠标options官网下载 |  [去除重复文件]doublekiller官网下载 | 
编程相关: ApacheServer官网下载 |  Apache官网下载 |  Git官网下载 |  Git高速下载 |  Jboss官网下载 |  Mysql官网下载 |  Mysql官网历史版本下载 |  NetBeans IDE官网下载 |  Spring官网下载 |  Nginx官网下载 |  Resin官网下载 |  Tomcat官网下载 |  jQuery历史版本下载 |  nosql官网下载 |  mongodb官网下载 |  mongodb_linux历史版本下载 |  mongodb客户端下载 |  VScode官网下载 |  cxf官网下载 |  maven官网下载 |  QT官网下载 |  SVN官网下载 |  SVN历史版本下载 |  nodeJS官网下载 |  oracle官网下载 |  jdk官网下载 |  STS官网下载 |  STS历史版本官网下载 |  vue官网下载 |  virtualbox官网下载 |  docker desktop官网下载 |  github desktop官网下载 |  EditPlus官网下载 |  zTree下载 |  layui官网下载 |  jqgrid官网下载 |  jqueryui官网下载 |  solr历史版本下载 |  solr分词器ik-analyzer-solr历史版本下载 |  zookeeper历史版本官网下载 |  nssm官网下载 |  elasticsearch官网下载 |  elasticsearch历史版本官网下载 |  redis官网下载 |  redis历史版本官网下载 |  redis的win版本下载 |  putty官网下载 |  查看svn密码TSvnPD官网下载 |  MongoDB连接工具Robo官网下载 |  dll查看exescope官网下载 |  dll2c官网下载 |  接口测试apipost官网下载 |  接口测试postman官网下载 |  原型设计工具AxureRP官网下载 |  canal官网下载 |  idea主题样式下载 |  vue的GitHub下载 |  finalShell官网下载 |  ETL工具kafka官网下载 |  cavaj[java反编译]官网下载 |  jd-gui[java反编译]官网下载 |  radmin[远程连接]官网下载 |  tcping[win ping端口]下载 |  jQueryUploadFile官网下载 |  RedisPlus下载 |  aiXcoder智能编程助手官网下载 |  [表单效验]validform官网下载 |  idea官网下载 |  RedisStudio下载 |  MD转word含公式pandoc官网下载 |  logviewer官网下载 |  Kafka官网下载 |  hbase高速下载 |  hadoop官网下载 |  hadooponwindows的GitHub下载 |  hive官网下载 |  soapui官网下载 |  flink官网下载 |  kafkatool官网下载 |  MinIO官网下载 |  MinIO中国镜像下载 | 
办公相关工具
免费在线拆分PDF【不超过30M】 |  免费在线PDF转Word【不超过10M】 |  在线文字识别转换【不超过1M】 |  PDF转换成Word【不超过50M】 |  在线OCR识别 |  Smallpdf |  文件转换器Convertio |  迅捷PDF转换器 |  字母大小写转换工具 |  档铺 |  快传airportal[可文字] |  快传-文叔叔 |  P2P-小鹿快传 |  [图床]ImgURL | 
网站入口
腾讯文档 |  有道云笔记网页版 |  为知笔记网页版 |  印象笔记网页版 |  蓝奏云 |  QQ邮箱 |  MindMaster在线思维导图 |  bilibili |  PDM文件在线打开 |  MPP文件在线打开 |  在线PS软件 |  在线WPS |  阿里云企业邮箱登陆入口 | 
其他
PDF转换 |  悦书PDF转换 |  手机号注册查询 |  Reg007 |  akmsg |  ip8_ip查询 |  ipip_ip查询 |  天体运行testtubegames |  测试帧率 |  在线网速测试 |