1.如何使用Qt操作word,实现插入图片和表格的
使用Qt操作word的步骤:
1. 新建一个文件,在绘制好的表格需要插入数据的地方设置书签(插入-书签),另存为模版文件(.dot),以D:/template.dot为例。
2. 进入QT界面,选择新建工程,在跳出的选项中选择其他项目—空的Qt项目,选择继续。
3. 在main文件中几个主要步骤参考:
1)新建一个word应用程序,并设置为可见.
2)获取所有的工作文档并以文件template.dot为模版新建一个文档
3)获取当前激活的文档。
4)获取文档中名字为text的标签。
5)选中标签,将字符InsertText插入到标签位置。
6)获取文档中名字为pic的标签。
7)选中标签,将图片插入到标签位置。
8)将文件另存为docbyqt.doc,关闭工作文档,退出应用程序。
2.qt里面如何调用mplayer
!!在qt里面有一个类QProcess,这个类的作用是调用外部的可执行程序,在qt里面使用这个类来调用外面的mplayer来播放视频,在这里就需要在提到买player的一种播放模式——slave模式,这种模式下面,是通过管道发送给mplayer相应的信息(在qt里面调用了mplayer后,就相当于产生了一个进程),就是,简单的说,在这种模式下面,你可以在程序里面来写入相应的命令来控制mplayer的播放,下面给出一点相应的实现代码:首先,要创建一个累 = new QProcess(this);mplayerProcess->setProcessChannelMode(QProcess::MergedChannels); //这个一定要设置mplayerProgram = tr("/usr/bin/mplayer"); //你的mplayer的路径timeClock = new QTimer(this);接下来就是通过命令来控制mplayer播放了:QStringList args;args。
3.qt 怎么操作excel
Qt操作Excel主要通过 QAxObject + 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()QAxObject *work_book = excel.querySubObject("ActiveWorkBook"); QAxObject *work_sheets = work_book->querySubObject("Sheets"); //Sheets也可换用WorkSheets int sheet_count = work_sheets->property("Count").toInt(); //获取工作表数目 qDebug()for(int i=1; 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()} 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()。