【Java实现.xlsx转.xmind】

文章介绍了如何使用Java编程将Excel表格中的数据转换成XMind流程图。主要涉及ApachePOI库读取Excel数据,以及XMindAPI创建和编辑流程图。代码示例展示了数据读取、流程图构建和保存的详细步骤。
摘要由CSDN通过智能技术生成

简单的就是将excel表格里面的数据转成一个Xmind的流程图

重要声明!!!入门新手一枚 如有错误 还请见谅~
源码地址:点击跳转

前期准备

1.安装Xmind,就直接去官网下载一个就好了,以下是我的版本 可以参考
在这里插入图片描述
2.给Idea配置maven环境,因为要用到相关的poi和xmind的依赖包,教程可以自行搜索 配置完成后用cmd/终端 mvn -v 指令检查是否配置成功就可以了
配置成功页面
配置成功页面

正式编码

  1. 首先在pom.xml文件中把需要用的依赖包配置好
    <!--Xmind -->
    <dependency>
      <groupId>com.github.eljah</groupId>
      <artifactId>xmindjbehaveplugin</artifactId>
      <version>0.8</version>
    </dependency>
    <!--poi -->
    <dependency>
      <groupId>org.apache.poi</groupId>
      <artifactId>poi-ooxml</artifactId>
      <version>3.17</version>
    </dependency>

2.Main.class

import org.apache.poi.openxml4j.exceptions.InvalidFormatException;
import org.xmind.core.*;

import java.io.File;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;

public class Main {
    public static void main(String[] args) throws IOException, InvalidFormatException, CoreException {
        Data data= new Data();
        //excel存放的目录
        String path="/Users/may/Desktop/";
        List<Map<String, Object>> dataList = new ArrayList<>();
        //目录拼接文件名 获取到对应的文件
        dataList=data.setPath(path+"test_case01.xlsx");
        //创建一个空白界面
        IWorkbookBuilder workbookBuilder= (IWorkbookBuilder) Core.getWorkbookBuilder();
        //创建工作溥
        IWorkbook iWorkbook=workbookBuilder.createWorkbook(data.fileName);
        //获取默认sheet
        ISheet primarySheet=iWorkbook.getPrimarySheet();
        //创建一个流程图的主题
        ITopic rootTopic= primarySheet.getRootTopic();
        //设置成为正确的逻辑图
        rootTopic.setStructureClass("org.xmind.ui.logic.right");
        rootTopic.setTitleText(data.fileName);
        //忽略表头
        for (int i=1;i<dataList.size();i++){
            //因为第一列是表头 不需要显示在逻辑图中 所以忽略第一行的数据 i从0开始
            //先定义一个父节点的位置,父结点也就是当前数据需要链接的结点,就当前位置 父结点就是根结点
            ITopic lastTopic = rootTopic;
            for (String value : dataList.get(i).keySet()) {
                //标记是否存在相同结点
                boolean flag=false;
                String key=value;
                //就当前数据创建一个新结点
                ITopic topic = iWorkbook.createTopic();
                topic.setTitleText((String) dataList.get(i).get(key));
                //caseId不用显示在逻辑图中,所以对key==caseId 数据不做处理
                if (key.equals("caseId")) {
                    continue;
                }
                //创建一list对象 用来装父结点的所子结点
                List<ITopic> chil= (List<ITopic>) lastTopic.getAllChildren();
                //如果chil长度<1,证明当前父结点没有子结点,直接父结点中添加就行
                if (chil.size()<1){
                    //将当前结点链接到父结点上
                    lastTopic.add(topic,ITopic.ATTACHED);
                    //将当前结点当作下一个新结点的父结点
                    lastTopic = topic;
                }
                else {
                    //如果chil长度>1,可能存在当前结点topic和lasttopic结点相同,
                    for (int k=0;k<chil.size();k++){
                        if (topic.getTitleText()==chil.get(k).getTitleText()) {
                            //如果相同 就将相同结点的topic 赋给 lasttopic
                            //并且将flag=true 表示存在相同结点
                            lastTopic = chil.get(k);
                            flag = true;
                            break;
                        }
                    }
                    if (!flag){//如果flag==flase,证明不存在相同结点,所以即使循环结束也依旧要把当前结点 topic链接到lasttopic 并且更新lasttopic
                        lastTopic.add(topic,ITopic.ATTACHED);
                        lastTopic = topic;
                    }
                }
            }
        }
        File file1 = new File(path+data.fileName+".xmind");
        //判断该路径下是否存在该文件,如果存在那么删除,如果不存在 直接新建
        if (file1.exists()){
            file1.delete();
        }
        iWorkbook.save(path+data.fileName+".xmind");


    }
}

3.Dat.class

import net.sf.json.JSONArray;
import org.apache.poi.ss.usermodel.CellType;
import org.apache.poi.xssf.usermodel.XSSFCell;
import org.apache.poi.xssf.usermodel.XSSFRow;
import org.apache.poi.xssf.usermodel.XSSFSheet;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

import java.io.*;
import java.util.*;

public class Data {
    String path;
    String fileName;
    //只做数据处理
    public List<Map<String, Object>> setPath(String path) throws IOException {
        this.path = path;
        File file = new File(path);
        this.fileName = file.getName();
        fileName = fileName.substring(0, fileName.indexOf("."));
        //System.out.println(this.fileName);
        List<Map<String, Object>> mapsList = null;
        String result = null;
        if (!file.exists()) {
            System.out.println("文件名不存在,请确认无误后重试!");
        } else {
            if (!file.canRead()) {
                System.out.println("该文件没有读取权限,请确认无误后重试!");
            } else {
                // 打开特定类型的输入流,读取文件的字节流 读取的内容in是一个地址:java.io.FileInputStream@19469ea2
                InputStream in = new FileInputStream(file);
                //System.out.println((char) in.read());
                //读取
                XSSFWorkbook sheets = new XSSFWorkbook(in);
                //System.out.println( sheets);
                //获取第一个sheet
                XSSFSheet sheet = sheets.getSheetAt(0);
                //getRow(0)读取第一行表头 A1/B1...
                XSSFRow titile = sheet.getRow(0);
                //System.out.println(sheet.getRow(0));
                System.out.println(sheet.getPhysicalNumberOfRows());
                //定义二维数组,存储读取出来的数据
                mapsList = new ArrayList<>();
                for (int i = 0; i < sheet.getPhysicalNumberOfRows(); i++) {
                    //从第二行开始
                    XSSFRow row = sheet.getRow(i);
                    //System.out.println(row.getPhysicalNumberOfCells());
                    //用于存储当前行的所有数据,以键-值的形式存储 HashMap允许存储相同的元素
                    Map<String, Object> map = new LinkedHashMap<>();
                    //循环遍历当前行
                    //row.getPhysicalNumberOfCells()只统计有内容总列数
                    //getLastCellNum 如果最后有数据的列为n,则返回n-1
                    for (int j = 0; j < row.getLastCellNum() + 1; j++) {
                        //获取这行数据中,对应列的键-值
                        XSSFCell title1 = titile.getCell(j);
                        //System.out.println(title1);
                        XSSFCell cell = row.getCell(j);
                        //System.out.println(cell);
                        //将获取到的值进行类型转换
                        if (cell == null) {
                            continue;
                        }
                        //修改单元格类型-文本类型
                        cell.setCellType(CellType.STRING);
                        //map里面只能是String Object类型的数据,现在的title1和cell的类型是XSSFCell类型 所以需要装换一下
                        String titleName = title1.getStringCellValue();
                        String valueName = cell.getStringCellValue();
                        //替换表格中的换行符
                        //if (valueName.contains("\n")) {
                         //   valueName = valueName.replace("\n", "***");
                        //}
                        map.put(titleName, valueName);
                    }
                    System.out.println(map);
                    mapsList.add(map);
                }
            }
        }
        return mapsList;
    }
}

输出效果

1、原始excel文件
在这里插入图片描述
2、输出Xmind文件结果
在这里插入图片描述

参考资料

1、poi Api:https://poi.apache.org/components/spreadsheet/how-to.html#event_api点击跳转
2、Xmind Api:http://sites.actsmind.com/support/xmnd-api点击跳转

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
分布式架构 漫谈分布式架构 初识分布式架构与意义 如何把应用从单机扩展到分布式 大型分布式架构演进过程 分布式架构设计 主流架构模型-SOA架构和微服务架构 领域驱动设计及业务驱动规划 分布式架构的基本理论CAP、BASE以及其应用 什么是分布式架构下的高可用设计 构架高性能的分布式架构 构建分布式架构最重要因素 CDN静态文件访问 分布式存储 分布式搜索引擎 应用发布与监控 应用容灾及机房规划 系统动态扩容 分布式架构策略-分而治之 从简到难,从网络通信探究分布式通信原理 基于消息方式的系统间通信 理解通信协议传输过程中的序列化和反序列化机制 基于框架的RPC通信技术 WebService/ApacheCXF RMI/Spring RMI Hession 传统RPC技术在大型分布式架构下面临的问题 分布式架构下的RPC解决方案 Zookeeper 分布式系统的基石 从0开始搭建3个节点额度zookeeper集群 深入分析Zookeeper在disconf配置中心的应用 基于Zookeeper Watcher 核心机制深入源码分析 Zookeeper集群升级、迁移 基于Zookeeper实现分布式服务器动态上下线感知 深入分析Zookeeper Zab协议及选举机制源码解读 Dubbo 使用Dubbo对单一应用服务化改造 Dubbo管理中心及及监控平台安装部署 Dubbo分布式服务模块划分(领域驱动) 基于Dubbo的分布式系统架构实战 Dubbo负载均衡策略分析 Dubbo服务调试之服务只订阅及服务只注册配置 Dubbo服务接口的设计原则(实战经验) Dubbo设计原理及源码分析 基于Dubbo构建大型分布式电商平台实战雏形 Dubbo容错机制及扩展性分析 分布式解决方案 分布式全局ID生成方案 session跨域共享及企业级单点登录解决方案实战 分布式事务解决方案实战 高并发下的服务降级、限流实战 基于分布式架构下分布式锁的解决方案实战 分布式架构实现分布式定时调度 分布式架构-中间件 分布式消息通信 消息中间件在分布式架构中的应用 ActiveMQ ActiveMQ高可用集群企业及部署方案 ActiveMQ P2P及PUB/SUB模式详解 ActiveMQ消息确认及重发策略 ActiveMQ基于Spring完成分布式消息队列实战 Kafka Kafka基于Zookeeper搭建高可用集群实战 kafka消息处理过程剖析 Java客户端实现Kafka生产者与消费者实例 kafka的副本机制及选举原理剖析 基于kafka实现应用日志实时上报统计分析 RabbitMQ 初步认识RabbitMQ及高可用集群部署 详解RabbitMQ消息分发机制及主题消息分发 RabbitMQ消息路由机制分析 RabbitMQ消息确认机制 Redis redis数据结构分析 Redis主从复制原理及无磁盘复制分析 Redis管道模式详解 Redis缓存与数据库一致性问题解决方案 基于redis实现分布式实战 图解Redis中的AOF和RDB持久化策略的原理 redis读写分离架构实践 redis哨兵架构及数据丢失问题分析 redis Cluster数据分布算法之Hash slot redis使用常见问题及性能优化思路 redis高可用及高并发实战 缓存击穿、缓存雪崩预防策略 Redis批量查询优化 Redis高性能集群之Twemproxy of Redis 数据存储 MongoDB NOSQL简介及MongoDB支持的数据类型分析 MongoDB可视化客户端及JavaApi实践 手写基于MongoDB的ORM框架 MongoDB企业级集解决方案 MongoDB聚合、索引及基本执行命令 MongoDB数据分片、存及恢复策略 MyCat MySQL主从复制及读写分离实战 MySQL+keepalived实现双主高可用方案实践 MySQL高性能解决方案之分库分表 数据库中间件初始Mycat 基于Mycat实习MySQL数据库读写分离 基于Mycat实战之数据库切分策略剖析 Mycat全局表、Er表、分片预警分析 Nginx 基于OpenResty部署应用层Nginx以及Nginx+lua实战 Nginx反向代理服务器及负载均衡服务器配置实战 利用keepalived+Nginx实战Nginx高可用方案 基于Nginx实现访问控制、连接限制 Nginx动静分离实战 Nginx Location ReWrite 等语法配置及原理分析 Nginx提供https服务 基于Nginx+lua完成访问流量实时上报Kafka的实战 Netty 高性能NIO框架 IO 的基本概念、NIO、AIO、BIO深入分析 NIO的核心设计思想 Netty产生的背景及应用场景分析 基于Netty实现的高性能IM聊天 基于Netty实现Dubbo多协议通信支持 Netty无锁化串行设计及高并发处理机制 手写实现多协议RPC框架
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值