zoukankan      html  css  js  c++  java
  • 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;
    	}
    
  • 相关阅读:
    【sqlalchemy】使用正确的DB_URI却报错密码错误-密码中包含特殊符号导致
    为什么只调用了1次函数,但是该函数却被执行了2次呢?
    【flask】使用类组织配置-使用工厂函数创建程序实例
    【python3】configparser读取ini配置文件
    【flask】使用配置类管理app测试环境-demo版
    【flask】flask项目配置 app.config
    【flask】环境配置-python-dotenv的使用
    从pip+requirements.txt+virtualenv管理依赖到使用pipenv管理依赖-修改布署方式
    【MAC】安装chrome浏览器
    【MAC】图片编辑工具-合成图片
  • 原文地址:https://www.cnblogs.com/seesun2012/p/9214758.html
Copyright © 2011-2022 走看看