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 ...
随机推荐
- npm的镜像和淘宝互换
1.得到原本的镜像地址 npm get registry > https://registry.npmjs.org/ 设成淘宝的 npm config set registry http://r ...
- socket http read
import java.io.BufferedReader; import java.io.IOException; import java.io.InputStream; import java.i ...
- python基础之继承原理,多态与封装
1.什么是继承? 继承是一种创建新的类的方式.class A: passclass B: pass2.如何继承---->如何寻找继承关系 现实生活中找继承关系是自下而上,在程序中写是自上而下继承 ...
- Some Interview Questions About Python
一大波超链接即将袭来 Django认证流程 Python实现阶乘 Python文件处理 Python统计日志文件IP出现次数 JSON数据解析 JSON数据解析2 买卖股票的最佳时期 读取一个大文件比 ...
- jsp中的session
浏览器和服务器的异常通话 常用方法 setAttribute(String key,Object value);//设置值 getAttribute(String key); //取值 Invalid ...
- lzugis——Arcgis Server for JavaScript API之自定义InfoWindow
各位看到这个标题不要嫌烦,因为本人最近一直在研究相关的问题,所以相关文章也只能是这些,同时希望看过我的文章的朋友,我的文章能够给你帮助. 在前面的两篇相关的文章里面,实现InfoWindow是通过di ...
- js 下获取子元素的方法
笔记核心: firstElementChild只会获取元素节点对象,从名称就可以看出来,firstChild则可以获取文本节点对象(当然也可以获取元素节点对象),比如空格和换行都被当做文本节点. js ...
- 【ACM非算法部分】读入优化
今天做了ACdream的比赛才知道原来还有读入优化这一说.Orz 读入一个整数的时候这么写: int a; scanf("%d",&a); 和 int a; char c; ...
- bzoj 4806 炮
Written with StackEdit. Description 众所周知,双炮叠叠将是中国象棋中很厉害的一招必杀技.炮吃子时必须隔一个棋子跳吃,即俗称"炮打隔子". 炮跟炮 ...
- 记一次愚蠢的gradle操作
今晚把工作移植到mac平台,在用gradle命令 exec ./gradlew --parallel --info assembleDebug 打包apk时卡住,gradle一直处于下载状态,过了几分 ...