POI读取Excle模板中的数据

声明:该Excle模板前两行是固定格式,所以数据是从第3行开始读取。将读取的数据保存在一个字符串二维数组中。

数组的大小是根据Excle中的数据的行数与列数定义的。本demo去除了Excle前两行数据。所以数组的行数是Excle的行数-2。

具体情况具体对待。

package com.im.common.utils;

import java.io.BufferedInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.text.DecimalFormat;
import java.text.SimpleDateFormat;
import java.util.ArrayList;
import java.util.Date;
import java.util.HashMap;
import java.util.HashSet;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import javax.servlet.http.HttpServletRequest;
import org.apache.poi.hssf.usermodel.HSSFCell;
import org.apache.poi.hssf.usermodel.HSSFDateUtil;
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.springframework.web.multipart.MultipartHttpServletRequest;
import org.springframework.web.multipart.commons.CommonsMultipartFile;

public class ExcleUtil {

    public static  String[][] readExcle(HttpServletRequest request) {
        // TODO Auto-generated method stub
        MultipartHttpServletRequest multipartRequest = (MultipartHttpServletRequest) request;
        CommonsMultipartFile file = (CommonsMultipartFile) multipartRequest.getFile("filename");
        String [][] temp = null;
        if (file != null) {
            try {
                temp = readXls(file.getInputStream(),request);
            } catch (IOException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        return temp;
    }

    /**
     * 逐行遍历其Excel
     */
    private static String [][] readXls(InputStream inputStream,  HttpServletRequest request)
            throws IOException {
        InputStream is = new BufferedInputStream(inputStream);
        HSSFWorkbook hssfWorkbook = new HSSFWorkbook(is);
        HSSFSheet hssfSheet = hssfWorkbook.getSheetAt(0); //获得第一sheet
        int column = hssfSheet.getRow(2).getLastCellNum();//获得第3行的列数
        int row = hssfSheet.getLastRowNum()+1;//获取行数
        String [][] arr  = new String [row-2][column]; //创建一个字符串二维数组
        for (int rowNum = 2; rowNum < row; rowNum++) {
            //synchroImport car = new synchroImport();
            HSSFRow hssfRow = hssfSheet.getRow(rowNum);
            for(int colNum = 0;colNum < hssfRow.getLastCellNum(); colNum++) {
                HSSFCell cell = hssfRow.getCell(colNum);
                arr[rowNum-2][colNum] = getCellValue(cell);
            }

        }
        hssfWorkbook.close();
        return arr;
    }

    /**
     * 对Excel的各个单元格的格式进行判断并转换
     */
    private static String getCellValue(HSSFCell cell) {
        String cellValue = "";
        DecimalFormat df = new DecimalFormat("#.###");
        if (cell == null) {
            return "";
        }
        if(cell.getCellType()==HSSFCell.CELL_TYPE_NUMERIC&&HSSFDateUtil.isCellDateFormatted(cell)) {
            return DateUtils.formatDate(
            HSSFDateUtil.getJavaDate(cell.getNumericCellValue()), "yyyy-MM-dd");
        }
        switch (cell.getCellType()) {
        case HSSFCell.CELL_TYPE_STRING:
            cellValue = cell.getRichStringCellValue().getString().trim();
            break;
        case HSSFCell.CELL_TYPE_NUMERIC:
            cellValue = df.format(cell.getNumericCellValue()).toString();
            break;
        case HSSFCell.CELL_TYPE_BOOLEAN:
            cellValue = String.valueOf(cell.getBooleanCellValue()).trim();
            break;
        case HSSFCell.CELL_TYPE_FORMULA:
            cellValue = cell.getCellFormula();
            break;
        default:
            cellValue = "";
        }
        return cellValue;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值