html:

<button class="layui-btn" onclick="exportData();">导出</button>
<button class="layui-btn" onclick="downloadTemplate();">模板下载</button>
<button id="importData" class="layui-btn" onclick="importData()">导入</button>

js:

//导入 用layui upload插件
layui.use([ "element", "laypage", "layer", "upload"], function() {
var element = layui.element;
var laypage = layui.laypage;
var layer = layui.layer;
var upload = layui.upload;//主要是这个
layui.upload.render({
elem: "#importData",//导入id
url: "/xx/importData",
size: '3072',
accept: "file",
exts: 'xls|xlsx|xlsm|xlt|xltx|xltm',
done: function (result) {
if (result.status == 0) {
refreshTable()
}
if (result.message != null) {
refreshTable();
layer.msg(result.message)
}
}
});
refreshTable()
});
//导出
function exportData() {
$.ajax({
type: "post", url: "/xx/exportData", data: {}, success: function (result) {
if (result.status == 0) {
window.open(result.data)
}
if (result.message != null) {
layer.msg(result.message)
}
}, error: function (XMLHttpRequest, textStatus, errorThrown) {
layer.msg('{"status":"' + XMLHttpRequest.status + '","readyState":"' + XMLHttpRequest.readyState + '","textStatus":"' + textStatus + '","errorThrown":"' + errorThrown + '"}')
}
})
}; //模板下载
function downloadTemplate() {
$.ajax({
type: "post", url: "/xx/downloadTemplate", data: {}, success: function (result) {
if (result.status == 0) {
window.open(result.data)
}
if (result.message != null) {
layer.msg(result.message)
}
}, error: function (XMLHttpRequest, textStatus, errorThrown) {
layer.msg('{"status":"' + XMLHttpRequest.status + '","readyState":"' + XMLHttpRequest.readyState + '","textStatus":"' + textStatus + '","errorThrown":"' + errorThrown + '"}')
}
})
}

 

java后端:

 // 导入
@PostMapping(value = "importData")
ResultJson importData(@RequestParam MultipartFile file) {
ResultJson resultJson = new ResultJson();
List<ProjectJson> importData = null;
try {
importData = ExcelUtil.importExcel(file.getInputStream(), ProjectJson.class);
} catch (IOException e) {
e.printStackTrace();
}
if (null == importData) {
resultJson.setStatus(1);
resultJson.setMessage("导入失败!");
return resultJson;
}
int num = 0; for (ProjectJson projectJson : importData) {
ProjectManageEntity projectManageEntity = new ProjectManageEntity();
num++;
if (CommonUtil.isEmpty(projectJson.getNumber())) {
resultJson.setMessage("导入失败!第" + num + "行的编号不能为空");
resultJson.setStatus(1);
return resultJson;
}
if (projectService.findByprojectNumber(projectJson.getNumber()) != null) {
resultJson.setStatus(1);
resultJson.setMessage("导入失败!第" + num + "行的编号重复");
resultJson.setData(null);
return resultJson;
} projectManageEntity.setCreateDate(new Date());
projectManageEntity.setUpdateDate(new Date());
projectManageEntity.setName(projectJson.getName());
projectManageEntity.setNumber(projectJson.getNumber());
projectManageEntity.setType(projectJson.getType());
projectManageEntity.setDeleteMark(false);
projectManageEntity.setCode("PROJECT_MANAGE" + UUID.randomUUID());
projectService.save(projectManageEntity);
} resultJson.setStatus(0);
resultJson.setMessage("导入成功!");
resultJson.setData(null);
return resultJson;
} //导出
@PostMapping(value = "exportData")
ResultJson exportData() {
String excelTitle = "项目管理";
String path = "/export/company/excel/" + DateUtil.getEightDateFormat().format(new Date());
String realPath = CommonUtil.createFolderPath(propertyUtil.getUploadPath() + path); return ExcelUtil.exportExcel(excelTitle, realPath, path, ProjectJson.class, projectService.getAll());
} //下载模板
@PostMapping(value = "downloadTemplate")
public ResultJson downloadTemplate() {
String excelTitle = "项目管理模板";
String path = "/export/company/excel/" + DateUtil.getEightDateFormat().format(new Date());
String realPath = CommonUtil.createFolderPath(propertyUtil.getUploadPath() + path);
return ExcelUtil.exportExcel(excelTitle, realPath, path, ProjectJson.class, projectService.getDownloadTemplate());
}
/**
* 创建指定目录
*
* @param folderPath 目录地址
* @return 目录地址
*/
public static final String createFolderPath(String folderPath) {
File file = new File(folderPath);
if (System.getProperty("os.name").toLowerCase().startsWith("win")) {
String[] diskNames = {"A:", "B:", "C:", "D:", "E:", "F:", "G:", "H:", "I:", "J:", "K:", "L:", "M:", "N:",
"O:", "P:", "Q:", "R:", "S:", "T:", "U:", "V:", "W:", "X:", "Y:", "Z:"};
for (int i = 0; i < diskNames.length; i++) {
if (i > 0) {
folderPath = folderPath.replace(diskNames[i - 1], diskNames[i]);
} else {
folderPath = diskNames[0] + folderPath;
}
file = new File(folderPath);
if (!file.exists()) {
file.mkdirs();
}
if (file.exists()) {
return folderPath;
}
}
return null;
} else {
if (!file.exists()) {
file.mkdirs();
}
if (file.exists()) {
return folderPath;
}
return null;
}
}
public class ExcelUtil {

    /**
* 导入Excel
*
* @param inputstream
* Excel数据流
* @param clazz
* 注解的实体类
* @return 导入的数据
*/
public static <T> List<T> importExcel(InputStream inputstream, Class<T> clazz) {
ImportParams params = new ImportParams();
params.setTitleRows(1);
params.setNeedSave(true);
try {
return ExcelImportUtil.importExcel(inputstream, clazz, params);
} catch (Exception e) {
e.printStackTrace();
return null;
}
} /**
* 导出Excel
*
* @param excelTitle
* Excel标题
* @param realPath
* 真实路径
* @param path
* 响应路径
* @param clazz
* 注解的实体类
* @param excels
* 注解的实体类集合
* @return 响应结果
*/
public static <T> ResultJson exportExcel(String excelTitle, String realPath, String path, Class<T> clazz,
List<T> excels) {
ResultJson resultJson = new ResultJson();
try {
Workbook workbook = ExcelExportUtil.exportExcel(new ExportParams(excelTitle, excelTitle), clazz, excels);
String filename = excelTitle + "-" + DateUtil.getEightDateFormat().format(new Date()) + ".xls";
File dirPath = new File(realPath);
if (!dirPath.exists()) {
dirPath.mkdirs();
}
try {
FileOutputStream outputStream = new FileOutputStream(realPath + "/" + filename);
workbook.write(outputStream);
resultJson.setStatus(0);
resultJson.setData(path + "/" + filename);
} catch (Exception e) {
e.printStackTrace();
resultJson.setStatus(1);
return resultJson;
}
} catch (Exception e) {
e.printStackTrace();
resultJson.setStatus(1);
return resultJson;
}
return resultJson;
} }

java+layui的Excel导入导出的更多相关文章

  1. Java 使用 Jxl 实现 Excel 导入导出

    开发过程中经常需要用到数据的导入导出功能,之前用的是POI,这次使用JXL,JXL相对于POI来说要轻量简洁许多,在数据量不大的情况下还是非常实用的.这里做一下使用JXL的学习记录.首先需要导入相应的 ...

  2. java jxl excel 导入导出的 总结(建立超链接,以及目录sheet的索引)

    最近项目要一个批量导出功能,而且要生成一个单独的sheet页,最后后面所有sheet的索引,并且可以点击进入连接.网上搜索了一下,找到一个方法,同时把相关的excel导入导出操作记录一下!以便以后使用 ...

  3. Java实现将Excel导入数据库和从数据库中导出为Excel

    实现的功能: 用Java实现从Excel导入数据库,如果存在就更新 将数据库中的数据导出为Excel 1.添加jxl.jar mysql-connector-java.1.7-bin.jar包到项目的 ...

  4. JAVA实现Excel导入/导出【转】

    JAVA实现Excel导入/导出[转] POI的下载与安装 请到网站http://www.apache.org/dyn/closer.cgi/poi/右击超链接2.5.1.zip下载压缩包poi-bi ...

  5. Java之POI的excel导入导出

    一.Apache POI是一种流行的API,它允许程序员使用Java程序创建,修改和显示MS Office文件.这由Apache软件基金会开发使用Java分布式设计或修改Microsoft Offic ...

  6. java简易excel导入导出工具(封装POI)

    Octopus 如何导入excel 如何导出excel github项目地址 Octopus Octopus 是一个简单的java excel导入导出工具. 如何导入excel 下面是一个excel文 ...

  7. JAVA Excel导入导出

    --------------------------------------------方式一(新)-------------------------------------------------- ...

  8. Java基础学习总结(49)——Excel导入导出工具类

    在项目的pom文件中引入 <dependency> <groupId>net.sourceforge.jexcelapi</groupId> <artifac ...

  9. Java Excel 导入导出(一)

    本文主要描述通过java实现Excel导入导出 一.读写Excel三种常用方式 1.JXL——Java Excel开放源码项目:读取,创建,更新 2.POI——Apache POI ,提供API给Ja ...

随机推荐

  1. SpringBoot原理—分析SpringBoot启动机制(starter机制)

    一:前言使用过springboot的同学应该已经知道,springboot通过默认配置了很多框架的使用方式帮我们大大简化了项目初始搭建以及开发过程.本文的目的就是一步步分析springboot的启动过 ...

  2. Java-出栈次序

    题目: X星球特别讲究秩序,所有道路都是单行线.一个甲壳虫车队,共16辆车,按照编号先后发车,夹在其它车流中,缓缓前行.路边有个死胡同,只能容一辆车通过,是临时的检查站,如图所示. X星球太死板,要求 ...

  3. tensorflow高阶操作

    本篇内容有:如何根据坐标有目的的选择(where).如何根据坐标有目的的更新(scatter_nd).如何生成一个坐标系() 1.where where针对的tensor是一个bool类型的tenso ...

  4. linux查找含有xxx内容的文件

    find . -name *.json |xargs grep "6379" |awk '{print $1}'|uniq

  5. 通过编写Java代码让Jvm崩溃

    在书上看到一个作者提出一个问题"怎样通过编写Java代码让Jvm崩溃",我看了之后也不懂.带着问题查了一下,百度知道里面有这样一个答案: 1 package jvm; 2 3 pu ...

  6. 剑指offer-面试题27-二叉树的镜像-二叉树

    /* 题目:输入一个二叉树,输出该函数的镜像. */ /* 思路: 基础条件:树为空,或只有一个节点. 其它:递归交换二叉树的左右子树. */ void Mirror(TreeNode *pRoot) ...

  7. P4802 [CCO 2015]路短最

    Problem 这题的题意是 求一条 经过 起点和终点的 最长路径.且一个点只能经过一次. 我们设定 \(dis_{i,j}\) 为 i 到 j 的距离(应该没有重边) 要注意的是 不能用 \(Flo ...

  8. FirstJavaWeb

    (未完成)出错有点多,Tomcat的配置也出问题了,Tomcat突然找不到jdk了,好像是我之前下载过一回然后没卸干净有残留文件,还有连接数据库的代码也有问题.       <%@page im ...

  9. C语言输出杨辉三角形

    // 打印杨辉三角: 行 + 列 ][] = { }; // 1. 确定要打印的行数: 13(n) ; i < ; ++i) { // 2. 确定列数:杨辉三角 行 == 列 ; j <= ...

  10. hdu 1025 Constructing Roads In JGShining's Kingdom(最长上升子序列)

    题意:贫穷和富有的城市都按顺序1-n排列,需要在中间建造尽可能多的道路,最多可以建造多少条? 解:如果条件这样给出,贫穷的城市按顺序排列,并且按顺序给出每个贫穷城市需要的资源,那么能建造的最多的道路数 ...