使用QT操作Excel 表格的常用方法

VBA 简介   

        Microsoft Office软件通常使用VBA来扩展Windows的应用程序功能,Visual Basic for Applications(VBA)是一种Visual Basic的一种宏语言。 在VBA的参考手册中就可以看到具体函数、属性的用法,Qt操作Excel主要通过 QAxObject + Excel VBA来实现!关于Qt对Excel的操作,网上的资料挺多的,但大多数都是比较基础的,关于插入工作表(至最后一行)、删除工作表、合并/拆分单元格、设置单元格背景色、设置单元格边框色、设置单元格字体(类型、大小、加粗、斜体、下划线、颜色等)、以及设置单元格对齐方式等用法都没有怎么提到,今天就总结一下有关Qt对Excel的操作。Qt操作Excel,无论后缀是xls还是xlsx都可以。下图是Excel VBA参考手册,内容不算太全!

 Excel读取

假设已存在一个excel文件,

主要读取内容:标题,工作表数目,工作表名称,起始行,起始列,行数,列数,单元格内容。

 

QAxObject excel("Excel.Application");  

excel.setProperty("Visible", true);  

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

work_books->dynamicCall("Open (const QString&)", QString("E:/test.xlsx"));
QVariant title_value = excel.property("Caption");  //获取标题

qDebug()<<QString("excel title : ")<<title_value;  

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

QAxObject *work_sheets = work_book->querySubObject("Sheets");  //Sheets也可换用WorkSheets

int sheet_count = work_sheets->property("Count").toInt();  //获取工作表数目

qDebug()<<QString("sheet count : ")<<sheet_count;  

for(int i=1; i<=sheet_count; i++)  

{  

QAxObject *work_sheet = work_book->querySubObject("Sheets(int)", i);  //Sheets(int)也可换用Worksheets(int)

QString work_sheet_name = work_sheet->property("Name").toString();  //获取工作表名称
QString message = QString("sheet ")+QString::number(i, 10)+ QString(" name");

qDebug()<<message<<work_sheet_name;  

}

if(sheet_count > 0)

{
QAxObject *work_sheet = work_book->querySubObject("Sheets(int)", 1);  

QAxObject *used_range = work_sheet->querySubObject("UsedRange");  

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

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

int row_start = used_range->property("Row").toInt();  //获取起始行   

int column_start = used_range->property("Column").toInt();  //获取起始列

int row_count = rows->property("Count").toInt();  //获取行数

int column_count = columns->property("Count").toInt();  //获取列数

for(int i=row_start; i

{  

for(int j=column_start; j

{  

QAxObject *cell = work_sheet->querySubObject("Cells(int,int)", i, j);  

QVariant cell_value = cell->property("Value");  //获取单元格内容

QString message = QString("row-")+QString::number(i, 10)+QString("-column-")+QString::number(j, 10)+QString(":");

qDebug()<<message<<cell_value;  

}  

}  

}

效果如下:

 

 Excel增、删、改

主要操作:

  • 设置标题
  • 插入工作表(至最后一行)
  • 设置工作表名称
  • 删除工作表
  • 设置单元格内容
  • 设置单元格字体(类型、大小、加粗、斜体、下划线、颜色等)
  • 设置单元格对齐方式
  • 设置单元格高度、宽度
  • 设置单元格背景色、边框色
  • 合并/拆分单元格
  • 清空单元格

代码如下:

QAxObject excel("Excel.Application");  

excel.setProperty("Visible", true);  

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

work_books->dynamicCall("Open(const QString&)", "E:\\test.xlsx");

excel.setProperty("Caption", "Qt Excel");

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

QAxObject *work_sheets = work_book->querySubObject("Sheets");  //Sheets也可换用WorkSheets

//删除工作表(删除第一个)

QAxObject *first_sheet = work_sheets->querySubObject("Item(int)", 1);

first_sheet->dynamicCall("delete");

//插入工作表(插入至最后一行)

int sheet_count = work_sheets->property("Count").toInt();  //获取工作表数目

QAxObject *last_sheet = work_sheets->querySubObject("Item(int)", sheet_count);

QAxObject *work_sheet = work_sheets->querySubObject("Add(QVariant)", last_sheet->asVariant());
last_sheet->dynamicCall("Move(QVariant)", work_sheet->asVariant());

work_sheet->setProperty("Name", "Qt Sheet");  //设置工作表名称

//操作单元格(第2行第2列)

QAxObject *cell = work_sheet->querySubObject("Cells(int,int)", 2, 2);

cell->setProperty("Value", "Java C++ C# PHP Perl Python Delphi Ruby");  //设置单元格值

cell->setProperty("RowHeight", 50);  //设置单元格行高

cell->setProperty("ColumnWidth", 30);  //设置单元格列宽

cell->setProperty("HorizontalAlignment", -4108); //左对齐(xlLeft):-4131  居中(xlCenter):-4108  右对齐(xlRight):-4152

cell->setProperty("VerticalAlignment", -4108);  //上对齐(xlTop)-4160 居中(xlCenter):-4108  下对齐(xlBottom):-4107

cell->setProperty("WrapText", true);  //内容过多,自动换行

//cell->dynamicCall("ClearContents()");  //清空单元格内容

QAxObject* interior = cell->querySubObject("Interior");

interior->setProperty("Color", QColor(0, 255, 0));   //设置单元格背景色(绿色)

QAxObject* border = cell->querySubObject("Borders"); 

border->setProperty("Color", QColor(0, 0, 255));   //设置单元格边框色(蓝色)

QAxObject *font = cell->querySubObject("Font");  //获取单元格字体

font->setProperty("Name", QStringLiteral("华文彩云"));  //设置单元格字体

font->setProperty("Bold", true);  //设置单元格字体加粗

font->setProperty("Size", 20);  //设置单元格字体大小

font->setProperty("Italic", true);  //设置单元格字体斜体

font->setProperty("Underline", 2);  //设置单元格下划线

font->setProperty("Color", QColor(255, 0, 0));  //设置单元格字体颜色(红色)

//设置单元格内容,并合并单元格(第5行第3列-第8行第5列)

QAxObject *cell_5_6 = work_sheet->querySubObject("Cells(int,int)", 5, 3);

cell_5_6->setProperty("Value", "Java");  //设置单元格值

QAxObject *cell_8_5 = work_sheet->querySubObject("Cells(int,int)", 8, 5);

cell_8_5->setProperty("Value", "C++");

QString merge_cell;

merge_cell.append(QChar(3 - 1 + 'A'));  //初始列

merge_cell.append(QString::number(5));  //初始行

merge_cell.append(":");

merge_cell.append(QChar(5 - 1 + 'A'));  //终止列

merge_cell.append(QString::number(8));  //终止行

QAxObject *merge_range = work_sheet->querySubObject("Range(const QString&)", merge_cell);

merge_range->setProperty("HorizontalAlignment", -4108);
merge_range->setProperty("VerticalAlignment", -4108);

merge_range->setProperty("WrapText", true);

merge_range->setProperty("MergeCells", true);  //合并单元格

//merge_range->setProperty("MergeCells", false);  //拆分单元格

//work_book->dynamicCall("Save()");  //保存文件(为了对比test与下面的test2文件,这里不做保存操作) work_book->dynamicCall("SaveAs(const QString&)", "E:\\test2.xlsx");  //另存为另一个文件 

work_book->dynamicCall("Close(Boolean)", false);  //关闭文件

excel.dynamicCall("Quit(void)");  //退出

 

效果如下:

操作前:

Qt之操作Excel

操作后:

Qt之操作Excel

    到这里很多人也许都在纳闷,单元格的宏怎么获取的?比如对齐方式(居中对齐),为什么值是-4108,而不是其他值呢?当然那不是我随便写的,自己可以录制宏,然后跟踪。

看下图:

Qt之操作Excel

  • 2
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Qt是一个跨平台的C++开发框架,提供了许多操作文件和表格的函数和类。要使用Qt操作Excel表格的书签,需要先安装并配置Qt的相关库。 首先,需要在Qt中引入相关的库。Qt提供了QAxObject类,用于操作COM组件。在Qt项目中,需要在.pro文件中添加`QT += axcontainer`以引入该库。 接下来,可以使用QAxObject的相关函数来读写Excel表格书签。首先,需要创建QAxObject对象,并调用其setControl函数来指定COM组件。在这里,我们需要指定Excel的COM组件: ```cpp QAxObject* excel = new QAxObject("Excel.Application"); ``` 然后,可以使用QAxObject的函数打开Excel表格,并获取工作簿和工作表: ```cpp QAxObject* workbooks = excel->querySubObject("Workbooks"); QAxObject* workbook = workbooks->querySubObject("Open(const QString&)", filePath); QAxObject* sheets = workbook->querySubObject("Worksheets"); QAxObject* sheet = sheets->querySubObject("Item(int)", sheetIndex); ``` 在获取到工作表后,可以使用QAxObject的相应函数操作Excel表格书签。具体的操作方法和函数,请参考Microsoft Excel的官方文档。 最后,记得在使用Excel后,调用相应的销毁函数来释放资源: ```cpp sheet->dynamicCall("Close()"); excel->dynamicCall("Quit()"); delete excel; ``` 这样,就可以使用Qt操作Excel表格书签了。需要注意的是,要确保计算机上安装了Microsoft Office并启用了相关功能。并且,在使用COM组件时要及时关闭和释放资源,以避免资源泄露。 总的来说,使用Qt操作Excel表格书签需要引入QAxObject类,并进行相应的函数调用。遵循以上步骤,可以顺利地读写Excel表格书签。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

视图猿人

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值