用qt读写excel文件一定要安装excel么

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了用qt读写excel文件一定要安装excel么相关的知识,希望对你有一定的参考价值。

参考技术A 方法/步骤

首先,我们要创建一个项目并进行初步的项目设置,过程参见本系列文章的第一篇。这里就不再多说了,我们将项目文件从qtcreator中打开。

为了显示读取到的数据,我们先在界面文件中添加一个Label,如果读取了数据可以在这里显示一下进行验证。

然后,打开mainwindow.cpp文件,在其中引入适当的头文件,具体如图中所示。

接着,我们在头文件中打开置顶的excel文件,并对其中的对象类进行配置,因为前文已经介绍过,就不详细说了,具体代码如下:
QAxObject excel("Excel.Application");
excel.setProperty("Visible",false);
QAxObject *workbooks = excel.querySubObject("WorkBooks");
workbooks->dynamicCall("Open (const QString&)",QString("c:/a.xls"));
QAxObject *workbook = excel.querySubObject("ActiveWorkBook");//获取活动工作簿
QAxObject *worksheets = workbook->querySubObject("WorkSheets");//获取所有的工作表,如图

然后,我们开始获取第一工作表。

通过range查询对应的cell,然后获取cell中value值。代码如下:
QAxObject *range = worksheet->querySubObject("Cells(int,int)",1,1); //获取cell的值
QString strVal = range->dynamicCall("Value2()").toString();

接着,我们将得到的strVal显示label上用于验证是否成功读取。

我们再在c盘下新建一个a.xls文件,并且在第一个单元格输入一个字符串,如图所示.

之后,我们用程序运行下,查看程序是否达到预期的效果.可以看到程序运行成功了.本回答被提问者采纳

MFC怎么读写EXCEL文件

可以用多种方法,比如说用ODBC对excel数据库进行操作,或者说用excel 的COM接口进行编程。我找到一个例子关键代码如下:
//创建并写入Excel文件
void CRWExcel::WriteToExcel()

CDatabase database;
CString sDriver = "MICROSOFT EXCEL DRIVER (*.XLS)"; // Excel安装驱动
CString sExcelFile = "c:\\\\demo.xls"; // 要建立的Excel文件
CString sSql;

TRY

// 创建进行存取的字符串
sSql.Format("DRIVER=%s;DSN=\'\'\'\';FIRSTROWHASNAMES=1;READONLY=FALSE;CREATE_DB=\\"%s\\";DBQ=%s",
sDriver, sExcelFile, sExcelFile);

// 创建数据库 (既Excel表格文件)
if( database.OpenEx(sSql,CDatabase::noOdbcDialog) )

// 创建表结构(姓名、年龄)
sSql = "CREATE TABLE demo (Name TEXT,Age NUMBER)";
database.ExecuteSQL(sSql);

// 插入数值
sSql = "INSERT INTO demo (Name,Age) VALUES (\'\'徐景周\'\',26)";
database.ExecuteSQL(sSql);

sSql = "INSERT INTO demo (Name,Age) VALUES (\'\'徐志慧\'\',22)";
database.ExecuteSQL(sSql);

sSql = "INSERT INTO demo (Name,Age) VALUES (\'\'郭徽\'\',27)";
database.ExecuteSQL(sSql);


// 关闭数据库
database.Close();

CATCH_ALL(e)

TRACE1("Excel驱动没有安装: %s",sDriver);

END_CATCH_ALL;


// 读取Excel文件
void CRWExcel::ReadFromExcel()

CDatabase database;
CString sSql;
CString sItem1, sItem2;
CString sDriver;
CString sDsn;
CString sFile = "Demo.xls"; // 将被读取的Excel文件名

// 检索是否安装有Excel驱动 "Microsoft Excel Driver (*.xls)"
sDriver = GetExcelDriver();
if (sDriver.IsEmpty())

// 没有发现Excel驱动
AfxMessageBox("没有安装Excel驱动!");
return;


// 创建进行存取的字符串
sDsn.Format("ODBC;DRIVER=%s;DSN=\'\'\'\';DBQ=%s", sDriver, sFile);

TRY

// 打开数据库(既Excel文件)
database.Open(NULL, false, false, sDsn);

CRecordset recset(&database);

// 设置读取的查询语句.
sSql = "SELECT Name, Age "
"FROM demo "
"ORDER BY Name ";

// 执行查询语句
recset.Open(CRecordset::forwardOnly, sSql, CRecordset::readOnly);

// 获取查询结果
while (!recset.IsEOF())

//读取Excel内部数值
recset.GetFieldValue("Name ", sItem1);
recset.GetFieldValue("Age", sItem2);

// 移到下一行
recset.MoveNext();


// 关闭数据库
database.Close();


CATCH(CDBException, e)

// 数据库操作产生异常时...
AfxMessageBox("数据库错误: " + e->m_strError);

END_CATCH;
参考技术A

以上是关于用qt读写excel文件一定要安装excel么的主要内容,如果未能解决你的问题,请参考以下文章

MFC怎么读写EXCEL文件

python读写Excel方法(xlwt)

Python 读写操作Excel —— 安装第三方库(xlrdxlwtxlutils)

用python读写excel的强大工具:pyopenxl

无法实现excel 和matlab连接,提示无法查证Spreadsheet link EX许可证或未安装Spreadsheet link EX.

第17天---python办公自动化---读写Excel文件