ããé¦å POIæ¯å¼æºç»ç»Apacheåºåçä¸ä¸ªå¼æºjarå ï¼æä¾äºæ¹ä¾¿è§£æExcelçAPIï¼æ们å¯ä»¥é常æ¹ä¾¿ç使ç¨å®æ¥è¯»åExcelãè¿éä»ç»3.5Finalçæ¬ã
ããæéç¨å°çjarå å¦ä¸:
ãã说å°Excelï¼æ2003å2007ï¼æ ¼å¼æ¯ä¸ä¸æ ·çï¼ç¨POI解æçæ¹æ³ä¹å°±ä¸ä¸æ ·ï¼Excel2003主è¦æ¯ä½¿ç¨org.apache.poi.hssf.usermodelå ä¸çç±»æ¥è§£æï¼èExcel2007å°±æ¯ä½¿ç¨org.apache.poi.xssf.usermodelæ¥è§£æã
ãã解æExcel2003æºç
说å°Excelï¼æ2003å2007ï¼æ ¼å¼æ¯ä¸ä¸æ ·çï¼ç¨POI解æçæ¹æ³ä¹å°±ä¸ä¸æ ·ï¼Excel2003主è¦æ¯ä½¿ç¨org.apache.poi.hssf.usermodelå ä¸çç±»æ¥è§£æï¼èExcel2007å°±æ¯ä½¿ç¨org.apache.poi.xssf.usermodelæ¥è§£æã
解æExcel2003æºç
StringBuffer content = new StringBuffer();
HSSFWorkbook workbook = new HSSFWorkbook(is); // å建对Excelå·¥ä½ç°¿æ件çå¼ç¨
for (int numSheets = 0; numSheets < workbook.getNumberOfSheets(); numSheets++) {
if (null != workbook.getSheetAt(numSheets)) {
HSSFSheet aSheet = workbook.getSheetAt(numSheets); // è·å¾ä¸ä¸ªsheet
for (int rowNumOfSheet = 0; rowNumOfSheet <= aSheet.getLastRowNum(); rowNumOfSheet++) {
if (null != aSheet.getRow(rowNumOfSheet)) {
HSSFRow aRow = aSheet.getRow(rowNumOfSheet); // è·å¾ä¸è¡
for (int cellNumOfRow = 0; cellNumOfRow <= aRow.getLastCellNum(); cellNumOfRow++) {
if (null != aRow.getCell(cellNumOfRow)) {
HSSFCell aCell = aRow.getCell(cellNumOfRow); // è·å¾åå¼
if (aCell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC) {
content.append(aCell.getNumericCellValue() + "\t");
} else if (aCell.getCellType() == HSSFCell.CELL_TYPE_BOOLEAN) {
content.append(aCell.getBooleanCellValue() + "\t");
} else if (aCell.getCellType() == HSSFCell.CELL_TYPE_STRING) {
content.append(aCell.getStringCellValue() + "\t");
} else if (aCell.getCellType() == HSSFCell.CELL_TYPE_FORMULA){
content.append(aCell.getCellFormula() + "\t");
} else {
continue;
}
}
if(cellNumOfRow == aRow.getLastCellNum()) {
content.append("\n");
}
}
}
}
}
}
return content.toString().trim();
解æExcel2007å2003åºæ¬ä¸æ ·ï¼åªæ¯å°HSSFSheet,HSSFCellçé½æ¹æXSSFSheet,XSSFCellå³å¯ã
å¦å¤è¦æé大家çæ¯Excelçæ ·å¼é½æ¯åºäºä¸ä¸ªåå æ ¼çï¼æ以ç¨HSSFRow.getRowStyle()æ¿æ ·å¼ä¼åºé®é¢çï¼ä¸ä¸å®ä¼æ¿å°ä½ æ³è¦çæ ·å¼ãå¤çå并åå æ ¼æ¯POIçä¸ä¸ªé¾ç¹ï¼åªè½éè¿å¤æå½ååå æ ¼æ¯å¦å¨å并åå æ ¼ä¹ä¸ï¼å¦ææ¯ï¼é£æ¤åå æ ¼çå¼ä¾¿æ¯è¿ä¸ªå并åå æ ¼çé¦ä½ç½®åå æ ¼çå¼ï¼åªæéè¿è¿æ ·æè½æ¥å¤çå并åå æ ¼ã
å¤çå并åå æ ¼ç代ç ï¼
public static boolean isMergedRegion(HSSFSheet sheet, HSSFCell cell) {
//å¾å°ä¸ä¸ªsheetä¸æå¤å°ä¸ªå并åå
æ ¼
int sheetmergerCount = sheet.getNumMergedRegions();
for(int i = 0; i < sheetmergerCount; i++) {
//å¾åºå
·ä½çå并åå
æ ¼
CellRangeAddress ca = sheet.getMergedRegion(i);
//å¾å°å并åå
æ ¼çèµ·å§è¡, ç»æè¡, èµ·å§å, ç»æå
int firstC = ca.getFirstColumn();
int lastC = ca.getLastColumn();
int firstR = ca.getFirstRow();
int lastR = ca.getLastRow();
//å¤æ该åå
æ ¼æ¯å¦å¨å并åå
æ ¼èå´ä¹å
, å¦ææ¯, åè¿å true
if(cell.getColumnIndex() <= lastC && cell.getColumnIndex() >= firstC) {
if(cell.getRowIndex() <= lastR && cell.getRowIndex() >= firstR) {
return true;
}
}
}
return false;
}
public static String getMergedRegionValue(HSSFSheet sheet, HSSFCell cell) {
//è·å¾ä¸ä¸ª sheet ä¸å并åå
æ ¼çæ°é
int sheetmergerCount = sheet.getNumMergedRegions();
//便å©å并åå
æ ¼
for(int i = 0; i < sheetmergerCount; i++) {
//è·å¾å并åå
æ ¼
CellRangeAddress ca = sheet.getMergedRegion(i);
//è·å¾å并åå
æ ¼çèµ·å§è¡, ç»æè¡, èµ·å§å, ç»æå
int firstC = ca.getFirstColumn();
int lastC = ca.getLastColumn();
int firstR = ca.getFirstRow();
int lastR = ca.getLastRow();
//å¤æ该åå
æ ¼æ¯å¦æ¯å¨å并åå
æ ¼ä¸, å¦ææ¯, åè¿åæå¨å并åå
æ ¼çé¦åå
æ ¼çå¼
if(cell.getColumnIndex() <= lastC && cell.getColumnIndex() >= firstC) {
if(cell.getRowIndex() <= lastR && cell.getRowIndex() >= firstR) {
HSSFRow fRow = sheet.getRow(firstR);
HSSFCell fCell = fRow.getCell(firstC);
//é¤äºå并åå
æ ¼é¦åå
æ ¼çå¼, å
¶ä½çç¨(*)æ¥åºå
if (fCell.getCellType() == HSSFCell.CELL_TYPE_NUMERIC && hasBorder(cell)) {
return String.valueOf(fCell.getNumericCellValue());
} else if (fCell.getCellType() == HSSFCell.CELL_TYPE_BOOLEAN && hasBorder(cell)) {
return String.valueOf(fCell.getBooleanCellValue());
} else if (fCell.getCellType() == HSSFCell.CELL_TYPE_STRING && hasBorder(cell)) {
return fCell.getStringCellValue();
} else if (fCell.getCellType() == HSSFCell.CELL_TYPE_FORMULA && hasBorder(cell)){
return String.valueOf(fCell.getCellFormula());
}
}
}
}
return "";
}
使用POI技术实现excel文件的导入,亲测有效!
实现思路:通过创建web项目,导入POI相关jar依赖,准备学生信息的excel文件,创建数据库并表,设计实体类,实现Servlet、Service与DAO层。具体步骤包括:创建并准备学生信息excel文件配置web项目,导入POI核心依赖创建数据库与学生表设计Student实体类编写StudentServlet实现StudentService创建StudentDao效果展示:导入成...
Apache POI使用详解
创建单元格 创建文档摘要信息 创建批注 批注位置参数说明 创建页眉和页脚 通过访问HSSFHeader或HSSFFooter静态属性定义。Excel单元格操作 设置格式 使用HSSFDataFormat区分内嵌格式和自定义格式。合并单元格 使用CellRangeAddress构造方法定义单元格区域。单元格对齐 水平对齐:LEFT, CENTER, RIGHT;垂直对齐:TOP, CE...
如何用Apache POI操作Excel文件
说到Excel,有2003和2007,格式是不一样的,用POI解析的方法也就不一样,Excel2003主要是使用org.apache.poi.hssf.usermodel包中的类来解析,而Excel2007就是使用org.apache.poi.xssf.usermodel来解析。解析Excel2003源码 StringBuffer content = new StringBuffer(); HSSFWorkbook workbook = new HSSFW...
如何用apachepoi操作excel文件
public void setUp() throws InvalidFormatException, IOException { \/\/ 加载excel文件,自动判断是HSSF还是XSSF workbook = WorkbookFactory.create(new File("E:\/aaa.xls"));} \/ 读取一个已存在的Excel
poi导入工具类
以下是构建Apache POI导入工具类的基本步骤:1. **依赖引入**:确保在项目中引入Apache POI的依赖。这是实现工具类的前提。2. **工具类编写**:创建一个工具类,其中封装了解析Excel文件的核心逻辑。此类通常包含方法,用于读取特定行或列的数据,以及解析单元格值等操作。3. **使用方法**:在实际...
一文搞定POI,再也不怕excel导入导出了
在Java开发中,处理Excel文件的导入导出是常见的需求,本文将简要介绍如何使用Apache POI、EasyPoi和EasyExcel这三个库进行操作。首先,了解其应用场景:企业管理系统、学校教务系统、电子商务平台、人力资源管理系统和医院信息系统等,都需要处理大量数据的导入导出,如员工信息、销售数据等。Apache POI是处理...
SpringBoot集成文件 - 集成POI之Excel导入导出
<groupId>org.apache.poi<\/groupId> <artifactId>poi-ooxml<\/artifactId> <version>最新版本号<\/version> <\/dependency> 导出Excel操作通常在控制器(Controller)层实现。通过UserServiceImple中的导出方法调用具体逻辑,生成一个Excel文件。方法的具体实现涉及获取数据、构建Excel工作簿和工作表、添加数据...
教你如何使用POI报表
以创建Excel报表为例,主要操作包括读取单元格数据,如在Main函数中使用getCellValue函数,对于出生日期这类“常规”类型的数据,会以字符串形式返回。在报表导出方面,通过POI的API,你可以将处理后的数据有效地输出到Excel文档中。在项目架构中,实体类可能存放在util包中,而Controller层则负责数据处理和...
eclipse怎么导入Excel里边的数据eclipse如何导入数据
在eclipse中导入Excel数据可以使用Apache POI库。首先需要将POI库导入到项目中。然后在代码中使用POI库的API,打开Excel文件,读取数据并进行处理。可以使用HSSFWorkbook类来打开Excel文件,使用HSSFSheet类来获取工作表,使用HSSFRow类和HSSFCell类来获取行和单元格数据。最后,将数据存储到Java对象中,以便在...
POI和EasyExcel讲解
在Excel版本上,Apache POI支持2003版本的.xls和2007版本的.xlsx格式。2003版本的.xls文件行数限制为65535行,而2007版本的.xlsx文件没有此限制。在创建Maven项目并使用Apache POI处理Excel时,需要使用Java 1.8版本,并在pom.xml文件中导入相关依赖。在实际操作中,开发者会使用工作簿、工作表、行、列...