Qt利用QAxWidget读取excel文件

QAxWidget Qt
0 91
suoniao 2021-01-20
需要:0索币

连接Excel控件

QAxWidget excel("Excel.Application");

显示当前窗口:
excel.setProperty("Visible", true);

 更改 Excel 标题栏:
excel.setProperty("Caption", "Invoke Microsoft Excel");

不显示任何警告信息

setProperty("DisplayAlerts",0)

添加新工作簿:
QAxObject * workbooks = excel.querySubObject("WorkBooks");
workbooks->dynamicCall("Add");

打开已存在的工作簿:
workbooks->dynamicCall("Open (const QString&)", QString("c:/test.xls"));

获取活动工作簿:
QAxObject * workbook = excel.querySubObject("ActiveWorkBook");

获取所有的工作表:
QAxObject * worksheets = workbook->querySubObject("WorkSheets");

获取工作表数量:
int intCount = worksheets->property("Count").toInt();

获取第一个工作表:
QAxObject * worksheet = workbook->querySubObject("Worksheets(int)", 1);

获取cell的值:
QAxObject * range = worksheet->querySubObject("Cells(int,int)", 1, 1 );

获取已使用区域

m_pworksheet->querySubObject("UsedRange")

获取行数

QAxObject *rows = usedrange->querySubObject("Rows"); 

int nRows = rows->property("Count").toInt();

获取列数

QAxObject *columns = usedrange->querySubObject("Columns");

int nCols = columns->property("Count").toInt();

以上操作不一定每个都可用(都好用),仅作为参考吧。起码我第9)个就没成功,不知为何?后来我改用了Range(QVariant, QVariant)的方法来替代它。

回帖
  • 消灭零回复
广告位招租 100元/月 广告位招租 100元/月
相关主题
QT程序闪退错误捕获教程利用DbgHelp 错误调试技术 0
使用CMAKE 配置TagLIb QT5 编译使用TagLib 0
QT实现Excel文件转CSV文件利用QAxObject库 0
QT实现Excel转PDF利用QAxObject库 0
Qt利用QAxWidget读取excel文件 0
Qt条件变量QWaitCondition使用教程 0
Qtcreator cannot open output file debug/suoniao.exe:Permission denied 0
Qt的对象树模型 Qt内存泄漏的原因分析 0
Qt有关QdateTime方法详解 0
Qt基础教程值QByteArray字节容器的使用详解 0
Qt读取打印机设备列表QPrinterInfo类实现 0
Qt利用QFile和QTextStream实现文件的读和写 0
Qt利用map映射读取超大文件 0
Qt高频率读取串口或者写入串口导致运行程序内存占用不断提升 0
QT实现HTTP协议 出现failed to load resource : net :: ERR_CONNECTION_RESET 0
C++相关视频教程合辑 0
C++界面库 Qt嵌入式开发从入门到精通 1604 0
c++就业班13期完整教程 2339 0
就业班C++培训完整版教程移动打车项目安全传输平台项目2504 0
C语言和C++就业班15期培训教程2502 0
相关主题
索鸟快传2.1.0版本发布 0
golang网络数据读取timeout的处理 – 以SetReadDeadline为例 0
索鸟网广告位招租 0
golang利用通道chan实现一个通用的TCP连接池 0
frpc和frps的交互流程详解了解了frp是如何进行TCP代理的 0
golang实现内存池 go语言字节池byte pool实现代码 0
golang网络编程之基于TCP协议实现长连接 golang心跳检测 0
国产光刻机产业链最新核心材料ArF 193nm光刻胶通过用户认证 0
javascript数组相关函数length属性、delete关键字、pop()栈方法、shift() 0
Qt为我们提供了几个可以用于线程Sleep的函数msleep和usleep 0
QT程序闪退错误捕获教程利用DbgHelp 错误调试技术 0
简单快速修改Qtcreator项目工程的名称 0
golang 的interface接口类型断言 0
golang类型断言type的使用 0
golang依赖包管理 mod使用教程 0
golang表单验证库validator 0
如何使用Go语言实现一个简单的异步任务框架呢?生产者消费者模型 0
内网穿透反向代理工具frp实现TCP协议代理源码分析 0
内网穿透反向代理库frp的实现原理分析一 0
什么是socks5?socks5 是一个简单的代理协议 0