import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.util.ArrayList;
import java.util.List;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
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;
public class PoiExcelUtil {
/**
* 获取Excel文件的内容
* @param in 文件流
* @param isXls xls 或 Xlsx
* @return
*/
public static List<String[]> readExcel(InputStream in, boolean isXls) {
List<String[]> list = new ArrayList<String[]>();
Workbook workbook = null;
try {
if (isXls) {
workbook = new HSSFWorkbook(in);//97-2003 Excel工作簿对象
} else {
workbook = new XSSFWorkbook(in);//2007 Excel工作簿对象
}
for (int i = 0; i < workbook.getNumberOfSheets(); i++) {
Sheet sheet = workbook.getSheetAt(i);//Excel工作表对象
for (int j = sheet.getFirstRowNum(); j <= sheet.getLastRowNum(); j++) {
if(j == 0){
continue;//跳过Header
}
Row row = sheet.getRow(j);//Excel工作表的行
String[] cellValues = new String[row.getLastCellNum()];
for (int k = row.getFirstCellNum(); k < row.getLastCellNum(); k++) {
Cell cell = row.getCell(k, Row.RETURN_BLANK_AS_NULL);//Excel工作表指定行的单元格
if(null == cell){
cellValues[k] = "";
}else{
//判断单元格值类型
switch(cell.getCellType()){
case Cell.CELL_TYPE_STRING://字符串类型
cellValues[k] = cell.getRichStringCellValue().getString();
break;
case Cell.CELL_TYPE_NUMERIC://数值类型
if(HSSFDateUtil.isCellDateFormatted(cell)){
cellValues[k] = cell.getDateCellValue().toString();
}else{
DecimalFormat decimalFormat = new DecimalFormat("#");
cellValues[k] = decimalFormat.format(cell.getNumericCellValue());
}
break;
case Cell.CELL_TYPE_FORMULA://公式
cellValues[k] = cell.getCellFormula();
break;
case Cell.CELL_TYPE_ERROR|Cell.CELL_TYPE_BLANK:
cellValues[k] = "";
break;
case Cell.CELL_TYPE_BOOLEAN:
cellValues[k] = String.valueOf(cell.getBooleanCellValue());
break;
default:
cellValues[k] = "";
}
}
}
list.add(cellValues);
}
}
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
return list;
}
public static void main(String[] args) {
File file = new File("C:\\Users\\Administrator\\Desktop\\LOLO DATA\\majia20150515.xls");
boolean isXls = file.getName().endsWith(".xls")||file.getName().endsWith(".XLS");
InputStream in = null;
try {
in = new FileInputStream(file);
} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
List<String[]> list = PoiExcelUtil.readExcel(in, isXls);
for(Object[] obj : list){
StringBuffer buffer = new StringBuffer();
for (Object object : obj) {
buffer.append(object).append(" ");
}
System.out.println(buffer.toString());
}
System.out.println("list size : " + list.size());
}
}
- 浏览: 59818 次
- 性别:
- 来自: 武汉
最新评论
-
sd445419855:
有一个小坑,Calendar.HOUR, 是设置 12 小时制 ...
获取年、季度、周的开始日期和结束日期工具类 -
Saro:
尝试下Joda-Time或者JAVA8吧。
获取年、季度、周的开始日期和结束日期工具类 -
hardneedl:
是时候用JAVA 8 新的日期时间类了
获取年、季度、周的开始日期和结束日期工具类 -
Asia1752:
[/img][/img][/img][/img][/img][ ...
在Eclipse中部署Maven项目的几种方法 -
HogwartsRow:
FLFLFLFLFLS 写道 5555555
什么情况,需要帮 ...
文本编辑器(KindEditor v.4x)使用说明书
相关推荐
Java读取Excel内容 v Java读取Excel内容 Java读取Excel内容
3. **读取Excel文件**: 使用Apache POI,我们可以通过`XSSFWorkbook`(对于.xlsx)或`HSSFWorkbook`(对于.xls)来打开Excel文件。以下是一个简单的示例: ```java Workbook workbook = new XSSFWorkbook(new ...
操作Excel工具类,导出Excel方法,读取Excel中的数据,导入导出采用excel2003 版本
在VB6.0环境下,开发人员经常需要处理与Excel数据的交互,比如读取Excel文件中的内容。这个“读取Excel内容实例VB6.0源代码”提供的就是一个实用的示例,帮助开发者快速掌握如何利用Visual Basic 6.0来读取Excel文件...
ReadExcelUtil 工具类提供了多种方法来读取 Excel 文件,包括读取指定Sheet的记录行数、读取指定行的内容等。 打开 Excel 文件 首先,需要打开 Excel 文件,通过 open() 方法可以实现这一步骤,该方法将读取 Excel...
在Java编程中,`util_ExcelUtils`工具类是一个用于操作Excel文件的实用程序类,它可以帮助开发者方便地读取Excel文件中的数据以及生成新的Excel文件。Excel文件通常被广泛用于数据存储、报告生成和数据分析等领域,...
读取环境为Win10+VS2015,个人参考资料封装的excel读取模块用来读取Excel2007中的数据,文件为压缩文件,亲测可用。
在SQL Server中,直接读取Excel文件是一种常见的需求,特别是在数据整合、分析或者报表生成时。标题和描述中提到的方法允许我们避免将Excel数据导入到数据库中,而是直接在SQL Server中对Excel文件进行查询或处理。...
创建一个名为 OfficeUtils 的工具类,该类提供了读取 Excel 文件的方法。该类使用 Apache POI 库读取 Excel 文件,并将数据存储在 Map 中。 ```java public class OfficeUtils { protected static final Logger ...
在本场景中,我们将探讨如何在Winform应用中读取Excel文件,包括表名和内容。这里使用的开发工具是Visual Studio 2010,它支持.NET Framework 4.0,这使得我们可以利用Microsoft Office Interop库来操作Excel文件。 ...
标题"脱离Office读取Excel表工具"指出我们的目标是创建一个独立于Microsoft Office环境的解决方案,用于读取Excel文件。这通常涉及到使用第三方库或者API,以便在没有Office组件的环境中也能实现文件的读取和操作。 ...
"Delphi7 读取 Excel 文件" Delphi7 是一个功能强大的开发环境,它提供了多种方式来读取 Excel 文件。在本文中,我们将介绍使用 OLE 和 Excel Application 读取 Excel 文件的方法。 使用 OLE 读取 Excel 文件 ...
java读取Excel文件中多个sheet,生成xml格式的文件
在C++中,读取Excel数据通常涉及到使用OLE Automation(对象链接和嵌入自动化)技术,这是一种允许不同应用程序之间交互的方式。在这个特定的例子中,我们使用Microsoft Visual Studio 2003 MFC(Microsoft ...
在Java编程中,读取Excel文件的内容是一项常见的任务,尤其在数据处理、报表生成或数据分析等领域。Excel文件通常包含表格数据,而Java提供多种库来处理这类任务,比如Apache POI、JExcelApi和OpenCSV等。本篇将重点...
在这个工具类中,通常会包含一系列静态方法,用于处理各种Excel相关的任务,比如打开文件、读取单元格内容、修改数据、保存文件等。以下是对这个工具类中可能涉及的关键知识点的详细解释: 1. **Apache POI库**:...
对于读操作,工具类通常会提供一个接口,允许开发者指定要打开的Excel文件路径和要读取的单元格范围。然后,工具类会解析文件,将读取到的数据以适当的数据类型返回。这样,开发者可以方便地将Excel数据转换为程序中...
以下是一些关于如何在VB6中读取Excel文件及其内容的关键知识点,以及如何连接到SQL数据库以读取数据。 1. **引入对象库**:首先,你需要在VB6项目中引入Microsoft Excel Object Library。这可以通过“工程”菜单 ->...
在Qt框架下,读取Excel文件通常涉及到使用第三方库,如QAxContainer模块或QCustomPlot等。QAxContainer允许Qt应用程序与ActiveX控件交互,而Excel文件可以通过Microsoft的COM接口来访问。以下是详细的知识点说明: ...
清除VBA密码,Private Sub VBAPassword() '你要解保护的Excel文件路径 Filename = Application.GetOpenFilename("Excel文件(*.xls & *.xla & *.xlt),*.xls;*.xla;*.xlt", , "VBA破解")