用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么的主要内容,如果未能解决你的问题,请参考以下文章
Python 读写操作Excel —— 安装第三方库(xlrdxlwtxlutils)
无法实现excel 和matlab连接,提示无法查证Spreadsheet link EX许可证或未安装Spreadsheet link EX.