/**
*
*/
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文件代码的更多相关文章

  1. java poi导出EXCEL xls文件代码

    String _currentPage = request.getParameter("currentPage"); Integer currentPage = 0; if(_cu ...

  2. java poi导入Excel(个人代码)

    案例使用的框架:jsp+spring+mybaties <form id="importForm" name="importForm" method=&q ...

  3. 在java poi导入Excel通用工具类示例详解

    转: 在java poi导入Excel通用工具类示例详解 更新时间:2017年09月10日 14:21:36   作者:daochuwenziyao   我要评论   这篇文章主要给大家介绍了关于在j ...

  4. Java POI导入Excel文件

    今天在公司需要做个导入Excel文件的功能,所以研究了一下,参考网上的一些资料总算是做出来了,在此记录一下防止以后忘记怎么弄. 本人用的是poi3.8,所以需要的JAR包如下: poi-3.8.jar ...

  5. java poi 导入excel

    最近项目需要导入excel,网上有很多例子,自己整合记录下,兼容2003和2007,暂时没有添加图片处理功能. 所需jar包  http://pan.baidu.com/s/1sjPuWDR pack ...

  6. 解决java POI导入Excel超时问题

    由于要导入大量数据,后台会耗费很长时间,导致超时. 本项目前端request.js中设定的超时时间为150s. const service = axios.create({ baseURL: base ...

  7. Java 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包)

    ava 使用poi导入excel,结合xml文件进行数据验证的例子(增加了jar包) 假设现在要做一个通用的导入方法: 要求: 1.xml的只定义数据库表中的column字段,字段类型,是否非空等条件 ...

  8. java如何导入Excel文件

    Java使用POI导入Excel文件,操作起来比较简单,支持xlsx格式. 下载POI资源包 从官网https://poi.apache.org/下载POI,笔者选择的是版本是3.17,下载后文件名是 ...

  9. 纳税服务系统【用户模块之使用POI导入excel、导出excel】

    前言 再次回到我们的用户模块上,我们发现还有两个功能没有完成: 对于将网页中的数据导入或导出到excel文件中,我们是完全没有学习过的.但是呢,在Java中操作excel是相对常用的,因此也有组件供我 ...

随机推荐

  1. eclipse maven spring +spring mvc mybatis

    http://yuanmomo.net/archives/449 http://www.tuicool.com/articles/feqUJz http://wenku.baidu.com/link? ...

  2. MiZ702学习笔记12——封装一个普通的VGA IP

    还记得<MiZ702学习笔记(番外篇)--纯PL VGA驱动>这篇文章中,用verilog写了一个VGA驱动.我们今天要介绍的就是将这个工程打包成一个普通的IP,目的是为后面的一篇文章做个 ...

  3. 关于MD5加密的小知识

    - (NSString *)MD5Hash { const char *cStr = [self UTF8String]; unsigned char result[16]; CC_MD5(cStr, ...

  4. jQuery插件使用大全

    1.jQuery datepicker日历插件使用说明 http://wenku.baidu.com/view/12804e1e59eef8c75fbfb3e3 2.jqueryFileUpload插 ...

  5. JQuery 表格 隔行换色 和鼠标滑过的样式

    $(document).ready(function () { $(".Pub_TB tbody tr:even td").css("background-color&q ...

  6. .Net中的Socket通讯

    .NetFrameWork为Socket通讯提供了System.Net.Socket命名空间,在这个命名空间里面有以下几个常用的重要类分别是: ·Socket类 这个低层的类用于管理连接,WebReq ...

  7. How to add EDT relation table[AX2012]

    setp 1. First create New Edit. setp 2.Create New Table First Table Name is NParentRel then drag and ...

  8. Linux环境下Python的安装过程

    Linux环境下Python的安装过程 前言 一般情况下,Linux都会预装 Python了,但是这个预装的Python版本一般都非常低,很多 Python的新特性都没有,必须重新安装新一点的版本,从 ...

  9. 【笔记】W3C CSS关键属性

    white-space属性: white-space 属性设置如何处理元素内的空白. 可能的值 值 描述 normal 默认值,合并所有空格,换行符会被浏览器忽略 pre 空白会被浏览器保留.其行为方 ...

  10. java之其它命令

    java编译命令 javac: javac -d <目录> 源文件.java 指定存放生成的class文件的路径命令行下编译带包名的java源文件: javac -d . XX.java ...