码迷,mamicode.com
首页 > 移动开发 > 详细

Java jxl导入excel文件,导入的数字、身份证号码、手机号变成了科学计数法,解决方案

时间:2018-06-22 18:23:01      阅读:1393      评论:0      收藏:0      [点我收藏+]

标签:日期   ref   orm   strong   计算   inpu   数字类型   exception   公式   

原文出自:https://blog.csdn.net/seesun2012

这是一个execl文件导入数据库操作,使用jxl解析execl导入数据库过程出现了科学计数法,与想要导入的数据不匹配,以下是案例以及解决方案:

导入成功后示例
1、手机号:15388886666 科学计数法:1.54E+10
2、数字:123456789000000 科学计数法:1.23E+14
3、身份证:432222198808083789 科学计数法:4.32E+17

解决思路
1、判断是否为数字类型(NUMBER)或数字计算公式(NUMBER_FORMULA);
2、获取解析后的值进行判断是否包含有(E、e、+等符号);
3、使用java自带数学类,将科学计算公式转换成所需类型。

具体代码

//  解析Execl
public static List<String[]> readExcel(File filePath) {
        List<String[]> list = new ArrayList<String[]>();
        // 日期的格式化
        SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
        try {
            // 以IO流的形式读取文件
            InputStream in = new FileInputStream(filePath);
            // 获取工作簿
            Workbook book = Workbook.getWorkbook(in);
            // 获取工作表
            Sheet sheet = book.getSheet(0);
            // 得到总列数
            int columns = sheet.getColumns();
            // 得到总行数
            int rows = sheet.getRows();
            for (int k = 2; k < rows; k++) { // 行
                String[] row = new String[columns];
                for (int i = 0; i < columns; i++) { // 列
                    Cell cell = sheet.getCell(i, k);
                    // 获得cell具体类型值的方式
                     if (cell.getType() == CellType.LABEL) {
                        LabelCell labelcell = (LabelCell) cell;
                        row[i] = labelcell.getString();
                    }else if (cell.getType() == CellType.DATE) {// excel 类型为时间类型处理;
                        DateCell dc = (DateCell) cell;
                        row[i] = sdf.format(dc.getDate());
                    }else if (cell.getType() == CellType.NUMBER || cell.getType() == CellType.NUMBER_FORMULA) {// excel 类型为数值类型处理;
                        NumberCell nc = (NumberCell) cell;
                        //  判断是否为科学计数法(包含E、e、+等符号)
                        if ((""+nc.getValue()).indexOf("E")!=-1 || (""+nc.getValue()).indexOf("e")!=-1 || (""+nc.getValue()).indexOf("+")!=-1) {
                            BigDecimal bd = new BigDecimal(""+nc.getValue());
                            row[i] = bd.toString();
                        }else{
                            row[i] = "" +  nc.getValue();
                        }
                    } else {
                        // 通用的获取cell值的方式,返回字符串
                        row[i] = cell.getContents();
                    }
                }
                // 添加到list集合中
                list.add(row);
            }
            // 关闭工作薄
            book.close();
        } catch (Exception e) {
            e.printStackTrace();
        }
        return list;
    }

Java jxl导入excel文件,导入的数字、身份证号码、手机号变成了科学计数法,解决方案

标签:日期   ref   orm   strong   计算   inpu   数字类型   exception   公式   

原文地址:https://www.cnblogs.com/seesun2012/p/9214758.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有 京ICP备13008772号-2
迷上了代码!