首先需下载poi java包,添加至构建路径,

写处理方法:

import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.File;
import java.util.*;

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.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 java.awt.AWTException;


 /*************************excel处理程序-开始*******************************************/

    /**
* 获取Excel中的数据(Excel 2003)
* @param file 文件路径
* @param beginCell 开始列
* @param endCell 结束列
* @throws IOException
*/
public static List<List> getExcelValue(String file, int beginCell, int endCell)throws IOException{
InputStream is = new FileInputStream(file);
Workbook workbook = null ;
if(file.endsWith(".xls")){
workbook = new HSSFWorkbook(is);
}else if(file.endsWith(".xlsx")){
workbook = new XSSFWorkbook(is);
} List<List> excelList = new ArrayList<List>(); Sheet sheet = workbook.getSheetAt(0); //操作第一个表格,其他的sheet不管
//按行循环
for(int rownum=0;rownum<=sheet.getLastRowNum();rownum++){
Row row = sheet.getRow(rownum);//获取行 List<String> rowList = new ArrayList<String>(); //每行的数据放一个List里
//每行中按列循环
for(int cellnum=beginCell;cellnum<=endCell;cellnum++){
Cell cell = row.getCell(cellnum); //获取操作的单元格
if(cell != null){ //单元格不为空,则将单元格中数据放入list中
rowList.add(getCellValue(cell));
}else{//单元格为空,则向list中放入空字符串
rowList.add("");
}
}
excelList.add(rowList);//将一行的数据放入excelList中
}
return excelList;
}
// } /**
* 获取Excel中的数据(Excel 2003),未传递开始与结尾的列数,所以获取所有
* @param file 文件路径
* @throws IOException
*/
public static List<List> getExcelValue(String file)throws IOException{
InputStream is = new FileInputStream(file);
Workbook workbook = null ;
if(file.endsWith(".xls")){
workbook = new HSSFWorkbook(is);
}else if(file.endsWith(".xlsx")){
workbook = new XSSFWorkbook(is);
} List<List> excelList = new ArrayList<List>(); Sheet sheet = workbook.getSheetAt(0); //操作第一个表格,其他的sheet不管
//按行循环
for(int rownum=0;rownum<=sheet.getLastRowNum();rownum++){
Row row = sheet.getRow(rownum);//获取行
int beginCell = 0;
int endCell = sheet.getRow(0).getPhysicalNumberOfCells();//获取该表格中最大列数 List<String> rowList = new ArrayList<String>(); //每行的数据放一个List里
//每行中按列循环
for(int cellnum=beginCell;cellnum<=endCell;cellnum++){
Cell cell = row.getCell(cellnum); //获取操作的单元格
if(cell != null){ //单元格不为空,则将单元格中数据放入list中
rowList.add(getCellValue(cell));
}else{//单元格为空,则向list中放入空字符串
rowList.add("");
}
}
excelList.add(rowList);//将一行的数据放入excelList中
}
return excelList;
}
// } private static String getCellValue(Cell cell) {
if (cell.getCellType() == cell.CELL_TYPE_BOOLEAN) {
// 返回布尔类型的值
return String.valueOf(cell.getBooleanCellValue());
} else if (cell.getCellType() == cell.CELL_TYPE_NUMERIC) {
// 返回数值类型的值
return String.valueOf((int)cell.getNumericCellValue());
} else {
// 返回字符串类型的值
return String.valueOf(cell.getStringCellValue());
}
} /**
* 当List<List> 内容写入Excel中
* @param dataList
*/
public static void writeExcel(List<List> dataList, String filePath){
try{
FileOutputStream os = new FileOutputStream(filePath); HSSFWorkbook workbook = new HSSFWorkbook();
HSSFSheet sheet = workbook.createSheet();
HSSFRow row = sheet.createRow(0); //行
HSSFCell cell = row.createCell(0); //列 //将所有数据以行为单位的进行循环
for(int i=0; i<dataList.size(); i++){ //循环行
List rowList = dataList.get(i);
row = sheet.createRow(i); //将某行的所有数据以单元格为单位进行循环
for(int j=0; j<rowList.size(); j++){ //循环列
String cellValue = String.valueOf(rowList.get(j)); //获取某单元格内容
cell = row.createCell(j); //创建对应的单元格
cell.setCellValue(cellValue); //写入内容
}
}
workbook.write(os);
os.flush();
os.close(); }catch (Exception e) {
e.printStackTrace();
}
}
/*************************excel处理程序-结束*******************************************/

使用:

writeExcel(csyl_dataList, test_report_FilePath); //输出excel文件

java - 读取,导出 excel文件数据的更多相关文章

  1. java POI导出Excel文件数据库的数据

    在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.这里我简单实现导出Excel文件. POI jar ...

  2. java 实现导出Excel文件

    java 实现导出Excel(java生成 excel 并导出文件) 经常有有一些数据需要导出成   excel  格式 ,所以就需要实现啦 开始: 1.加入jar poi-3.6-20091214. ...

  3. Java:导出Excel大批量数据的优化过程

    背景 团队目前在做一个用户数据看板(下面简称看板),基本覆盖用户的所有行为数据,并生成分析报表,用户行为由多个数据来源组成(餐饮.生活日用.充值消费.交通出行.通讯物流.交通出行.医疗保健.住房物业. ...

  4. Java读取批量Excel文件

    1.首先基础知识: 原文链接:https://blog.csdn.net/baidu_39298625/article/details/105842725 一 :简介 开发中经常会设计到excel的处 ...

  5. java导入导出Excel文件

    package poi.excel; import java.io.IOException; import java.io.InputStream; import java.io.OutputStre ...

  6. java poi 导出Excel文件

    1,导包  poi-3.9-XXX.JAR 2, 创建一个实体对象 public class Student implements Serializable { /** * */ private st ...

  7. 使用poi读取Excel文件数据

    package com.haiyisoft.iecp.util; import java.io.File;import java.io.FileInputStream;import java.io.F ...

  8. java导入、导出Excel文件

    一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已经习惯用Excel打印.这样在我们实际 ...

  9. Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类

    Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类 ============================== ©Copyright 蕃薯耀 20 ...

随机推荐

  1. 数据库设计系列之四--ER图

    逻辑设计是做什么? 1.将需求转化为数据库的逻辑模型 2.通过ER图的型式对逻辑模型进行展示 3.同所选用的具体的DBMS系统无关

  2. LeetCode OJ:Maximum Product Subarray(子数组最大乘积)

    Find the contiguous subarray within an array (containing at least one number) which has the largest ...

  3. AutoLayout 使用详细

    1.实际应用中,这Compact,Any,Regular如何运用呢? w:Any h:Any 是我们刚建立工程时候默认选择的,算是一切描述的父类.其他的种类描述都是在此基础上变化的,比如:如果weig ...

  4. 安装nodejs+npm的体验

    NODEJS.NPM安装配置步骤(WINDOWS版本) 1.windows下的NodeJS安装是比较方便的(v0.6.0版本之后,支持windows native),只需要登陆官网(http://no ...

  5. matlab批量转化img到gray

    path = 'D:\宝贝儿数据集\COIL-3D\coil-100\'; save_path = 'D:\宝贝儿数据集\COIL-3D\coil-100-gray\'; file=dir([path ...

  6. Ubuntu安装最新版的nodejs

    安装玩Ubuntu的虚拟机之后安装nodejs发现npm的版本才3.5.2,这都多老了?于是Google了一下,发现是由于Ubuntu官方维护的包源太老了,想要安装nodejs的最新版,两种方法,一种 ...

  7. 一个高性能RPC框架的连接管理

    既然说连接,先对EpollServer的连接管理做个介绍吧.客户端与服务器一次conn,被封装成为Connection类在服务器进行管理. 服务器连接有三种类型,分别为: enum EnumConne ...

  8. Ubuntu 16.04 为 PHP7 添加 memcached 以及 redis 扩展

    切换到 PHP 7 之后,网站的速度大幅提升,不过通常的扩展可能某一个就还没有支持 PHP7 Memcached 比如说我现在使用了最新的 Ubuntu 16.04,虽然内置了 PHP 7 源,但 m ...

  9. php之opcodes

    opcode是一种php脚本编译之后的语言. 例如: <?php echo "Hello World"; $a = 1 + 1; echo $a; ?> php执行这段 ...

  10. 常用的两个PHP类

      /** * Class Interval * @author logonmy * @desc 简单分析程序执行时间: */   Class Interval{ var $start;   publ ...