Qt 源码之 Qt 操作 Excel

移动开发
Qt 源码之 Qt 操作 Excel,通过几个简单的操作为大家讲解有关Qt 中Excel的操作。先来看内容。

Qt 源码之 Qt 操作 Excel是本文丫介绍的内容,先来看内容:QAxWidget excel("Excel.Application");

1、显示当前窗口:

excel.setProperty("Visible", true);

2、更改 Excel 标题栏:

excel.setProperty("Caption", "Invoke Microsoft Excel");

3、添加新工作簿:

QAxObject * workbooks = excel.querySubObject("WorkBooks");

workbooks->dynamicCall("Add");

4、打开已存在的工作簿:

workbooks->dynamicCall("Open (const QString&)", QString("c:/test.xls"));

5、获取活动工作簿:

QAxObject * workbook = excel.querySubObject("ActiveWorkBook");

6、获取所有的工作表:

QAxObject * worksheets = workbook->querySubObject("WorkSheets");

7、获取工作表数量:

int intCount = worksheets->property("Count").toInt();

8、获取***个工作表:

QAxObject * worksheet = workbook->querySubObject("Worksheets(int)", 1);

9、获取cell的值:

QAxObject * range = worksheet->querySubObject("Cells(int,int)", 1, 1 );

示例代码:

  1. view plaincopy to clipboardprint?  
  2. #include <QtGui>     
  3. #include <QAxObject>     
  4. #include <QAxWidget>     
  5. #include <qaxselect.h>     
  6. int main(int argc, char **argv)     
  7. {     
  8.     QApplication a(argc, argv);     
  9.     QAxSelect select;     
  10.     select.show();     
  11.     QAxWidget excel("Excel.Application");     
  12.     excel.setProperty("Visible", true);     
  13.     QAxObject * workbooks = excel.querySubObject("WorkBooks");     
  14.     workbooks->dynamicCall("Open (const QString&)", QString("c:/test.xls"));     
  15.     QAxObject * workbook = excel.querySubObject("ActiveWorkBook");     
  16.     QAxObject * worksheets = workbook->querySubObject("WorkSheets");     
  17.     int intCount = worksheets->property("Count").toInt();     
  18.     for (int i = 1; i <= intCount; i++)     
  19.     {     
  20.         int intVal;     
  21.         QAxObject * worksheet = workbook->querySubObject("Worksheets(int)", i);     
  22.         qDebug() << i << worksheet->property("Name").toString();     
  23.         QAxObject * range = worksheet->querySubObject("Cells(1,1)");     
  24.         intVal = range->property("Value").toInt();     
  25.         range->setProperty("Value", QVariant(intVal+1));     
  26.         QAxObject * range2 = worksheet->querySubObject("Range(C1)");     
  27.         intVal = range2->property("Value").toInt();     
  28.         range2->setProperty("Value", QVariant(intVal+1));     
  29.     }     
  30.     QAxObject * worksheet = workbook->querySubObject("Worksheets(int)", 1);     
  31.     QAxObject * usedrange = worksheet->querySubObject("UsedRange");     
  32.     QAxObject * rows = usedrange->querySubObject("Rows");     
  33.     QAxObject * columns = usedrange->querySubObject("Columns");     
  34.     int intRowStart = usedrange->property("Row").toInt();     
  35.     int intColStart = usedrange->property("Column").toInt();     
  36.     int intCols = columns->property("Count").toInt();     
  37.     int intRows = rows->property("Count").toInt();     
  38.     for (int i = intRowStart; i < intRowStart + intRows; i++)     
  39.     {     
  40.         for (int j = intColStart; j <= intColStart + intCols; j++)     
  41.         {     
  42.             QAxObject * range = worksheet->querySubObject("Cells(int,int)", i, j );     
  43.             qDebug() << i << j << range->property("Value");     
  44.         }     
  45.     }     
  46.     excel.setProperty("DisplayAlerts", 0);     
  47.     workbook->dynamicCall("SaveAs (const QString&)", QString("c:/xlsbyqt.xls"));     
  48.     excel.setProperty("DisplayAlerts", 1);     
  49.     workbook->dynamicCall("Close (Boolean)", false);     
  50.     excel.dynamicCall("Quit (void)");     
  51.     return a.exec();     
  52. }   

小结:Qt 源码之 Qt 操作 Excel的内容介绍完了,希望本文对你有所帮助,原文来自: http://blog.csdn.net/tingsking18/archive/2010/06/18/5677353.aspx

责任编辑:zhaolei 来源: CSDN
相关推荐

2011-06-23 14:05:32

Qt 事件机制

2011-06-23 15:10:39

Qt 窗体

2011-06-23 15:32:05

Qt Windows消息

2011-06-23 13:38:27

QT 元对象 信号

2011-06-23 14:40:13

Qt 信号

2011-06-23 13:25:42

QT 源码 窗口

2011-07-05 14:46:34

2011-06-09 18:05:00

QT MySql

2011-06-28 16:18:24

Qt QObject

2011-06-16 11:28:48

Qt QApplicati

2011-06-20 13:05:53

Qt 4.7 Qt Quick

2011-07-04 17:18:23

Qt SQLite 数据库

2011-06-20 13:54:41

Qt 动态 切换

2011-06-10 12:44:09

2011-06-23 14:27:48

QT QLibrary 动态库

2011-07-05 15:16:00

QT 进度条

2011-06-15 09:02:01

Qt QDomDocume XML

2011-06-13 09:04:39

QT Flash 交互

2011-06-24 17:38:09

Qt 坐标 事件

2011-06-21 14:53:25

QT 界面美化 QStyle
点赞
收藏

51CTO技术栈公众号