使用easyexcel读取excel并生成sql语句

1、引入pom依赖

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd"><modelVersion>4.0.0</modelVersion><groupId>com.bjrhc</groupId><artifactId>readExcel</artifactId><version>1.0-SNAPSHOT</version><properties><maven.compiler.source>8</maven.compiler.source><maven.compiler.target>8</maven.compiler.target></properties><dependencies><dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>3.1.3</version></dependency><dependency><groupId>ch.qos.logback</groupId><artifactId>logback-classic</artifactId><version>1.2.3</version> <!-- 根据最新版本进行更新 --></dependency><dependency><groupId>org.projectlombok</groupId><artifactId>lombok</artifactId><version>RELEASE</version><scope>compile</scope></dependency></dependencies></project>

2、创建实体类

如果你不想读sql中的每一个字段,就可以像我这样,加上注解,只声明要读的列:

@Data
public class ExcelPO {@ExcelProperty("业务对象")private String obj;@ExcelProperty("业务部门")private String bumen;@ExcelProperty("属性")private String shuxing;@ExcelProperty("来源表英文名")private String tableNameEnglish;@ExcelProperty("来源表中文名")private String tableNameChina;@ExcelProperty("来源字段英文名")private String ziduan;
}

3、编写工具类

import com.alibaba.excel.EasyExcel;
import com.alibaba.excel.context.AnalysisContext;
import com.alibaba.excel.read.listener.ReadListener;
import lombok.SneakyThrows;import java.io.BufferedWriter;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.util.*;public class ExcelListener {public static void main(String[] args) throws Exception {//excel路径String fileName = "doc/excel.xlsx";//读取EasyExcel.read(fileName)//读第0个sheet表.sheet(0)//从第二行开始读.headRowNumber(1)//对应的实体类.head(ExcelPO.class).registerReadListener(new TransformerDataListener()).doReadSync();}public static class TransformerDataListener implements ReadListener<ExcelPO> {//用来接受读出来的数据Map<String, List<Object>> hashMap = new HashMap<>();@SneakyThrows@Overridepublic void invoke(ExcelPO data, AnalysisContext context) {// 每一行数据在这里处理if (data.getBumen().equals("选择部门")){if (data.getObj().contains("选择对象")){if (data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ||data.getShuxing().equals("字段信息") ){//判断是否已经存储过这张表,如果存储过直接给他的value加上要存储的字段if (hashMap.containsKey(data.getTableNameEnglish())){List list = hashMap.get(data.getTableNameEnglish());list.add(data.getZiduan());}else {//如果没有则添加一个新的mapList list1 = new ArrayList<>();list1.add(data.getZiduan());hashMap.put(data.getTableNameEnglish(),list1);}}}};//创建一个用来存储我们查到并需要的内容的txtString txt = "doc/text.txt";File file = new File(txt);//不存在则创建一个新的txt文档if (!file.exists()) {try {file.createNewFile();} catch (IOException e) {e.printStackTrace();}}//写txtFileWriter fw = new FileWriter(file);BufferedWriter bw = new BufferedWriter(fw);for (Map.Entry<String, List<Object>> entry : hashMap.entrySet()) {String key = entry.getKey();List<Object> values = entry.getValue();StringBuilder s = new StringBuilder("select * from "+ key + " where ");// 输出List中的每个值for (Object value : values) {s.append(value+" is null or ");}s.replace(s.lastIndexOf("or"), s.lastIndexOf("or")+"or".length(), ";");bw.write(String.valueOf(s));bw.newLine();}//写操作完成后关闭流bw.close();}@Overridepublic void doAfterAllAnalysed(AnalysisContext context) {// 所有数据解析完成后的回调}// 如果需要处理异常,重写下列方法@Overridepublic void onException(Exception exception, AnalysisContext context) {exception.printStackTrace();}}
}

在这里我将生成的sql放入了一个新的txt中,项目目录参考:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/810792.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【IR-SDE】Image Restoration SDE项目演示运行app.py

背景&#xff1a; code:GitHub - Algolzw/image-restoration-sde: Image Restoration with Mean-Reverting Stochastic Differential Equations, ICML 2023. Winning solution of the NTIRE 2023 Image Shadow Removal Challenge. paper: Official PyTorch Implementations o…

如何面对微服务在部署和管理上的挑战

微服务因其灵活性和可扩展性而备受大型系统架构师的青睐&#xff0c;但是相对于一般的单体系统&#xff0c;微服务的部署和管理更具挑战性。 面对微服务架构中“部署和管理的复杂性”挑战&#xff0c;可以采取以下策略和工具来应对&#xff1a; 容器化技术&#xff1a; 使用Do…

LabVIEW闭环步进电机运动系统设计及精度分析

LabVIEW闭环步进电机运动系统设计及精度分析 在自动化设备不断发展的当代&#xff0c;闭环步进电机以其高精度和可靠性成为了自动化设备的重要组成部分。以LabVIEW软件为核心&#xff0c;结合运动控制卡及驱动器模块&#xff0c;设计并实现了一个闭环步进电机的多轴运动控制系…

Rancher1.0版本安装使用

Rancher1.0版本安装使用 准备环境 rancher是一个容器管理和服务编排工具。 如下链接&#xff0c;讲的可以&#xff0c;大家参考下&#xff0c;我已经测试过了。 http://tonybai.com/2016/04/14/an-introduction-about-rancher/ 操作系统Centos7.2 用户为root。最好使用Cent…

【iOS ARKit】USDZ文件

USDZ 概述 ARKit 支持 USDZ&#xff08;Universal Scene Description Zip&#xff0c;通用场景描述文件包&#xff09;、Reality 两种格式的模型文件&#xff0c;得益于 USDZ的强大描述能力与网络传输便利性&#xff0c;使得iOS 设备能够在其信息&#xff08;Message&#xff0…

ryu、python安装、版本问题

conda conda create --name py35 python3.5 创建 conda activate py35 //激活 conda deactivate py35//退出 conda remove --name py35 --all//移除 conda info -e //已安装环境/miniconda3/bin/python base位置/etc/python /usr/lib/python3.5m /usr/bin/python2.7 minine…

Mapbox 教程: 改变地图样式

注&#xff1a;相关功能在Mapbox GL JS v3中可用。在新版本中&#xff0c;默认使用标准样式&#xff0c;在创建地图时&#xff0c;可以在构造函数中明确指定style option 设置指定样式&#xff0c;也可以不设置style option 从而使用默认样式。 本示例通过Mapbox加载了一份带三…

esxi配置使用以及虚拟机管理

vSphere Client安装和esxi主机 esxi配置 许可证 虚拟机管理 vSphere Client中创建、删除等虚拟机的管理。 vSphere Client中创建虚拟机并安装操作系统&#xff1b; 步骤1 创建虚拟机 密码&#xff1a;Tongxin2023 (1) 厚置备延迟置零 以默认的厚格式创建虚拟磁盘。创建过…

佛山市人工智能产业生态交流会:实在智能Agent引领“智造浪潮”

制造业&#xff0c;实体经济的核心&#xff0c;技术创新的先锋&#xff0c;供给侧结构性改革的关键。在新一轮产业竞争中&#xff0c;数字化转型成为制造业升级的必由之路&#xff0c;是引领未来的重要抓手。 为促进数字经济赋能实体经济&#xff0c;加快人工智能技术的推广应用…

设计模式|建造者模式(Builder Pattern)

文章目录 结构优点缺点适用场景示例建造者模式(Builder Pattern)是一种创建型设计模式,用于将一个复杂对象的构建过程与其表示分离,以便可以使用相同的构建过程创建不同的表示。 结构 Builder(建造者)接口或抽象类: 定义了构建对象的各个步骤的方法。ConcreteBuilder(具…

C# 冻结Excel窗口以锁定行列、或解除冻结

在处理大型Excel工作簿时&#xff0c;有时候我们需要在工作表中冻结窗格&#xff0c;这样可以在滚动查看数据的同时保持某些行或列固定不动。冻结窗格可以帮助我们更容易地导航和理解复杂的数据集。相反&#xff0c;当你不需要冻结窗格时&#xff0c;你可能需要解冻它们以获得完…

数据结构 | 线性表的顺序表示(王道)

文章目录 顺序表定义综合应用顺序表定义 静态分配 #define MaxSize 50 typedef struct{ElemType data[MaxSize];int length; }SqList;动态分

ubuntu 20.04 设置国内镜像源(阿里源、清华源)

在网上搜了好多设置国内镜像源&#xff0c;都写的乱七八糟的&#xff0c;都是随便换&#xff0c;最后还是换得一堆问题。 镜像源也是跟版本一一对应的&#xff0c;不能随便一个国内源就还过去用&#xff0c;否则会出现各种各样的问题&#xff0c;我也是吃过亏之后才发现的。 国…

【Vue 自定义事件】

组件的自定义事件 一种组件间通讯的方式&#xff0c;适用于&#xff1a;子组件 —> 父组件 绑定自定义事件 第一种方式:在父组件中写单标签1.<Demo 事件名"方法">2.<Demo v-on:事件名"方法"/>第二种方式:使用ref绑定(配置在生命周期中)this…

通讯录项目(用c语言实现)

一.什么是通讯录 通讯录是一种用于存储联系人信息的工具或应用程序。它是一种电子化的地址簿&#xff0c;用于记录和管理个人、机构或组织的联系方式&#xff0c;如姓名、电话号码、电子邮件地址和邮寄地址等。通讯录的目的是方便用户在需要时查找和联系他人。 通讯录通常以列…

手眼标定问题排查_2_圆网格数据排查

经过昨天晚上的调试&#xff0c;发现了一个主要问题&#xff1a;使用圆网格标定板标定时&#xff0c;不能使用cornerSubPix()函数&#xff0c;否则寻找角点时&#xff0c;会导致图一的情况(裁剪为30万像素)。就找到能参考的程序&#xff0c;推进还是很快的。 图一 一些数据对比…

imu6xl点灯(C语言)

参考正点原子开发指南 根据原理图可以看出&#xff0c;我们需要设置低电平导通电路。 在原理图上找到LED0&#xff0c;对应IO为GPIO3 IO复用配置 IMX6UL每个引脚都可以复用 在用户手册第30章可以找到IOMUXC_SW_MUX_CTL_PAD_GPIO1_IO03这个寄存器&#xff0c;地址为0x020E0068&…

Linux网络名称空间和虚拟机有何区别

在Linux系统中&#xff0c;网络名称空间和虚拟机都是实现资源隔离和虚拟化的技术&#xff0c;但它们在设计理念、实现机制、资源消耗、使用场景等方面存在着显著的区别。本文旨在全方位、系统性地分析这两种技术的区别。&#x1f50d; 1. 设计理念与实现机制 1.1. 网络名称空…

未来汽车硬件安全的需求(2)

目录 4.汽车安全控制器 4.1 TPM2.0 4.2 安全控制器的硬件保护措施 5. EVITA HSM和安全控制器结合 6.小结 4.汽车安全控制器 汽车安全控制器是用于汽车工业安全关键应用的微控制器。 他们的保护水平远远高于EVITA HSM。今天的典型应用是移动通信&#xff0c;V2X、SOTA、…

bat脚本中使用gradle命令后,脚本不继续执行,直接退出

在window 的bat脚本执行的时候&#xff0c;执行完一个gradlew 目标后会自动退出&#xff0c;pause命令也无效。 原因&#xff1a;gradlew本身是一个bat命令&#xff0c;因此在exit退出的时候&#xff0c;整个脚本进程将退出&#xff0c;加入call命令调用即可&#xff1a; 如下…