java - 读取,导出 excel文件数据
首先需下载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文件数据的更多相关文章
- java POI导出Excel文件数据库的数据
在web开发中,有一个经典的功能,就是数据的导入导出.特别是数据的导出,在生产管理或者财务系统中用的非常普遍,因为这些系统经常要做一些报表打印的工作.这里我简单实现导出Excel文件. POI jar ...
- java 实现导出Excel文件
java 实现导出Excel(java生成 excel 并导出文件) 经常有有一些数据需要导出成 excel 格式 ,所以就需要实现啦 开始: 1.加入jar poi-3.6-20091214. ...
- Java:导出Excel大批量数据的优化过程
背景 团队目前在做一个用户数据看板(下面简称看板),基本覆盖用户的所有行为数据,并生成分析报表,用户行为由多个数据来源组成(餐饮.生活日用.充值消费.交通出行.通讯物流.交通出行.医疗保健.住房物业. ...
- Java读取批量Excel文件
1.首先基础知识: 原文链接:https://blog.csdn.net/baidu_39298625/article/details/105842725 一 :简介 开发中经常会设计到excel的处 ...
- java导入导出Excel文件
package poi.excel; import java.io.IOException; import java.io.InputStream; import java.io.OutputStre ...
- java poi 导出Excel文件
1,导包 poi-3.9-XXX.JAR 2, 创建一个实体对象 public class Student implements Serializable { /** * */ private st ...
- 使用poi读取Excel文件数据
package com.haiyisoft.iecp.util; import java.io.File;import java.io.FileInputStream;import java.io.F ...
- java导入、导出Excel文件
一.介绍 当前B/S模式已成为应用开发的主流,而在企业办公系统中,常常有客户这样子要求:你要把我们的报表直接用Excel打开(电信系统.银行系统).或者是:我们已经习惯用Excel打印.这样在我们实际 ...
- Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类
Java 通过Xml导出Excel文件,Java Excel 导出工具类,Java导出Excel工具类 ============================== ©Copyright 蕃薯耀 20 ...
随机推荐
- VS2015自带v120的Platform Toolset
在VS2015安装组件时,勾选 “Windows 8.1 和 Windows Phone 8.0/8.1”下面的“工具和 Windows SDK”,将会安装Visual Studio 2013 (v1 ...
- python3 on macos with vscode
brew install python3 python3 -m pip install pylint python3 -m pip install autopep8 python3 -m pip in ...
- LCS 的 NlogN作法
这个算法其实是因为LIS有NlogN的作法,把LCS转化为了LIS来做. 对于序列A{},B{},我们可以记录下来B中的每个元素在A中出现的位置,按顺序保存在一个新序列当中, 如果有多个位置按倒序写, ...
- 解决loadrunner在脚本回放时长时间等待及在vugen中create controller scenario时报错的方法!超管用!!
解决loadrunner在脚本回放时长时间等待及在vugen中create controller scenario时报错的方法 经过咨询,有两种方法.经过实践,下面的方法1有效,方法2无效(我下载安装 ...
- Oracle11g数据库监听配置
(转自:http://blog.sina.com.cn/s/blog_6908928501018057.html) 经验告诉我:最好把数据库的SID和数据库全局名称分开,免得配置时混了,如果要配置服务 ...
- Android中SQLite介绍
现在的主流移动设备像Android.iPhone等都使用SQLite作为复杂数据的存储引擎,在我们为移动设备开发应用程序时,也许就要使用到SQLite来存储我们大量的数据,所以我们就需要掌握移动设备上 ...
- Django --- celery异步任务与RabbitMQ模块
一 RabbitMQ 和 celery 1 celery Celery 是一个 基于python开发的分布式异步消息任务队列,通过它可以轻松的实现任务的异步处理, 如果你的业务场景中需要用到异步任务, ...
- Python爬虫----抓取豆瓣电影Top250
有了上次利用python爬虫抓取糗事百科的经验,这次自己动手写了个爬虫抓取豆瓣电影Top250的简要信息. 1.观察url 首先观察一下网址的结构 http://movie.douban.com/to ...
- 【MFC】断言(ASSERT)的用法
摘自:Moondark http://www.cnblogs.com/moondark/archive/2012/03/12/2392315.html 断言(ASSERT)的用法 我一直以为as ...
- Shell 参数(1)
shell 中参数相关: ./a.sh a b c d $# 是传给脚本的参数个数 $0 是脚本本身的名字 $1 是传递给该shell脚本的第一个参数 $2 是传递给该shell脚本的第二个参数 $@ ...