QOdbc读写excel

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
リリース: 2016-06-07 15:55:34
オリジナル
1913 人が閲覧しました

#include QApplication #include QSqlDatabase #include QDebug #include QMessageBox #include QSqlQuery #include QVariant #include QTime #include QTextCodec void writeExcel(QString excelFilePath) { // 创建一个数据库实例, 设置连接字符串 QSqlDa

#include

#include <QSqlDatabase>
ログイン後にコピー
#include <QDebug>
ログイン後にコピー
#include <QMessageBox>
ログイン後にコピー
#include <QSqlQuery>
ログイン後にコピー
#include <QVariant>
ログイン後にコピー
#include <QTime>
ログイン後にコピー
#include <QTextCodec>
ログイン後にコピー
void writeExcel(QString excelFilePath)
ログイン後にコピー
{
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
    // 创建一个数据库实例, 设置连接字符串
ログイン後にコピー
    QSqlDatabase db = QSqlDatabase::addDatabase("QODBC","excelexport");
ログイン後にコピー
ログイン後にコピー
    QString dsn = QString("DRIVER={Microsoft Excel Driver (*.xls)};DSN=&#39;&#39;; 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, "r", "open false");
ログイン後にコピー
ログイン後にコピー
    }
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
    // 创建表格
ログイン後にコピー
    QString sql = "create table sheet (name TEXT, age NUMBER)";
ログイン後にコピー
    QSqlQuery query(db);
ログイン後にコピー
    if (!query.exec(sql))
ログイン後にコピー
    {
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
        qDebug()<< "create table false!";
ログイン後にコピー
        QMessageBox::about(NULL, "r", "create table false!");
ログイン後にコピー
    }
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
    // 写入数据
ログイン後にコピー
    db.exec( "insert into sheet(name, age) values(&#39;ctb&#39;, &#39;28&#39;)");
ログイン後にコピー
    db.exec( "insert into sheet(name, age) values(&#39;xw&#39;, &#39;19&#39;)");
ログイン後にコピー
    db.exec( "insert into sheet(name, age) values(&#39;lg&#39;, &#39;34&#39;)");
ログイン後にコピー
    // 关闭数据库
ログイン後にコピー
ログイン後にコピー
    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();
ログイン後にコピー
}
ログイン後にコピー
ログイン後にコピー
ログイン後にコピー
写入结果:
ログイン後にコピー
读取打印结果
ログイン後にコピー
関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート