QOdbc读写excel

php中文网
发布: 2016-06-07 15:55:34
原创
2241人浏览过

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

#include

Sider
Sider

多功能AI浏览器助手,帮助用户进行聊天、写作、阅读、翻译等

Sider 1731
查看详情 Sider
#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=''; 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('ctb', '28')");
登录后复制
    db.exec( "insert into sheet(name, age) values('xw', '19')");
登录后复制
    db.exec( "insert into sheet(name, age) values('lg', '34')");
登录后复制
    // 关闭数据库
登录后复制
    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();
登录后复制
}
登录后复制
写入结果:
登录后复制
读取打印结果
登录后复制
相关标签:
WPS零基础入门到精通全套教程!
WPS零基础入门到精通全套教程!

全网最新最细最实用WPS零基础入门到精通全套教程!带你真正掌握WPS办公! 内含Excel基础操作、函数设计、数据透视表等

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号