自己封装的poi操作Excel工具类

       在上一篇文章使用poi读写Excel中分享了一下poi操作Excel的简单示例,这次要分享一下我封装的一个Excel操作的工具类。


       该工具类主要完成的功能是:读取Excel、汇总Excel的功能。在读取时,可以设定开始和结束读取的位置、设定是否读取多个sheet、设定读取那个或者那些sheet等。在汇总时,如设定是否覆盖目标文件、设定是否比较检查重复内容、设定检查重复的列索引等功能。具体来演示一下吧:


       工具类源码:

package com.tgb.ccl.excel.util;

import java.io.File;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.util.ArrayList;
import java.util.List;

import org.apache.poi.hssf.usermodel.HSSFWorkbook;
import org.apache.poi.ss.usermodel.Cell;
import org.apache.poi.ss.usermodel.CellStyle;
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.ss.util.CellRangeAddress;
import org.apache.poi.xssf.usermodel.XSSFWorkbook;

/**
 * Excel文件操作工具类,包括读、写、合并等功能
 * 
 * @author  : 龙轩
 * @group   : tgb8
 * @Version : 1.00
 * @Date    : 2014-10-29 上午12:40:44
 */
public class ExcelUtil {
	
	//%%%%%%%%-------常量部分 开始----------%%%%%%%%%
	/**
	 * 默认的开始读取的行位置为第一行(索引值为0)
	 */
	private final static int READ_START_POS = 0;
	
	/**
	 * 默认结束读取的行位置为最后一行(索引值=0,用负数来表示倒数第n行)
	 */
	private final static int READ_END_POS = 0;
	
	/**
	 * 默认Excel内容的开始比较列位置为第一列(索引值为0)
	 */
	private final static int COMPARE_POS = 0;
	
	/**
	 * 默认多文件合并的时需要做内容比较(相同的内容不重复出现)
	 */
	private final static boolean NEED_COMPARE = true;
	
	/**
	 * 默认多文件合并的新文件遇到名称重复时,进行覆盖
	 */
	private final static boolean NEED_OVERWRITE = true;
	
	/**
	 * 默认只操作一个sheet
	 */
	private final static boolean ONLY_ONE_SHEET = true;
	
	/**
	 * 默认读取第一个sheet中(只有当ONLY_ONE_SHEET = true时有效)
	 */
	private final static int SELECTED_SHEET = 0;
	
	/**
	 * 默认从第一个sheet开始读取(索引值为0)
	 */
	private final static int READ_START_SHEET= 0;
	
	/**
	 * 默认在最后一个sheet结束读取(索引值=0,用负数来表示倒数第n行)
	 */
	private final static int READ_END_SHEET = 0;
	
	/**
	 * 默认打印各种信息
	 */
	private final static boolean PRINT_MSG = true;
	
	//%%%%%%%%-------常量部分 结束----------%%%%%%%%%
	

	//%%%%%%%%-------字段部分 开始----------%%%%%%%%%
	/**
	 * Excel文件路径
	 */
	private String excelPath = "data.xlsx";

	/**
	 * 设定开始读取的位置,默认为0
	 */
	private int startReadPos = READ_START_POS;

	/**
	 * 设定结束读取的位置,默认为0,用负数来表示倒数第n行
	 */
	private int endReadPos = READ_END_POS;
	
	/**
	 * 设定开始比较的列位置,默认为0
	 */
	private int comparePos = COMPARE_POS;

	/**
	 *  设定汇总的文件是否需要替换,默认为true
	 */
	private boolean isOverWrite = NEED_OVERWRITE;
	
	/**
	 *  设定是否需要比较,默认为true(仅当不覆写目标内容是有效,即isOverWrite=false时有效)
	 */
	private boolean isNeedCompare = NEED_COMPARE;
	
	/**
	 * 设定是否只操作第一个sheet
	 */
	private boolean onlyReadOneSheet = ONLY_ONE_SHEET;
	
	/**
	 * 设定操作的sheet在索引值
	 */
	private int selectedSheetIdx =SELECTED_SHEET;
	
	/**
	 * 设定操作的sheet的名称
	 */
	private String selectedSheetName = "";
	
	/**
	 * 设定开始读取的sheet,默认为0
	 */
	private int startSheetIdx = READ_START_SHEET;

	/**
	 * 设定结束读取的sheet,默认为0,用负数来表示倒数第n行	
	 */
	private int endSheetIdx = READ_END_SHEET;
	
	/**
	 * 设定是否打印消息
	 */
	private boolean printMsg = PRINT_MSG;
	
	
	//%%%%%%%%-------字段部分 结束----------%%%%%%%%%
	

	public static void main(String[] args) {
		ExcelUtil eu = new ExcelUtil();
		
		//从第一行开始读取
		eu.setStartReadPos(1);
		
		String src_xlspath = "D:\\2.xls";
		String dist_xlsPath = "D:\\1.xls";
		List<Row> rowList;
		try {
			rowList = eu.readExcel(src_xlspath);
			//eu.writeExcel_xls(rowList, src_xlspath, dist_xlsPath);
		} catch (IOException e) {
			e.printStackTrace();
		}
	}
	
	public ExcelUtil(){
		
	}
	
	public ExcelUtil(String excelPath){
		this.excelPath = excelPath;
	}
	
	/**
	 * 还原设定(其实是重新new一个新的对象并返回)
	 * @return
	 */
	public ExcelUtil RestoreSettings(){
		ExcelUtil instance = new  ExcelUtil(this.excelPath);
		return instance;
	}
	
	/**
	 * 自动根据文件扩展名,调用对应的读取方法
	 * 
	 * @Title: writeExcel
	 * @Date : 2014-9-11 下午01:50:38
	 * @param xlsPath
	 * @throws IOException
	 */
	public List<Row> readExcel() throws IOException{
		return readExcel(this.excelPath);
	}

	/**
	 * 自动根据文件扩展名,调用对应的读取方法
	 * 
	 * @Title: writeExcel
	 * @Date : 2014-9-11 下午01:50:38
	 * @param xlsPath
	 * @throws IOException
	 */
	public List<Row> readExcel(String xlsPath) throws IOException{
		
		//扩展名为空时,
		if (xlsPath.equals("")){
			throw new IOException("文件路径不能为空!");
		}else{
			File file = new File(xlsPath);
			if(!file.exists()){
				throw new IOException("文件不存在!");
			}
		}
		
		//获取扩展名
		String ext = xlsPath.substring(xlsPath.lastIndexOf(".")+1);
		
		try {
			
			if("xls".equals(ext)){				//使用xls方式读取
				return readExcel_xls(xlsPath);
			}else if("xlsx".equals(ext)){		//使用xlsx方式读取
				return readExcel_xlsx(xlsPath);
			}else{									//依次尝试xls、xlsx方式读取
				out("您要操作的文件没有扩展名,正在尝试以xls方式读取...");
				try{
					return readExcel_xls(xlsPath);
				} catch (IOException e1) {
					out("尝试以xls方式读取,结果失败!,正在尝试以xlsx方式读取...");
					try{
						return readExcel_xlsx(xlsPath);
					} catch (IOException e2) {
						out("尝试以xls方式读取,结果失败!\n请您确保您的文件是Excel文件,并且无损,然后再试。");
						throw e2;
					}
				}
			}
		} catch (IOException e) {
			throw e;
		}
	}
	
	/**
	 * 自动根据文件扩展名,调用对应的写入方法
	 * 
	 * @Title: writeExcel
	 * @Date : 2014-9-11 下午01:50:38
	 * @param rowList
	 * @throws IOException
	 */
	public void writeExcel(List<Row> rowLis
  • 28
    点赞
  • 91
    收藏
    觉得还不错? 一键收藏
  • 24
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 24
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值