QOdbc读写excel

WBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWBOYWB
풀어 주다: 2016-06-07 15:55:34
원래의
1914명이 탐색했습니다.

#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으로 문의하세요.
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿