java poi导入EXCEL xls文件代码
/**
*
*/
package com.bn.car.common.report.excel; import java.io.FileInputStream;
import java.io.IOException;
import java.io.InputStream;
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 com.bn.car.biz.supply.dto.PartsInfoDTO; /**
* @author huangjing
* @date 2014-1-24
*/
public class XlsMain {
public static void main(String[] args) throws IOException {
try {
XlsMain xlsMain = new XlsMain();
PartsInfoDTO dto = null;
List<PartsInfoDTO> list = xlsMain.readXls("d://parts2.xls");
// System.out.println(list.size());
for (int i = 0; i < list.size(); i++) {
dto = list.get(i);
System.out.println(dto.getPartsCode() +"--"+dto.getPartsName() +"--"+dto.getStoreNum() +"--"+dto.getCostPrice() +"--"+dto.getMarketPrice() +"--"+dto.getRetailPrice() +"--"+dto.getWeight() +"--"+dto.getUpdown());
}
System.out.println("OK!!");
} catch (Exception e) {
// TODO: handle exception
e.printStackTrace();
}
} /**
* 读取xls文件内容
*
* @return List<XlsDto>对象
* @throws IOException
* 输入/输出(i/o)异常
*/
public static List<PartsInfoDTO> readXls(String xlspath) throws IOException {
InputStream is = new FileInputStream(xlspath);
HSSFWorkbook hssfWorkbook = new HSSFWorkbook(is);
PartsInfoDTO dto = null;
List<PartsInfoDTO> list = new ArrayList<PartsInfoDTO>();
// 循环工作表Sheet
for (int numSheet = 0; numSheet < hssfWorkbook.getNumberOfSheets(); numSheet++) {
HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(numSheet);
// System.out.println("hssfSheet:" + hssfSheet);
if (hssfSheet == null) {
continue;
}
// 循环行Row,从第一行开始。
for (int rowNum = 1; rowNum <= hssfSheet.getLastRowNum(); rowNum++) {
HSSFRow hssfRow = hssfSheet.getRow(rowNum);
// System.out.println("hssfRow:"+hssfRow);
if (hssfRow == null) {
continue;
}
dto = new PartsInfoDTO();
// 循环列Cell
// 0学号 1姓名 2学院 3课程名 4 成绩
// for (int cellNum = 0; cellNum <=4; cellNum++) {
HSSFCell cell = hssfRow.getCell(0);
// System.out.println("cell:" + cell);
if (cell == null) {
continue;
}
dto.setPartsCode(getValue(cell)); cell = hssfRow.getCell(1);
// System.out.println("cell1:" + cell);
if (cell == null) {
continue;
}
dto.setPartsName(getValue(cell)); cell = hssfRow.getCell(2);
// System.out.println("cell2:" + cell);
if (cell == null) {
continue;
}
dto.setStoreNum(Float.valueOf(getValue(cell)).intValue()); cell = hssfRow.getCell(3);
// System.out.println("cell3:" + cell);
if (cell == null) {
continue;
}
dto.setCostPrice(Float.valueOf(getValue(cell))); cell = hssfRow.getCell(4);
// System.out.println("cell4:" + cell);
if (cell == null) {
continue;
}
dto.setMarketPrice(Float.parseFloat(getValue(cell))); cell = hssfRow.getCell(5);
// System.out.println("cell5:" + cell);
if (cell == null) {
continue;
}
dto.setRetailPrice(Float.parseFloat(getValue(cell))); cell = hssfRow.getCell(6);
// System.out.println("cell6:" + cell);
if (cell == null) {
continue;
}
dto.setWeight(Float.parseFloat(getValue(cell))); cell = hssfRow.getCell(7); //写成8了,取不到,所以不执行下面的代码~!!
// System.out.println("cell7:" + cell);
if (cell == null) {
continue;
}
if(getValue(cell).equals("是")){
dto.setUpdown(1);
}else{
dto.setUpdown(0);
} // System.out.println("上下架:"+dto.getUpdown());
list.add(dto);
}
}
// System.out.println("SIZE:" + list.size());
return list;
} /**
* 得到Excel表中的值
*
* @param hssfCell
* Excel中的每一个格子
* @return Excel中每一个格子中的值
*/
@SuppressWarnings("static-access")
public static String getValue(HSSFCell hssfCell) {
if (hssfCell.getCellType() == hssfCell.CELL_TYPE_BOOLEAN) {
// 返回布尔类型的值
return String.valueOf(hssfCell.getBooleanCellValue());
} else if (hssfCell.getCellType() == hssfCell.CELL_TYPE_NUMERIC) {
// 返回数值类型的值
return String.valueOf(hssfCell.getNumericCellValue());
} else {
// 返回字符串类型的值
return String.valueOf(hssfCell.getStringCellValue());
}
} }
parts2.xls (导入模板文件~!)
java poi导入EXCEL xls文件代码的更多相关文章
- java poi导出EXCEL xls文件代码
String _currentPage = request.getParameter("currentPage"); Integer currentPage = 0; if(_cu ...
- java poi导入Excel(个人代码)
案例使用的框架:jsp+spring+mybaties <form id="importForm" name="importForm" method=&q ...
- 在java poi导入Excel通用工具类示例详解
转: 在java poi导入Excel通用工具类示例详解 更新时间:2017年09月10日 14:21:36 作者:daochuwenziyao 我要评论 这篇文章主要给大家介绍了关于在j ...
- Java POI导入Excel文件
今天在公司需要做个导入Excel文件的功能,所以研究了一下,参考网上的一些资料总算是做出来了,在此记录一下防止以后忘记怎么弄. 本人用的是poi3.8,所以需要的JAR包如下: poi-3.8.jar ...
- java poi 导入excel
最近项目需要导入excel,网上有很多例子,自己整合记录下,兼容2003和2007,暂时没有添加图片处理功能. 所需jar包 http://pan.baidu.com/s/1sjPuWDR pack ...
- 解决java POI导入Excel超时问题
由于要导入大量数据,后台会耗费很长时间,导致超时. 本项目前端request.js中设定的超时时间为150s. const service = axios.create({ baseURL: base ...
- Java 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包)
ava 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包) 假设现在要做一个通用的导入方法: 要求: 1.xml的只定义数据库表中的column字段,字段类型,是否非空等条件 ...
- java如何导入Excel文件
Java使用POI导入Excel文件,操作起来比较简单,支持xlsx格式. 下载POI资源包 从官网https://poi.apache.org/下载POI,笔者选择的是版本是3.17,下载后文件名是 ...
- 纳税服务系统【用户模块之使用POI导入excel、导出excel】
前言 再次回到我们的用户模块上,我们发现还有两个功能没有完成: 对于将网页中的数据导入或导出到excel文件中,我们是完全没有学习过的.但是呢,在Java中操作excel是相对常用的,因此也有组件供我 ...
随机推荐
- PowerDesigner 工具面板 association,inheritance,association link 不可用 解决方法
PowerDesigner 画E-R 图,关联,继承及关联实体连接不可用. 如图: 解决方法: tools->modeloptions->Notation 改为"E/R+Meri ...
- 济南学习 Day 2 T2 pm
她[问题描述]给你L,R,S,M,求满足L≤ (S × x) mod M ≤ R最小的正整数 X.[输入格式]第一行一个数T代表数据组数.接下来一行每行四个数代表该组数据的L,R,S,M.[输出格式] ...
- AndroidStudio支持新的NDK的操作使用
在2015的Google I / O大会,5月底,谷歌宣布了一项新的支持由Android NDK Studio 1.3,Jetbrains CLion集成功能,Android gradle插件.这种支 ...
- isNotNull与isNotEmpty的区别
<isNotNull> 检查属性是否不为null <isNotEmpty> 检查Collection.size()的值,属性的String或String.valueOf()值, ...
- IOS_修改项目模板
1. /Applications/Xcode.app/Contents/Developer/Library/Xcode/Templates/File\ Templates/Source/Cocoa\ ...
- 通信录分组并且分组标签悬停划入划出(包含错误信息及修改)--第三方开源--PinnedSectionListView
PinnedSectionListView在github上的链接地址是:https://github.com/beworker/pinned-section-listview . 下载下来后直接将Pi ...
- execute连接 类型
set rs=server.createobject("adodb.recordset") sql="select top 10 id,name from tablena ...
- ActiveMQ之deliveryMode
在下面的例子中,分别发送一个Persistent和nonpersistent的消息,然后关闭退出JMS. import javax.jms.Connection;import javax.jms.De ...
- VC2010 MFC文档类菜单快捷键无法加载问题
问题1. 在菜单中项中输入&Run\tF5, 运行显示Run,而不是Run F5. 问题2.在Accelerator中绑定了快捷键,但运行程序不起作用. 以上2中问题在VC++2008和VC+ ...
- session 测试用例详解
http协议是WEB服务器与客户端(浏览器)相互通信的协议,它是一种无状态协议.所谓无状态,指的是不会维护http请求数据,http请求是独立的,非持久的.而越来越复杂的WEB应用,需要保存一些用户状 ...