从excel导入数据库的数据变成科学计数法怎么办 急!!!
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了从excel导入数据库的数据变成科学计数法怎么办 急!!!相关的知识,希望对你有一定的参考价值。
从excel中得来的数据变成了科学计算法,可以通过更改单元格属性,得到相应的内容:1、一般excel单元格默认为“常规”属性,如下图输入数字:
2、结果会变成科学记数法:
3、更改单元格属性为“数值”,得到正确的答案:鼠标右键点击需要更改属性的单元格,选择单元格属性,选择属性为数值:
4、最终效果图:
参考技术A 简单的方法是先复制到TXT上,再导入数据库,如果EXCEL数据列不多,你可以设置成数字格式,保留两位小数后,逐一检查下EXCEL中数据是不是完整的显示了,如果EXCEL中数据仍然是科学记数法,你可以吧单元格稍微拉宽点,让他完整的显示后保存后再导入数据库 参考技术B 1.设置单元格为文本格式。
2.
选中单元格,右键,设置单元格格式。
3.数据前面加单引号。 参考技术C 导入什么数据库
。access
还是oracle,sql
server2000.
其实主要是格式的问题。
实在不行,把文本拷贝到
txt中,也支持导入的。 参考技术D 1、设置单元格为文本格式
2、数据前面加单引号
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;
}
以上是关于从excel导入数据库的数据变成科学计数法怎么办 急!!!的主要内容,如果未能解决你的问题,请参考以下文章
把excel导入sql server数据库日期类型变成科学计数法怎么办
excel导入csv格式 身份证号就变成科学计数法了,怎么转变回去
关于excel保存为csv格式后,重新打开文本型数字变为科学计数,且15位后面变成0??