QT:QOdbc 讀寫 excel資料
阿新 • • 發佈:2019-02-02
新建空QT專案。
在.pro檔案中新增:
QT+=widgets
QT+=sql
新增main.cpp。
加入如下程式碼:
#include <QApplication> #include <QSqlDatabase> #include <QDebug> #include <QMessageBox> #include <QSqlQuery> #include <QVariant> void writeExcel(QString excelFilePath) { // 建立一個數據庫例項, 設定連線字串 QSqlDatabase db = QSqlDatabase::addDatabase("QODBC","excelexport"); QString dsn = QString("DRIVER={Microsoft Excel Driver (*.xls)};DSN=''; FIRSTROWHASNAMES=1; READONLY=FALSE;CREATE_DB=\"%1\";DBQ=%2"). arg(excelFilePath).arg(excelFilePath); db.setDatabaseName(dsn); // 開啟資料庫 if (!db.open()) { qDebug()<< "open false"; QMessageBox::about(NULL, "Message", "open false"); } // 建立表格 QString sql = "create table sheet (name TEXT, age NUMBER, job TEXT )"; QSqlQuery query(db); if (!query.exec(sql)) { qDebug()<< "create table false!"; QMessageBox::about(NULL, "Message", "create table false!"); } // 寫入資料 db.exec( "insert into sheet(name, age) values('Jim', '28')"); db.exec( "insert into sheet(name, age) values('Finch', '19')"); db.exec( "insert into sheet(name, age) values('Bob', '34')"); db.exec("insert into sheet(name, age) values('Lily', '25')"); // 關閉資料庫 db.close(); } void readExcel(const QString excelPath) { // excel 資料庫連線字串 需要QODBC 驅動 QSqlDatabase db = QSqlDatabase::addDatabase("QODBC","excelexport"); QString connString = QString("Driver={Microsoft Excel Driver (*.xls)};Readonly=1;DriverId=790;Dbq=%1;DefaultDir=D:\\").arg(excelPath); db.setDatabaseName(connString); // 開啟資料庫 if (!db.open()) { qDebug()<< "open false"; QMessageBox::about(NULL, "r", "open false"); } //查詢資料 QString sql = "Select * from [sheet$]"; QSqlQuery query(sql, db); while (query.next()) { //讀取資料 QString name = query.value(0).toString(); int age = query.value(1).toInt(); qDebug()<< name << age <<endl; } // 關閉資料庫 db.close(); } int main(int argc, char *argv[]) { QApplication a(argc, argv); //中文支援 //QTextCodec::setCodecForLocale(QTextCodec::codecForName("system")); //QTextCodec::setCodecForTr(QTextCodec::codecForName("system")); //QTextCodec::setCodecForCStrings(QTextCodec::codecForName("system")); writeExcel("D:\\test01.xls"); readExcel("D:\\test01.xls"); return a.exec(); }