搜索了一整天之后,我找不到问题的答案。我的问题是:为什么ODBC驱动程序返回第二个值,而不是第一个,代码是从format获取的。
在while循环中,我在第一步看到值为2,而在excel中,我有1。为什么?
感谢你的任何帮助
守则是:
srcdb.setDatabaseName("DRIVER={Microsoft Excel Driver (*.xls, *.xlsx, *.xlsm, *.xlsb)};DBQ=" + QString(getSettings("folderpath") + '/' + file));
if(srcdb.open()) {
QSqlQuery query("SELECT * FROM [" + QString("Sheet1") + "$A1:A3]"); // Select range, place A1:B5 after $
while (query.next()) {
QString column = query.value(0).toString();
qDebug() << column;
}
}
发布于 2014-10-28 15:20:59
在维基中发现了这个:
默认情况下,OBDC使用第一行作为列的名称,可以在连接设置中使用“FirstRowHasNames”选项更改此选项。请记住,您使用的是数据库,而且每个列都有自己的数据类型。因此,如果第二行包含文本,第三行包含数字,sql将从中选择一种数据类型。如果几行包含文本,其余行包含浮点数,则sql将使文本出现并使数字消失。
这就是为什么"2“被显示为第一。
https://stackoverflow.com/questions/26609440
复制相似问题