将excel数据导入sql中,出现科学计数法
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了将excel数据导入sql中,出现科学计数法相关的知识,希望对你有一定的参考价值。
excel是先填入了数据,又设置成文本格式的,插入到sql的表中有的就显示成科学计数法的格式,有没有办法不修改excel的格式,修改代码,让表显示正确?
这个问题我遇到过。办法就是数据库建表的时候把对应列定义成字符型,如果需要计算或判断的时候记得转换格式,比如 oracle 中用 to_number,其他的可能是 cast。追问
我设置断点看了一下,程序中从excel中读取的时候就已经是科学计数法的格式了,比如在excel中数据时33010061,在代码中插入到表中时就已经是科学计数法了,是不是非得要先设置成文本格式,再填入数据才行?我现在这个是填入了数据了,又设置成文本格式的。
追答对,sql建表的时候就先设置成字符型。
追问sql的表是设置成varchar类型了,但excel是不是非得要先设置成文本格式,再填入数据才行?我现在这个是填入了数据了,又设置成文本格式的。
追答在excel中先填数字,再设置文本格式。插入数据库之前再看看excel,是不是已经变成科学计数法的样子了?
追问没有,不过如果excel中那一列的宽度很窄的话,就变成科学计数法了,如果是较宽的就正常显示。。。
追答那说明仍旧是格式。
参考技术A 用fill方法,直接将exel映射成table追问不是太懂,麻烦能详细说一下吗
追答昨天下班了,现在给你源代码看。再不行发邮件到我邮箱Router_Wu@hotmail.com给你解答!
DataTable dt = new DataTable();
try
string strConn = "Provider=Microsoft.Ace.OleDb.12.0;" + "data source=" + Path + ";Extended Properties='Excel 12.0; HDR=Yes; IMEX=1'"; //此连接可以操作.xls与.xlsx文件 (支持Excel2003 和 Excel2007 的连接字符串)
OleDbConnection conn = new OleDbConnection(strConn);
conn.Open();
string strExcel = "";
OleDbDataAdapter myCommand = null;
strExcel = "select * from ["+ TableName + "$]";//此处TableName是Excel的sheet名
myCommand = new OleDbDataAdapter(strExcel, strConn);
dt = new DataTable();
myCommand.Fill(dt);
conn.Close();
catch (Exception ex)
throw new Exception(ex.Message);
问题已经解决了,谢谢你了,不过没有分了。。。
参考技术B 你数据库的表是什么字段类型,如果是字符型,那么可以调整插入代码。如果不是,那么就是你的数据表结果显示工具的事情了。追问是varchar类型的。
追答如果这列肯定是数字的话,可以加个判断,如果是科学计数法,转换成数字。有现成的转换方法的。
来自:求助得到的回答 参考技术B 可以将字段设置保留几位数追问字段?什么意思,麻烦详细说一下,谢谢
追答是否可以将其设置为float类型
参考技术C excel设置文本格式你对整列设置就可以了,怎么会
“一个个双击”
呢
?
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数据导入sql中,出现科学计数法的主要内容,如果未能解决你的问题,请参考以下文章
SQL Server中如何把 科学记数法字符串 变为 数字字符串
excel导入csv格式 身份证号就变成科学计数法了,怎么转变回去