JAVA通过导入一定格式的excel对数据库数据进行模糊筛选
在工作中遇到一个需求是通过导入固定格式的excel来和数据库数据进行模糊匹配,符合条件的可以通过,不符合条件的就不通过,解决代码:
首先要导入上传文件的jar:
<dependency>
<groupId>commons-fileupload</groupId>
<artifactId>commons-fileupload</artifactId>
<version>1.2.1</version>
</dependency>
POI的jar:
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.15</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>3.15</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.15</version>
</dependency>
前台页面:
<input type="file" id="file" name="file"/>
<button id="inPutExcel" type="button" class="btn btn-primary" onclick="excelUpload()">导入</button>
js代码:
//excel导入
function excelUpload() {
//获得用户上传的文件
var file=document.getElementById("file").files[0];
var path =document.getElementById("file").value;
var formData = new FormData();
formData.append("file",file);
//进行一个简单的判断
if (path==""&&path==null){
alert("请选择要导入的文件")
}else {
if (path.endsWith(".xlsx")){
$.ajax({
url:"/excelUpload",
type:"post",
data:formData,
/**
*属性必须false
*/
contentType: false,
/**
* 属性必须false
* XMLHttpRequest会对 formdata 进行正确的处理
*/
processData: false,
success:function (data) {
if (data){
alert("导入成功");
} else {
alert("导入出错"