首页 > 数据库 > mysql教程 > QOdbc读写excel

QOdbc读写excel

WBOY
发布: 2016-06-07 15:55:34
原创
1902 人浏览过

#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
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板