用POI读取具有任意合并单元的excel数据
maven依赖:
- <dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi</artifactId>
<version>3.9</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml</artifactId>
<version>3.9</version>
</dependency>
<dependency>
<groupId>org.apache.poi</groupId>
<artifactId>poi-ooxml-schemas</artifactId>
<version>3.9</version>
</dependency>
- package com.wk.p3.excel.utils;
- import java.io.File;
- import java.io.FileInputStream;
- import java.io.IOException;
- import java.io.InputStream;
- import java.util.*;
- import org.apache.poi.hssf.usermodel.HSSFCell;
- 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 org.apache.poi.openxml4j.exceptions.InvalidFormatException;
- import org.apache.poi.ss.usermodel.WorkbookFactory;
- import org.apache.poi.ss.util.CellRangeAddress;
- /**
- * Created by handsome on 2016/7/11.
- */
- public class ExcelUtil {
- public static void main(String[] args){
- ExcelUtil excelUtil = new ExcelUtil();
- //读取excel数据
- ArrayList<Map<String,String>> result = excelUtil.readExcelToObj("C:\\Users\\handsome\\Desktop\\软文excel\\表\\表\\稿件免费媒体投放链接---上传表.xlsx");
- // ArrayList<Map<String,String>> result = excelUtil.readExcelToObj("C:\\Users\\handsome\\Desktop\\软文excel\\表\\表\\稿件付费媒体投放链接---上传表.xlsx");
- for(Map<String,String> map:result){
- System.out.println(map);
- }
- }
- /**
- * 读取excel数据
- * @param path
- */
- private ArrayList<Map<String,String>> readExcelToObj(String path) {
- Workbook wb = null;
- ArrayList<Map<String,String>> result = null;
- try {
- wb = WorkbookFactory.create(new File(path));
- result = readExcel(wb, 0, 2, 0);
- } catch (InvalidFormatException e) {
- e.printStackTrace();
- } catch (IOException e) {
- e.printStackTrace();
- }
- return result;
- }
- /**
- * 读取excel文件
- * @param wb
- * @param sheetIndex sheet页下标:从0开始
- * @param startReadLine 开始读取的行:从0开始
- * @param tailLine 去除最后读取的行
- */
- private ArrayList<Map<String,String>> readExcel(Workbook wb,int sheetIndex, int startReadLine, int tailLine) {
- Sheet sheet = wb.getSheetAt(sheetIndex);
- Row row = null;
- ArrayList<Map<String,String>> result = new ArrayList<Map<String,String>>();
- for(int i=startReadLine; i<sheet.getLastRowNum()-tailLine+1; i++) {
- row = sheet.getRow(i);
- Map<String,String> map = new HashMap<String,String>();
- for(Cell c : row) {
- String returnStr = "";
- boolean isMerge = isMergedRegion(sheet, i, c.getColumnIndex());
- //判断是否具有合并单元格
- if(isMerge) {
- String rs = getMergedRegionValue(sheet, row.getRowNum(), c.getColumnIndex());
- // System.out.print(rs + "------ ");
- returnStr = rs;
- }else {
- // System.out.print(c.getRichStringCellValue()+"++++ ");
- returnStr = c.getRichStringCellValue().getString();
- }
- if(c.getColumnIndex()==0){
- map.put("id",returnStr);
- }else if(c.getColumnIndex()==1){
- map.put("base",returnStr);
- }else if(c.getColumnIndex()==2){
- map.put("siteName",returnStr);
- }else if(c.getColumnIndex()==3){
- map.put("articleName",returnStr);
- }else if(c.getColumnIndex()==4){
- map.put("mediaName",returnStr);
- }else if(c.getColumnIndex()==5){
- map.put("mediaUrl",returnStr);
- }else if(c.getColumnIndex()==6){
- map.put("newsSource",returnStr);
- }else if(c.getColumnIndex()==7){
- map.put("isRecord",returnStr);
- }else if(c.getColumnIndex()==8){
- map.put("recordTime",returnStr);
- }else if(c.getColumnIndex()==9){
- map.put("remark",returnStr);
- }
- }
- result.add(map);
- // System.out.println();
- }
- return result;
- }
- /**
- * 获取合并单元格的值
- * @param sheet
- * @param row
- * @param column
- * @return
- */
- public String getMergedRegionValue(Sheet sheet ,int row , int column){
- int sheetMergeCount = sheet.getNumMergedRegions();
- for(int i = 0 ; i < sheetMergeCount ; i++){
- CellRangeAddress ca = sheet.getMergedRegion(i);
- int firstColumn = ca.getFirstColumn();
- int lastColumn = ca.getLastColumn();
- int firstRow = ca.getFirstRow();
- int lastRow = ca.getLastRow();
- if(row >= firstRow && row <= lastRow){
- if(column >= firstColumn && column <= lastColumn){
- Row fRow = sheet.getRow(firstRow);
- Cell fCell = fRow.getCell(firstColumn);
- return getCellValue(fCell) ;
- }
- }
- }
- return null ;
- }
- /**
- * 判断合并了行
- * @param sheet
- * @param row
- * @param column
- * @return
- */
- private boolean isMergedRow(Sheet sheet,int row ,int column) {
- int sheetMergeCount = sheet.getNumMergedRegions();
- for (int i = 0; i < sheetMergeCount; i++) {
- CellRangeAddress range = sheet.getMergedRegion(i);
- int firstColumn = range.getFirstColumn();
- int lastColumn = range.getLastColumn();
- int firstRow = range.getFirstRow();
- int lastRow = range.getLastRow();
- if(row == firstRow && row == lastRow){
- if(column >= firstColumn && column <= lastColumn){
- return true;
- }
- }
- }
- return false;
- }
- /**
- * 判断指定的单元格是否是合并单元格
- * @param sheet
- * @param row 行下标
- * @param column 列下标
- * @return
- */
- private boolean isMergedRegion(Sheet sheet,int row ,int column) {
- int sheetMergeCount = sheet.getNumMergedRegions();
- for (int i = 0; i < sheetMergeCount; i++) {
- CellRangeAddress range = sheet.getMergedRegion(i);
- int firstColumn = range.getFirstColumn();
- int lastColumn = range.getLastColumn();
- int firstRow = range.getFirstRow();
- int lastRow = range.getLastRow();
- if(row >= firstRow && row <= lastRow){
- if(column >= firstColumn && column <= lastColumn){
- return true;
- }
- }
- }
- return false;
- }
- /**
- * 判断sheet页中是否含有合并单元格
- * @param sheet
- * @return
- */
- private boolean hasMerged(Sheet sheet) {
- return sheet.getNumMergedRegions() > 0 ? true : false;
- }
- /**
- * 合并单元格
- * @param sheet
- * @param firstRow 开始行
- * @param lastRow 结束行
- * @param firstCol 开始列
- * @param lastCol 结束列
- */
- private void mergeRegion(Sheet sheet, int firstRow, int lastRow, int firstCol, int lastCol) {
- sheet.addMergedRegion(new CellRangeAddress(firstRow, lastRow, firstCol, lastCol));
- }
- /**
- * 获取单元格的值
- * @param cell
- * @return
- */
- public String getCellValue(Cell cell){
- if(cell == null) return "";
- if(cell.getCellType() == Cell.CELL_TYPE_STRING){
- return cell.getStringCellValue();
- }else if(cell.getCellType() == Cell.CELL_TYPE_BOOLEAN){
- return String.valueOf(cell.getBooleanCellValue());
- }else if(cell.getCellType() == Cell.CELL_TYPE_FORMULA){
- return cell.getCellFormula() ;
- }else if(cell.getCellType() == Cell.CELL_TYPE_NUMERIC){
- return String.valueOf(cell.getNumericCellValue());
- }
- return "";
- }
- /**
- * 从excel读取内容
- */
- public static void readContent(String fileName) {
- boolean isE2007 = false; //判断是否是excel2007格式
- if(fileName.endsWith("xlsx"))
- isE2007 = true;
- try {
- InputStream input = new FileInputStream(fileName); //建立输入流
- Workbook wb = null;
- //根据文件格式(2003或者2007)来初始化
- if(isE2007)
- wb = new XSSFWorkbook(input);
- else
- wb = new HSSFWorkbook(input);
- Sheet sheet = wb.getSheetAt(0); //获得第一个表单
- Iterator<Row> rows = sheet.rowIterator(); //获得第一个表单的迭代器
- while (rows.hasNext()) {
- Row row = rows.next(); //获得行数据
- System.out.println("Row #" + row.getRowNum()); //获得行号从0开始
- Iterator<Cell> cells = row.cellIterator(); //获得第一行的迭代器
- while (cells.hasNext()) {
- Cell cell = cells.next();
- System.out.println("Cell #" + cell.getColumnIndex());
- switch (cell.getCellType()) { //根据cell中的类型来输出数据
- case HSSFCell.CELL_TYPE_NUMERIC:
- System.out.println(cell.getNumericCellValue());
- break;
- case HSSFCell.CELL_TYPE_STRING:
- System.out.println(cell.getStringCellValue());
- break;
- case HSSFCell.CELL_TYPE_BOOLEAN:
- System.out.println(cell.getBooleanCellValue());
- break;
- case HSSFCell.CELL_TYPE_FORMULA:
- System.out.println(cell.getCellFormula());
- break;
- default:
- System.out.println("unsuported sell type======="+cell.getCellType());
- break;
- }
- }
- }
- } catch (IOException ex) {
- ex.printStackTrace();
- }
- }
- }
用POI读取具有任意合并单元的excel数据的更多相关文章
- 使用POI创建word表格合并单元格兼容wps
poi创建word表格合并单元格代码如下: /** * @Description: 跨列合并 */ public void mergeCellsHorizontal(XWPFTable table, ...
- poi生成表格自动合并单元格
直接复制这个工具类即可使用: /** * 合并单元格 * @author tongyao * @param sheet sheet页 * @param titleColumn 标题占用行 * @par ...
- 转:java 解析excel,带合并单元的excel
收集了一些对博主有帮助的博文,如下 >>>>>>>>>>>第一部分: 首先,mavn导入jar包 <!-- 解析excel需要导 ...
- Python合并多个Excel数据
安装模块 1.找到对应的模块 http://www.python-excel.org/ 2.用pip install 安装 pip install xlrdpip install XlsxWrite ...
- POI读取格式化后的单元格数据
public static String getFormattedValue(Cell cell) { FormulaEvaluator evaluator = cell.getSheet().get ...
- 使用POI读取xlsx文件,包含对excel中自定义时间格式的处理
package poi; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundExcepti ...
- NPOI操作EXCEL(五)——含合并单元格复杂表头的EXCEL解析
我们在第三篇文章中谈到了那些非常反人类的excel模板,博主为了养家糊口,也玩命做出了相应的解析方法... 我们先来看看第一类复杂表头: ...... 博主称这类excel模板为略复杂表头模板(蓝色部 ...
- 使用npoi导入Excel - 带合并单元格--附代码
之前我们在使用npoi导入excel表格的时候,往往会遇见那种带有合并单元格的数据在导入的时候出现合并为空的问题, 也就是只有第一条有数据,其余均为空白.在网上翻了半天也没有找到合适的解决方案,最后还 ...
- C#导出Excel,并且设置Excel单元格格式,合并单元格.
注:要添加COM组件 Microsoft Excel 11.0 Object Library 引用. 具体代码如下: using System; using System.Collections.G ...
随机推荐
- 2016-10-17: source insight插件
使用快捷键注释,单行注释,多行注释,#if 0注释 将文件 mycomment.em点此下载放到sourceinsight的Base工程的路径下(一般是在C:\Documents and Settin ...
- OC Runtime
OC 是面向运行时的语言.Runtime就是系统在运行的时候的一些机制,其中最主要的是消息发送机制.OC语言与其他语言(如C语言)在函数(方法)的调用有很大的不同.C语言,函数的调用在编译的时候就已经 ...
- 在Ubuntu上安装Mysql For Python
安装: 首先安装pip,并且把pip更新到最小版本 apt-get install python-pip pip install -U pip 安装mysql开发包 apt-get install p ...
- ES6学习笔记(2)
变量的解构赋值 ES6允许按照一定模式,从数组和对象中提取值,对变量进行赋值,被称为解构(Destructuring); 数组的解构赋值 let [a, b, c] = [1, 2, 3]; cons ...
- css之z-index
要想z-index可以使用,就要配合定位元素使用即position 如果定位元素z-index没有发生嵌套: 1.后来居上的准则 2.哪个大,哪个上 例如 如果定位元素z-index发生嵌套: 1.祖 ...
- EJDK, Raspberry Pi, and NetBeans IDE 8
https://blogs.oracle.com/geertjan/entry/youtube_ejdk_raspberry_pi_and
- SCN
SCN 一.SCN的引入 众所周知,当oracle实例崩溃时,oracle通过检查点队列使用CKPT进程,周期性的将LRBA记入控制文件,以记录读取REDO LOG的范围.确定范围之后,oracle首 ...
- NSMutableAttributedString 的使用
NSMutableAttributedString *msAttriStr = [[NSMutableAttributedString alloc] initWithString:[NSString ...
- CListCtlr 控件的常见用法
今天第一次用CListCtrl控件,遇到不少问题,查了许多资料,现将用到的一些东西总结如下: 以下未经说明,listctrl默认view 风格为report 相关类及处理函数 MFC:CListCtr ...
- JOSN 为空数据的处理
for(var i=0,l=thisuserList.length;i<l;i++){ for(var key in thisuserList[i]){ if(thisuserList[i][k ...