excel解析

        依赖

<dependency>
            <groupId>org.apache.poi</groupId>
            <artifactId>poi-ooxml</artifactId>
            <version>4.1.1</version>
        </dependency>

 

源码

public final static List<List<String>> getUpd(Workbook wk, int startindex) {
        Sheet sht = wk.getSheetAt(0);
        List<List<String>> rows = new ArrayList<>(sht.getLastRowNum() + 1);
        for (int i = startindex; i <= sht.getLastRowNum(); i++) {
            Row row = sht.getRow(i);
            if (row != null) {
                List<String> datas = new ArrayList<>(row.getLastCellNum());
                for (int j = 0; j < row.getLastCellNum(); j++) {
                    Cell cell = row.getCell(j);
                    if (cell != null) {
                        if (CellType.NUMERIC == cell.getCellType()) {
                            if (DateUtil.isCellDateFormatted(cell)) {
                                Double numericCellValue = cell.getNumericCellValue();
                                Date date = DateUtil.getJavaDate(numericCellValue);
                                if (numericCellValue < 1) {
                                    LocalTime localTime = date.toInstant().atZone(ZoneId.systemDefault()).toLocalTime();
                                    datas.add(localTime.getHour() + ":" + localTime.getMinute() + ":"
                                            + localTime.getSecond());
                                } else if (numericCellValue == numericCellValue.longValue()) {
                                    LocalDate localdate = date.toInstant().atZone(ZoneId.systemDefault()).toLocalDate();
                                    datas.add(localdate.getYear() + "-" + localdate.getMonthValue() + "-"
                                            + localdate.getDayOfMonth());

                                } else {
                                    datas.add(new SimpleDateFormat("yyyy-MM-dd HH:mm:ss").format(date));
                                }
                            } else {
                                DecimalFormat df = new DecimalFormat("0");
                                datas.add(df.format(cell.getNumericCellValue()));
                            }
                        }

                        else {

                            datas.add(cell.getStringCellValue());
                        }
                    } else {
                        datas.add(null);
                    }
                }
                rows.add(datas);
            }
        }
        return rows;
    }

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值