`
zhangwei_david
  • 浏览: 478035 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

POI 解析excel

    博客分类:
  • POI
阅读更多

@Component("tuitionPropertyParser")

public class TuitionPropertyParser {

 

    /**普通日志记录器**/

    private static final Logger               logger    = LoggerFactory

                                                            .getLogger(TuitionPropertyParser.class);

 

    /**初始化标准文件头部信息

     * 如果因字段位置发生变化,只需要修改该key 对象的索引即可

     * **/

    private static final Map<String, Integer> headerMap = new LinkedHashMap<String, Integer>() {

                                                            /**  */

                                                            private static final long serialVersionUID = -1695920344078930133L;

 

                                                            {

                                                                put(HeaderKeys.PARTNER_ID, 0);

                                                                put(HeaderKeys.USER_ID, 1);

                                                                put(HeaderKeys.TRADE_NO, 2);

                                                                put(HeaderKeys.PAYMENT_TIME, 3);

                                                                put(HeaderKeys.CURRENCY, 4);

                                                                put(HeaderKeys.AMOUNT, 5);

                                                                put(HeaderKeys.BILLER_CODE, 6);

                                                                put(HeaderKeys.REFERENCE_NO, 7);

                                                                put(HeaderKeys.STATUS, 8);

                                                            }

                                                        };

 

    /**

     * 定义表格的第一列每一个单元格的标题

     * 

     * @author Zhangwei

     * @version $Id: TuitionPropertyParser.java, v 0.1 2014年7月23日 下午5:26:56 Zhangwei Exp $

     */

    private static class HeaderKeys {

        /**商户Id**/

        private static final String PARTNER_ID   = "Partner Transaction ID(Alipay)";

        /**支付用户userId**/

        private static final String USER_ID      = "User ID(Alipay)";

        /**支付流水号**/

        private static final String TRADE_NO     = "Trade No.(Alipay)";

        /**支付时间**/

        private static final String PAYMENT_TIME = "Payment Time(Alipay)";

        /**币种**/

        private static final String CURRENCY     = "Currency(Alipay)";

        /**金额**/

        private static final String AMOUNT       = "Amount(Alipay)";

        /**biller_code**/

        private static final String BILLER_CODE  = "Biller Code(Alipay)";

        /**reference_ no**/

        private static final String REFERENCE_NO = "Reference No.(Alipay)";

        /**订单状态**/

        private static final String STATUS       = "Status(PayBang)";

 

    }

 

    /**

     * 具体的文件解析方法

     * 

     * @param in 输入流

     * @return

     * @throws IOException 

     * @throws ParseException 

     */

    public List<TuitionOrderModel> parser(InputStream in, String fileName, String userId)

                                                                                         throws IOException,

                                                                                         ParseException {

        List<TuitionOrderModel> list = new ArrayList<TuitionOrderModel>();

        // 创建一个工作表

        HSSFWorkbook workBook = new HSSFWorkbook(in);

        // 循环sheet

        for (int i = 0; i < workBook.getNumberOfSheets(); i++) {

            HSSFSheet sheet = workBook.getSheetAt(i);

            if (sheet == null) {

                continue;

            }

            list.addAll(parseSheet(sheet, fileName, userId));

        }

        return list;

 

    }

 

    /**

     * 解析表格是一个sheet

     * 

     * @param sheet 需要解析的sheet

     * @param fileName 文件名称

     * @return

     * @throws ParseException

     */

    private List<TuitionOrderModel> parseSheet(HSSFSheet sheet, String fileName,

                                               String operateUserId) throws ParseException {

        List<TuitionOrderModel> list = new ArrayList<TuitionOrderModel>();

        // 获取第一行

        HSSFRow head = sheet.getRow(0);

        if (head != null) {

            if (!validateHeader(head)) {

                throw new AlipayRuntimeException("文件头部信息不合法,请确认!head=" + headerMap);

            }

            // 解析文件内容

            for (int i = 1; i <= sheet.getLastRowNum(); i++) {

                HSSFRow row = sheet.getRow(i);

                if (row == null) {

                    continue;

                }

                list.add(parseCell(row, fileName, operateUserId));

            }

        }

        return list;

 

    }

 

    /**

     * 解析每一行数据, 除了金额列,其他列读取到的都是字符串类型

     * 每个单元格的域与 hearderMap 的key 是对应的,如果 列的数据类型有变化,需要做出相应的修改

     * 

     * @param row 表格中的一行

     * @param fileName 文件名称

     * @return

     * @throws ParseException

     */

    private TuitionOrderModel parseCell(HSSFRow row, String fileName, String userId)

                                                                                    throws ParseException {

 

        TuitionOrderModel model = new TuitionOrderModel();

        model.setPartnerId(getStringValue(row.getCell(getIndexBykey(HeaderKeys.PARTNER_ID))));

        model.setUserId(getStringValue(row.getCell(getIndexBykey(HeaderKeys.USER_ID))));

        model.setTradeNo(getStringValue(row.getCell(getIndexBykey(HeaderKeys.TRADE_NO))));

        model.setPaymentTime(DateUtil.parseDateNewFormat(getStringValue(row

            .getCell(getIndexBykey(HeaderKeys.PAYMENT_TIME)))));

        model.setCurrency(getStringValue(row.getCell(getIndexBykey(HeaderKeys.CURRENCY))));

        model.setAmount(new Money(row.getCell(getIndexBykey(HeaderKeys.AMOUNT))

            .getNumericCellValue()));

        model.setBillerCode(getStringValue(row.getCell(getIndexBykey(HeaderKeys.BILLER_CODE))));

        model.setReferenceNo(getStringValue(row.getCell(getIndexBykey(HeaderKeys.REFERENCE_NO))));

        model.setStatus(getStringValue(row.getCell(getIndexBykey(HeaderKeys.STATUS))));

        model.setSourceFilePath(fileName);

        Map<String, String> map = new HashMap<String, String>();

        map.put("operator", userId);

        map.put("IP", OperationContextHolder.getEnvironment().getClientIp());

        map.put("logonId", OperationContextHolder.getPrincipal().getLogonId());

        model.setRemark(map);

        return model;

 

    }

 

    /**

     * 从单元格式读取数据字符串数据,如果单元格时数字类型是将读取的数据转换为整数对应的字符串

     * 如果需要读取double 类型值时,请直接使用getNumericCellValue()

     * 

     * @param hssfCell

     * @return

     */

    private String getStringValue(HSSFCell hssfCell) {

        String value = null;

        if (hssfCell.getCellType() == Cell.CELL_TYPE_BOOLEAN) {

            value = String.valueOf(hssfCell.getBooleanCellValue());

        } else if (hssfCell.getCellType() == Cell.CELL_TYPE_NUMERIC) {

            value = String.valueOf((long) hssfCell.getNumericCellValue());

        } else {

            value = String.valueOf(hssfCell.getStringCellValue());

        }

        if (logger.isDebugEnabled()) {

            logger.debug("解析到的数据是" + value);

        }

        return value;

    }

 

    /**

     * 获取指定key 对象表格的索引

     * 

     * @param key

     * @return

     */

    private int getIndexBykey(String key) {

        if (!headerMap.containsKey(key)) {

            throw new AlipayRuntimeException("未定义指定的key=" + key + "所在的列");

        }

        return headerMap.get(key);

    }

 

    /**

     * 解析exel 第一行头部信息

     * 

     * @param head 文件的第一行

     * @return

     */

    private boolean validateHeader(HSSFRow head) {

 

        for (int i = 0; i < head.getLastCellNum(); i++) {

            HSSFCell cell = head.getCell(i);

            String value = cell.getStringCellValue();

            if (i != headerMap.get(value)) {

                throw new AlipayRuntimeException("当前列(" + i + ")的值(" + value

                                                 + ")与配置的hearderMap 数据部一直,请确认!headerMap="

                                                 + headerMap);

            }

        }

        return true;

    }

 

}

分享到:
评论

相关推荐

    使用POI解析excel文件并写入数据库

    使用poi解析excel文件,并将数据写入到数据库 项目说明 这个项目实现的功能是读取excel文件中的数据,解析并写入数据库。 读取的excel文件位于项目目录下的 excel\0805.xlsx 使用IntelliJ IDEA开发此项目 使用MYSQL...

    Java Poi 解析EXCEL数据

    以上就是使用Java Poi解析Excel数据的基本流程。在实际应用中,你可能还需要处理其他复杂场景,比如样式、公式、超链接等。Poi库提供了丰富的API来处理这些问题,使得与Excel文件的交互变得简单且灵活。在提供的"poi...

    利用POI解析excel并存入数据库demo

    在这个"利用POI解析excel并存入数据库demo"中,我们将关注如何使用 POI 库来读取 Excel 文件,并将数据有效地存入 MySQL 数据库。 首先,要开始使用 POI,你需要在你的项目中引入相应的依赖。如果你使用的是 Maven...

    poi解析excel文件

    标题提到的"poi解析excel文件"是利用Apache POI 3.8版本进行Excel数据的读取和解析。 在Apache POI 3.8中,主要涉及以下核心概念: 1. **HSSF(Horrible Spreadsheet Format)**:这是Apache POI中处理旧版Excel...

    POI解析EXCEl分层

    标题“POI解析EXCEL分层”涉及到的主要知识点是Apache POI库在处理Microsoft Excel文件时的层次化数据解析。Apache POI是一个流行的开源Java API,它允许开发者读取、写入和修改Microsoft Office格式的文件,其中...

    poi 解析excel文件内容demo

    在这个"poi 解析excel文件内容demo"中,我们主要关注如何使用Apache POI库来读取和解析Excel文件,无论它们是2003版的.XLS还是2007以后的.XLSX格式。 首先,Apache POI提供了两种主要的接口来处理Excel文件:HSSF...

    poi解析excel

    【标题】"poi解析excel"涉及的是Java编程中使用Apache POI库来处理Microsoft Excel文件的知识。Apache POI是开源项目,提供了API用于读写Microsoft Office格式的文件,特别是Excel。在Java应用中,POI使得开发者能够...

    poi解析excel的poi包

    以上就是使用Apache POI解析Excel文件并将数据存入Oracle数据库的基本步骤。在实际应用中,你可能需要根据具体需求进行调整,例如处理不同类型的单元格(数字、日期等)、异常处理、优化性能等。

    POI解析Excel简单实例

    POI解析Excel简单实例

    apache poi解析Excel时报错,我将Excel打开后保存,就不会报错,用jar完美解决

    apache poi解析Excel时报错,我将Excel打开后保存,就不会报错,我将重写的类从新打包这样问题虽然网上有解决方案,但是需要自己打包重写对应类,我已将这些步骤做好了。

    POI解析excel并存入mysqlのdemo

    这个“POI解析excel并存入mysqlのdemo”是利用 Java 的 Apache POI 库来读取 Excel 数据,并将这些数据存储到 MySQL 数据库中的示例。下面我们将详细探讨相关的知识点。 1. **Apache POI**: Apache POI 是一个...

    poi 解析excel实例

    在描述中提到的“ poi解析excel的工具类”,通常包含了一些常用的方法,例如打开文件、读取单元格数据、处理合并单元格等。以下是一些可能包含在该工具类中的关键方法: 1. **打开文件**:使用`WorkbookFactory`类...

    POI解析Excel文档

    【标题】"POI解析Excel文档"涉及到的主要技术是Apache POI库,它是一个用于读取和写入Microsoft Office格式档案的开源Java API。在Java编程环境中,使用POI库可以方便地处理Excel(.xlsx和.xls)文件,进行数据的...

    poi解析Excel所需要的包

    在Java环境中,使用Apache POI库解析Excel文件时,确实需要引入一系列的依赖包来确保所有必要的功能得以正常运行。这些包包含了对Excel文件格式的理解和支持,允许开发者读取、写入和修改Excel数据。 1. **Apache ...

    poi解析excel2007

    最新版poi解析excel2007源码,简单实用,需要的可下.

    通过poi解析Excel示例

    本示例将深入讲解如何使用Apache POI来解析Excel文件。 Apache POI是Apache软件基金会的一个开源项目,它的主要功能是处理微软的Office Open XML (OOXML) 和早期的二进制文件格式,例如Excel的.BIFF8格式。在Java中...

    使用poi解析Excel

    《使用POI解析Excel》 在信息技术领域,处理数据是日常工作中不可或缺的一部分,而Excel作为广泛使用的电子表格软件,其数据处理能力强大且灵活。Apache POI是一个开源库,专门用于读取和写入Microsoft Office格式...

    POI解析excel

    在本文中,我们将深入探讨如何使用POI解析Excel 2013和2017版本的文件,并将结果转换为List集合。 一、Apache POI简介 Apache POI是Apache软件基金会的一个开源项目,它提供了API来读取、写入和修改Microsoft ...

Global site tag (gtag.js) - Google Analytics