#include QApplication #include QSqlDatabase #include QDebug #include QMessageBox #include QSqlQuery #include QVariant #include QTime #include QTextCodec void writeExcel(QString excelFilePath) { // 创建一个数据库实例, 设置连接字符串 QSqlDa
#include
#include <QSqlDatabase>
Copier après la connexion
#include <QDebug>
Copier après la connexion
#include <QMessageBox>
Copier après la connexion
#include <QSqlQuery>
Copier après la connexion
#include <QVariant>
Copier après la connexion
#include <QTime>
Copier après la connexion
#include <QTextCodec>
Copier après la connexion
void writeExcel(QString excelFilePath)
Copier après la connexion
{
Copier après la connexion
Copier après la connexion
Copier après la connexion
// 创建一个数据库实例, 设置连接字符串
Copier après la connexion
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC","excelexport");
Copier après la connexion
Copier après la connexion
QString dsn = QString("DRIVER={Microsoft Excel Driver (*.xls)};DSN=''; FIRSTROWHASNAMES=1; READONLY=FALSE;CREATE_DB=\"%1\";DBQ=%2").
Copier après la connexion
arg(excelFilePath).arg(excelFilePath);
Copier après la connexion
db.setDatabaseName(dsn);
Copier après la connexion
// 打开数据库
Copier après la connexion
Copier après la connexion
if (!db.open())
Copier après la connexion
Copier après la connexion
{
Copier après la connexion
Copier après la connexion
Copier après la connexion
qDebug()<< "open false";
Copier après la connexion
Copier après la connexion
QMessageBox::about(NULL, "r", "open false");
Copier après la connexion
Copier après la connexion
}
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion
// 创建表格
Copier après la connexion
QString sql = "create table sheet (name TEXT, age NUMBER)";
Copier après la connexion
QSqlQuery query(db);
Copier après la connexion
if (!query.exec(sql))
Copier après la connexion
{
Copier après la connexion
Copier après la connexion
Copier après la connexion
qDebug()<< "create table false!";
Copier après la connexion
QMessageBox::about(NULL, "r", "create table false!");
Copier après la connexion
}
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion
// 写入数据
Copier après la connexion
db.exec( "insert into sheet(name, age) values('ctb', '28')");
Copier après la connexion
db.exec( "insert into sheet(name, age) values('xw', '19')");
Copier après la connexion
db.exec( "insert into sheet(name, age) values('lg', '34')");
Copier après la connexion
// 关闭数据库
Copier après la connexion
Copier après la connexion
db.close();
Copier après la connexion
Copier après la connexion
}
Copier après la connexion
Copier après la connexion
Copier après la connexion
void readExcel(const QString excelPath)
Copier après la connexion
{
Copier après la connexion
Copier après la connexion
Copier après la connexion
// excel 数据库连接字符串 需要QODBC 驱动
Copier après la connexion
QSqlDatabase db = QSqlDatabase::addDatabase("QODBC","excelexport");
Copier après la connexion
Copier après la connexion
QString connString = QString("Driver={Microsoft Excel Driver (*.xls)};Readonly=1;DriverId=790;Dbq=%1;DefaultDir=D:\\").arg(excelPath);
Copier après la connexion
db.setDatabaseName(connString);
Copier après la connexion
// 打开数据库
Copier après la connexion
Copier après la connexion
if (!db.open())
Copier après la connexion
Copier après la connexion
{
Copier après la connexion
Copier après la connexion
Copier après la connexion
qDebug()<< "open false";
Copier après la connexion
Copier après la connexion
QMessageBox::about(NULL, "r", "open false");
Copier après la connexion
Copier après la connexion
}
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion
//查询数据
Copier après la connexion
QString sql = "Select * from [sheet$]";
Copier après la connexion
QSqlQuery query(sql, db);
Copier après la connexion
while (query.next()) {
Copier après la connexion
//读取数据
Copier après la connexion
QString name = query.value(0).toString();
Copier après la connexion
int age = query.value(1).toInt();
Copier après la connexion
qDebug()<< name << age <<endl;
Copier après la connexion
}
Copier après la connexion
Copier après la connexion
Copier après la connexion
Copier après la connexion
// 关闭数据库
Copier après la connexion
Copier après la connexion
db.close();
Copier après la connexion
Copier après la connexion
}
Copier après la connexion
Copier après la connexion
Copier après la connexion
int main(int argc, char *argv[])
Copier après la connexion
{
Copier après la connexion
Copier après la connexion
Copier après la connexion
QApplication a(argc, argv);
Copier après la connexion
//中文支持
Copier après la connexion
QTextCodec::setCodecForLocale(QTextCodec::codecForName("system"));
Copier après la connexion
QTextCodec::setCodecForTr(QTextCodec::codecForName("system"));
Copier après la connexion
QTextCodec::setCodecForCStrings(QTextCodec::codecForName("system"));
Copier après la connexion
writeExcel("D:\\test01.xls");
Copier après la connexion
readExcel("D:\\test01.xls");
Copier après la connexion
return a.exec();
Copier après la connexion
}
Copier après la connexion
Copier après la connexion
Copier après la connexion
写入结果:
Copier après la connexion
读取打印结果
Copier après la connexion