1. 程式人生 > >QT:QOdbc 讀寫 excel資料

QT:QOdbc 讀寫 excel資料

新建空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();
}