这篇文章是我第一个博客的第一篇文章,希望可以给大家一些帮助吧。
这是在做项目时用到一个功能 主要是实现批量导入用户信息到数据库,在做这个功能的时候也是在网上找了一些代码,感觉网上一些代码写的不是很全。我在这整理了一下,摘取出其中的读取excel文件数据代码,仅供参考。
下面是页面代码:
<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<title>读取Excel数据</title>
<style type="text/css">
div {
position: relative;
top: 120px;
text-align:center;
}
.submit {
clear: both;
position: relative;
border: 1px solid black;
background: blue;
color: white;
width: 70px;
height: 30px;
border-radius: 6px;
box-shadow: #000 3px 3px;
cursor: pointer;
}
.submit:hover{
background:#6D6DFF;
}
.submit:active{
top:3px;
left:3px;
box-shadow: #000 0px 0px;
background:#6D6DFF;
}
</style>
<script type="text/javascript">
function formCheck(form){
if(form.excelFile.value == ""){
alert("请选择上传的文件");
return false;
}else{
var str= form.excelFile.value;
var lc = str.toLowerCase();
var arr = lc.split(".");
var extname = arr[arr.length-1];
if(extname != "xls" && extname != "xlsx"){
alert("请选择excel格式文件!");
return false;
}
}
}
</script>
</head>
<body>
<div>
<form name="readExcel" action="/importExcel" method="post" enctype="multipart/form-data" onsubmit="return formCheck(this);">
Excel文件路径: <input type="file" name="excelFile"><br>
<input class="submit" type="submit" value="导入">
</form>
</div>
</body>
</html>
我用的是JSP,在页面中加了一段JS代码,用来判断是否为空和是否为excel格式文件。
下面是struts.xml的配置:
<package name="default" extends="json-default">
<action name="importExcel" class="com.truth.action.ImportExcelAction">
<result>/importUser.jsp</result>
</action>
</package>
struts.xml 的配置我就不多说了,大家应该能看懂吧。
在写java代码之前,要在项目里引入一个poi.jar文件,poi.jar下载地址
下面的是action中的代码:
package com.truth.action;
import java.io.File;
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
import org.apache.commons.lang.StringUtils;
import org.apache.log4j.Logger;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.Row;
import org.apache.poi.ss.usermodel.Sheet;
import org.apache.poi.ss.usermodel.Workbook;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;
import org.springframework.beans.factory.annotation.Autowired;
import com.opensymphony.xwork2.ActionSupport;
import com.truth.domain.User;
public class ImportExcelAction extends ActionSupport{
private static final long serialVersionUID = 2078983971691770134L;
private static final Logger log = Logger.getLogger(ImportExcelAction.class);
private File excelFile; //上传的文件
private String excelFileName; //保存原始文件名
private User user;
//判断文件类型
public Workbook createWorkBook(InputStream is) throws IOException{
if(excelFileName.toLowerCase().endsWith("xls")){
return new HSSFWorkbook(is);
}else if(excelFileName.toLowerCase().endsWith("xlsx")){
return new XSSFWorkbook(is);
}else{
return null;
}
}
public String execute() throws Exception{
Workbook book = createWorkBook(new FileInputStream(excelFile));
if(book == null){//防止跳过页面直接访问报错
tip = "请选择excel格式文件";
return SUCCESS;
}
//book.getNumberOfSheets(); 判断Excel文件有多少个sheet
log.debug(book.getNumberOfSheets());
//获取激活的sheet索引,就是在excel保存时显示的是哪个sheet
log.debug(book.getActiveSheetIndex());
//通过索引获取sheet信息
Sheet sheet = book.getSheetAt(book.getActiveSheetIndex());
// 保存工作单名称
// Row firstRow = sheet.getRow(0);
// Iterator<Cell> iterator = firstRow.iterator();
//保存列名
// List<String> cellNames = new ArrayList<String>();
// while (iterator.hasNext()) {
// cellNames.add(iterator.next().getStringCellValue());
// }
//用于存储用户信息
List<User> users = new ArrayList<User>();
//用于转换为手机号
DecimalFormat df = new DecimalFormat("#");
//遍历用户信息
for (int i = 1;i <=sheet.getLastRowNum();i++){
Row ros = sheet.getRow(i);
try {
User u = new User();
u.setName(ros.getCell(0).getStringCellValue());
String phone = df.format(ros.getCell(1).getNumericCellValue());
u.setPhone(phone.trim());
u.setEmail(ros.getCell(2).getStringCellValue());
u.setCompany(ros.getCell(3).getStringCellValue());
users.add(u);
} catch (Exception e){
e.printStackTrace();
}
}
return SUCCESS;
}
public File getExcelFile() {
return excelFile;
}
public void setExcelFile(File excelFile) {
this.excelFile = excelFile;
}
public String getExcelFileName() {
return excelFileName;
}
public void setExcelFileName(String excelFileName) {
this.excelFileName = excelFileName;
}
public User getUser() {
return user;
}
public void setUser(User user) {
this.user = user;
}
}
上面的代码已经很清楚的教给大家怎么使用了。
在读取excel数据列是最好要判断每一列的类型,如有手机号列就在读取是就要调用Cell.getNumericCellValue();方法,否则就会报错。我做的这个excel文件里的每一列都是固定的,所以我就没有加判断。
希望能给大家一些帮助,如果有什么问题可以给我留言。
分享到:
相关推荐
poi struts2 Excel导入数据库 用jdbc连的sql server2000 非常简单 一看就能明白怎么个回事 就一张表 3个字段 适合第一次用poi的朋友
java运用poi把excel数据导入到oracle数据库中,上场内容未自己写的小demo,可下载查看,不清楚的可以联系我进行帮助。
struts1 poi Excel批量导入支持xls和xlsx-源码java 有需要的能帮助到
利用 Apache POI 对 excel 操作并存入MySQL数据库的一个小demo。
这个是使用java语言 poi导入excel到数据库中,同时使用了xml对excel的每个单元格数据进行了非空验证。经测试,导入数据库成功。
java_poi实现excel导入导出功能,有详细的注解
使用poi解析excel文件,并将数据写入到数据库 项目说明 这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL...
Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出Java POI EXCEL导入导出...
程序使用Struts2(SSH即Struts2+Hibernate+Spring)+POI+MySQL实现Excel动态数据导入和导出,程序源码文件附带运行说明
该工具类是poi基于事件驱动去读取海量excel数据,解决内存溢出以及空单元格的问题。 该压缩包里面有两个文件,TestExcel.java主要是原始的处理方法,操作简单,适合小数据量的读取。 ExampleEventUserModelUtil.java...
java实现excel的导入导出(poi详解),经过测试poi效率要比jxl要高很多,特别是数据量大的时候jxl根本无法用肉眼入目,本资源是个可运行项目demo,很有参考价值!
java POI完整示例,POI将word转HTML,数据库倒出数据到Excel等
Java通过POI读取Excel遍历数据,根本word模板批量生成word文档,demo可运行,可根据需求修改
1、POI_EXCEL包下分别有两个类,一个是读取excel内容,一个是想excel写入内容 2、cn.itcast包下的所有包,是为了实现从excel写入到数据库中,和从数据库写入到excel中 注意事项: 1、需要导入maven工程 2、使用...
java读取excel 表格数据。 public static void main(String[] args) { String[][] content=POIExcelUtils.read("E:\\1.xlsx"); for(int i=0;i;i++) { if(content[i]!=null){ for(int j=0;j[i].length;j...
Java使用poi实现excel导入导出,导入导出已做成通用方法,内附说明文档
java-poi导入excel文件内容到数据库,导出数据库内容到本地excel
Java POI根据模板生成Excel文件并写入磁盘,资源文件仅为实现的简单测试Demo,并没有进行代码优化,可以直接导入运行,资源文件仅供参考。
前几天项目上需要加上导入导出,在网上找了一下,么有...于是自己写,源码里所需要的jar都有,从jsp界面进行Excel的导入导出,并可用于上传和下载。如有所用,喜不自禁,分享,开源的意义。 写的不是特别好,不喜勿喷!