java利用poi来读取execl表格返回对象
利用poi来读取execl表格,返回一个对象(可能有点不完善,但是应该能满足平常的所用),用到了反射等等;
使用的jar包有:
commons-collections4-4.1.jar
poi-3.17.jar
poi-ooxml.3.17.jar
poi-ooxml-schemas.3.17.jar
xmllbeans-2.6.0.jar
/**
* 静态属性包
* @author Administrator
*
*/
public class Common {
public static final String OFFICE_EXCEL_2003_POSTFIX = "xls";
public static final String OFFICE_EXCEL_2010_POSTFIX = "xlsx";
public static final String EMPTY = "";
public static final String POINT = ".";
public static final String LIB_PATH = "lib";
/*public static final String STUDENT_INFO_XLS_PATH = LIB_PATH + "/student_info" + POINT + OFFICE_EXCEL_2003_POSTFIX;
public static final String STUDENT_INFO_XLSX_PATH = LIB_PATH + "/student_info" + POINT + OFFICE_EXCEL_2010_POSTFIX;*/
public static final String NOT_EXCEL_FILE = " : Not the Excel file!";
public static final String PROCESSING = "Processing...";
}
import java.lang.reflect.Field;
/**
* 工具包
* @author Administrator
*
*/
public class Util {
public static String getPostfix(String path) {
if (path == null || Common.EMPTY.equals(path.trim())) {
return Common.EMPTY;
}
if (path.contains(Common.POINT)) {
return path.substring(path.lastIndexOf(Common.POINT) + 1, path.length());
}
return Common.EMPTY;
}
// 获取属性的类型
public static String getFileType(Field field) {
// 如果类型是String
if (field.getGenericType().toString().equals("class java.lang.String")) { // 如果type是类类型,则前面包含"class
return "String";
}
// 如果类型是String
if (field.getGenericType().toString().equals("int")) { // 如果type是类类型,则前面包含"class
return "int";
}
// 如果类型是String
if (field.getGenericType().toString().equals("double")) { // 如果type是类类型,则前面包含"class
return "double";
}
// 如果类型是Integer
if (field.getGenericType().toString().equals("class java.lang.Integer")) {
return "Integer";
}
// 如果类型是Double
if (field.getGenericType().toString().equals("class java.lang.Double")) {
return "Double";
}
// 如果类型是Boolean 是封装类
if (field.getGenericType().toString().equals("class java.lang.Boolean")) {
return "Boolean";
}
// 如果类型是boolean 基本数据类型不一样 这里有点说名如果定义名是 isXXX的 那就全都是isXXX的
if (field.getGenericType().toString().equals("boolean")) {
return "boolean";
}
// 如果类型是Date
if (field.getGenericType().toString().equals("class java.util.Date")) {
return "Date";
}
// 如果类型是Short
if (field.getGenericType().toString().equals("class java.lang.Short")) {
return "Short";
}
return "null";
}
}
import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFRow;
import org.apache.poi.hssf.usermodel.HSSFSheet;
import org.apache.poi.hssf.usermodel.HSSFWorkbook;
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;
/**
* 由于jxl停止更新,因此使用poi来进行excel的表格的读入
*
* @author Administrator
*
*/
public class ReadExcel {
public List<Object> readExcel(String path, Object o) throws IOException {
if (path == null || Common.EMPTY.equals(path)) {
return null;
} else {
String postfix = Util.getPostfix(path);
if (!Common.EMPTY.equals(postfix)) {
if (Common.OFFICE_EXCEL_2003_POSTFIX.equals(postfix)) {
return readXls(path, o);
} else if (Common.OFFICE_EXCEL_2010_POSTFIX.equals(postfix)) {
return readXlsx(path, o);
}
} else {
System.out.println(path + Common.NOT_EXCEL_FILE);
}
}
return null;
}
@SuppressWarnings("resource")
public List<Object> readXlsx(String path, Object object) throws IOException {
System.out.println(Common.PROCESSING + path);
InputStream is = new FileInputStream(path);
XSSFWorkbook xssfWorkbook = new XSSFWorkbook(is);
List<Object> list = new ArrayList<Object>();
// Read the Sheet
for (int numSheet = 0; numSheet < xssfWorkbook.getNumberOfSheets(); numSheet++) {
XSSFSheet xssfSheet = xssfWorkbook.getSheetAt(numSheet);
if (xssfSheet == null) {
continue;
}
// Read the Row
for (int rowNum = 1; rowNum <= xssfSheet.getLastRowNum(); rowNum++) {
XSSFRow xssfRow = xssfSheet.getRow(rowNum);
if (xssfRow != null) {
// 根据反射获取对象的属性名
String[] str = getFiledName(object);
for (int i = 0; i < str.length; i++) {
try {
// 根据对象的属性名来给对象赋值
Field f = object.getClass().getDeclaredField(str[i]);
// 设置对象属性可见
f.setAccessible(true);
XSSFCell temp = xssfRow.getCell(i);
// 赋值
String type = Util.getFileType(f);
if(type.equals("String")) {
f.set(object, temp.getStringCellValue());
} else if(type.equals("Integer")) {
f.set(object, (int)(temp.getNumericCellValue()));
} else if(type.equals("int")) {
f.set(object, (int)(temp.getNumericCellValue()));
} else if(type.equals("double")) {
f.set(object,(temp.getNumericCellValue()));
} else if(type.equals("Double")) {
f.set(object, (temp.getNumericCellValue()));
} else if(type.equals("boolean")) {
f.set(object, (temp.getBooleanCellValue()));
} else if(type.equals("Boolean")){
f.set(object, (temp.getBooleanCellValue()));
} else if(type.equals("Date")) {
f.set(object, (temp.getDateCellValue()));
} else {
f.set(object, temp.getStringCellValue());
}
} catch (Exception e) {
e.printStackTrace();
}
}
try {
// 拷贝Object对象
Class<?> fromClass = object.getClass();
// 获取属性名
Field[] fromFields = fromClass.getDeclaredFields();
// 创建拷贝的对象
Object ints = null;
// 赋值拷贝的对象
ints = fromClass.newInstance();
for(Field fromField : fromFields) {
fromField.setAccessible(true);
fromField.set(ints, fromField.get(object));
}
list.add(ints);
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
}
}
return list;
}
public List<Object> readXls(String path, Object object) throws IOException {
System.out.println(Common.PROCESSING + path);
InputStream is = new FileInputStream(path);
@SuppressWarnings("resource")
HSSFWorkbook hssfWorkbook = new HSSFWorkbook(is);
List<Object> list = new ArrayList<Object>();
// Read the Sheet
for (int numSheet = 0; numSheet < hssfWorkbook.getNumberOfSheets(); numSheet++) {
HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(numSheet);
if (hssfSheet == null) {
continue;
}
// Read the Row
for (int rowNum = 1; rowNum <= hssfSheet.getLastRowNum(); rowNum++) {
HSSFRow hssfRow = hssfSheet.getRow(rowNum);
if (hssfRow != null) {
// 根据反射获取对象的属性名
String[] str = getFiledName(object);
for (int i = 0; i < str.length; i++) {
try {
// 根据对象的属性名来给对象赋值
Field f = object.getClass().getDeclaredField(str[i]);
// 设置对象属性可见
f.setAccessible(true);
HSSFCell temp = hssfRow.getCell(i);
// 赋值
// 赋值
String type = Util.getFileType(f);
if(type.equals("String")) {
f.set(object, temp.getStringCellValue());
} else if(type.equals("Integer")) {
f.set(object, (int)(temp.getNumericCellValue()));
} else if(type.equals("int")) {
f.set(object, (int)(temp.getNumericCellValue()));
} else if(type.equals("double")) {
f.set(object,(temp.getNumericCellValue()));
} else if(type.equals("Double")) {
f.set(object, (temp.getNumericCellValue()));
} else if(type.equals("boolean")) {
f.set(object, (temp.getBooleanCellValue()));
} else if(type.equals("Boolean")){
f.set(object, (temp.getBooleanCellValue()));
} else if(type.equals("Date")) {
f.set(object, (temp.getDateCellValue()));
} else {
f.set(object, temp.getStringCellValue());
}
} catch (Exception e) {
e.printStackTrace();
}
}
try {
// 拷贝Object对象
Class<?> fromClass = object.getClass();
// 获取属性名
Field[] fromFields = fromClass.getDeclaredFields();
// 创建拷贝的对象
Object ints = null;
// 赋值拷贝的对象
ints = fromClass.newInstance();
for(Field fromField : fromFields) {
fromField.setAccessible(true);
fromField.set(ints, fromField.get(object));
}
list.add(ints);
} catch (Exception e1) {
// TODO Auto-generated catch block
e1.printStackTrace();
}
}
}
}
return list;
}
@SuppressWarnings("unused")
private String[] getFiledName(Object o) {
Field[] fields = o.getClass().getDeclaredFields();
String[] fieldNames = new String[fields.length];
for (int i = 0; i < fields.length; i++) {
fieldNames[i] = fields[i].getName();
}
return fieldNames;
}
}
下面利用student来示范一下
/**
* 实体类
* @author Administrator
*
*/
public class Student{
/**
* id
*/
private int id;
/**
* 姓名
*/
private String name;
/**
* 性别
*/
private String sex;
/**
* 年龄
*/
private int age;
/**
* 职位
*/
private String title;
public Student() {
super();
}
public int getId() {
return id;
}
public void setId(int id) {
this.id = id;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public String getSex() {
return sex;
}
public void setSex(String sex) {
this.sex = sex;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public String getTitle() {
return title;
}
public void setTitle(String title) {
this.title = title;
}
@Override
public String toString() {
return "Student [id=" + id + ", name=" + name + ", sex=" + sex + ", age=" + age + ", title=" + title + "]";
}
}
import java.io.IOException;
import java.util.List;
/**
* 测试类
* @author Administrator
*
*/
public class TestDemo {
public static void main(String[] args) throws IOException {
String excel2010 = "H:\\MyTest\\Java\\test.xls";
// read the 2010 excel
Student student = new Student();
List<Object> list1 = new ReadExcel().readExcel(excel2010,student);
if (list1 != null) {
for (Object o : list1) {
Student s = (Student)o;
System.out.println(s);
}
}
}
}
大家有问题的可以私加我qq:2585700076
java利用poi来读取execl表格返回对象的更多相关文章
- java利用poi生成/读取excel表格
1.引入jar包依赖 <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi< ...
- java利用POI实现读取Word并获取指定样式的文本
import org.apache.poi.hwpf.HWPFDocument; import org.apache.poi.hwpf.model.StyleDescription; import o ...
- JAVA 使用 POI进行读取Excel表格示例
导包 编码 public class PoiTest { /** * 最终效果 * 表头一内容0 表头二内容1 表头三内容2 表头一内容1 表头二内容2 表头三内容3 表头一内容2 表头二内容3 表头 ...
- 利用poi来向execl中写入对象
附上jar包下载链接: 附上百度网盘下载连接: 链接:https://pan.baidu.com/s/1t_jXUq3CuhZo9j_UI4URAQ 密码:r2qi package com.wz.po ...
- Java利用poi生成word(包含插入图片,动态表格,行合并)
转(小改): Java利用poi生成word(包含插入图片,动态表格,行合并) 2018年12月20日 09:06:51 wjw_11093010 阅读数:70 Java利用poi生成word(包含插 ...
- Java读取Execl表格数据
在前面提到用java代码新建一个Execl 表格并添加数据到表格中, 这次写了一个读取Execl表格数据并添加导数据库中的案列 给定对方一个Execl模板表格,如果导入的Execl表格和预订的表格不相 ...
- java 利用POI 读取Execel数据的真实行数
java 利用poi 读execel文件的操作,读取总的数据行数一般是通过调用 sheet.getLastRowNum() ;可是这样有时候会出现一些问题,例如,当其中一行的数据的确都为空,可是其原本 ...
- 利用POI工具读取word文档并将数据存储到sqlserver数据库中
今天实现了利用POI工具读取word文档,并将数据存储到sql数据库中,代码如下: package word; import java.io.File; import java.io.FileInpu ...
- java的poi技术读取Excel数据到MySQL
这篇blog是介绍java中的poi技术读取Excel数据,然后保存到MySQL数据中. 你也可以在 : java的poi技术读取和导入Excel了解到写入Excel的方法信息 使用JXL技术可以在 ...
随机推荐
- 使用Python的requests模块编写请求脚本
requests模块可用来编写请求脚本. 比如,使用requests的post函数可以模拟post请求: resp = requests.post(url, data = content) url即为 ...
- Hibernate学习笔记三 多表
一对多|多对一 表中的表达 实体中的表达 实体代码: package com.yyb.domain; import java.util.HashSet; import java.util.Set; p ...
- W班-项目选题报告成绩
作业链接 https://edu.cnblogs.com/campus/fzu/FZUSoftwareEngineering1715W/homework/907 作业要求 1份团队选题报告(word电 ...
- 个人总结——Beta阶段
Beta总结 我们在beta 结束之后, 每位写一个博客, 回顾并总结自己的beta过程,哪些方面做的好的,哪些方面做得不足需要改进的 回答问题 分析在Alpha阶段自己提出的五个问题,针对每个问题, ...
- 20155306 2017-2018-1《信息安全系统设计》第二周课堂测试以及myod的实现
20155306 2017-2018-1<信息安全系统设计>第二周课堂测试以及myod的实现 第二周课堂测验: (注:前两项在课堂已提交,在此不做详解) 第一项: 每个.c一个文件,每个. ...
- 201621123060《JAVA程序设计》第一周学习总结
1.本周学习总结 1.讲述了JAVA的发展史,关于JDK.JRE.JVM的联系和区别 2.JDK是用JAVA开发工具.做项目的关键.JRE是JAVA的运行环境(JAVA也是JAVA语言开发的).JVM ...
- TOTP算法 基于时间的一次性密码
/** Copyright (c) 2011 IETF Trust and the persons identified as authors of the code. All rights rese ...
- [Redis源码阅读]redis持久化
作为web开发的一员,相信大家的面试经历里少不了会遇到这个问题:redis是怎么做持久化的? 不急着给出答案,先停下来思考一下,然后再看看下面的介绍.希望看了这边文章后,你能够回答这个问题. 为什么需 ...
- jQuery 文档操作之prepend() 和prependTo()方法.
//prepend() $("#btnpre").click(function(){ //该方法在被选元素的开头(仍位于内部)插入指定内容. $("div"). ...
- 【转】支持向量机(SVM)
什么是支持向量机(SVM)? SVM 是一种有监督的机器学习算法,可用于分类或回归问题.它使用一种称为核函数(kernel)的技术来变换数据,然后基于这种变换,算法找到预测可能的两种分类之间的最佳边界 ...