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

原文出自: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;
    }

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

时间: 2024-10-06 01:19:10

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

用POI导出excel时,较长的数字不想被自动变为科学计数法的解决方式(转)

做过很多次导出excel了.都碰到一个问题,内容里如果包含一个比较长的数字,比如订单号“2546541656596”,excel会自动变成科学计数法... 弄过好几次都没有解决,最近又要导出excel了,下决心一定要找到解决办法 自己在excel里测试过,较长的数字,都会自动变成科学计数法,除非我们把单元格格式设置成“文本型” 哈哈,似乎找到了思路:用poi先把单元格设置成“文本型”就可以了把. 从文档里找到了这个方法HSSFCell.setCellType(int type),怎么看这个方法都

Java——jxl读取Excel文件

1.创建文件流,打开EXCEL文件(jxi不支持.xlsx文件,支持.xls) FileInputStream excelFile = new FileInputStream(excelPath); Workbook workbook = Workbook.getWorkbook(excelFile); 2.切换到对应文件名 Sheet excelSheet = workbook.getSheet(sheetName); 3.获取实际行数和列数 int rows = excelSheet.get

Java导入Excel文件

package com.cme.core; import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import java.io.IOException; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.util.Ar

Java POI导入Excel文件

今天在公司需要做个导入Excel文件的功能,所以研究了一下,参考网上的一些资料总算是做出来了,在此记录一下防止以后忘记怎么弄. 本人用的是poi3.8,所以需要的JAR包如下: poi-3.8.jar poi-excelant-3.8-20120326.jar poi-ooxml-3.8-20120326.jar poi-ooxml-schemas-3.8-20120326.jar poi-scratchpad-3.8-20120326.jar xmlbeans-2.3.0.jar 附上百度云盘

jxl创建Excel文件java代码示例

记得要下载 并 导入 jxl.jar 包,免积分下载地址:http://download.csdn.net/detail/u010011052/7561041 package Test; import java.io.*; import jxl.*; import jxl.format.Colour; import jxl.write.*; public class JXLTest { private static WritableWorkbook book; private static Wr

Java代码实现excel数据导入到Oracle

1.首先需要两个jar包jxl.jar,ojdbc.jar(注意版本,版本不合适会报版本错误)2.代码: Java代码   import java.io.File; import java.io.FileInputStream; import java.io.IOException; import java.io.InputStream; import jxl.Cell; import jxl.Sheet; import jxl.Workbook; import jxl.read.biff.Bi

解决从Excel导入数据库,导入到DataTable时数据类型发生变化的问题(如数字类型变成科学计数法,百分数变成小数)

做项目的时候,C#读取Excel数据到DataTable或者DataSet,设断点查看DataTable,发现Excel的显示为较长位数数字的字段如0.000012在DataTable中显示为科学计数法1.2E-05,而百分数如143%在DataTable中显示为1.43.可是我想Excel中显示的是什么数据,读取到DataTable或者DataSet后与Excel中完全一致,解决办法如下: 1)打开要导入的EXCEL,把所有数据全选中(Ctrl+A)----复制(Ctrl+C): 2)新建一个

jeecg3.5中的导入excel文件的使用及完善

jeecg中导入导出excel文件使用了jeecg团队自己开发的一个easypoi库,所以使用起来非常简单,以我项目中导入黑名单列表功能为例: 在实体中增加注解 先增加类的注解: @ExcelTarget("blackListEntity") public class BlackListEntity implements java.io.Serializable { 再增加字段注解: /**手机号码*/ @Excel(name="手机号码") private Lon

Java文件操作系列[2]——使用JXL操作Excel文件

由于java流无法实现对Excel文件的读写操作,因此在项目中经常利用第三方开源的组件来实现.支持Excel文件操作的第三方开源组件主要有Apache的POI和开源社区的JXL. 总体来说,二者的区别是:JXL较为轻量级,如果是对Excel文件的简单操作,建议使用JXL:POI的功能相当强大,但同时处理问题也相当的繁琐. 1.准备工作 [必需]下载JXL的jar包:jxl.jar [非必需]JXL API  (提取密码:zgqj) 2.一些必要的说明 主要是对Excel结构的说明: Excel后