QTword文档操作实例——根据word模板生成word报表

Posted coutcodes

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了QTword文档操作实例——根据word模板生成word报表相关的知识,希望对你有一定的参考价值。

链接地址:【QT】word文档操作实例——根据word模板生成word报表

引言

在QT5.3中,在.pro使用的是:QT += widgets gui axcontainer 来使用ActiveQt框架中的QAxContainer模块(Qt4版本添加Qt += qaxcontainer)=),所以在项目在头文件中包含QAxWidget和QAxObject。

简单介绍ActiveQt框架由两个模块组成:
QAxContainer模块允许我们使用COM对象并且可以在Qt应用程序中嵌入QActive控件。
QAxServer模块允许我们导出使用Qt编写的自定义的COM对象和Active控件。

一、word模板准备

模板的准备至关重要,而其中更重要的是模板中书签的设置命名,因为接下来的程序代码中,程序就是根据书签的名字,来定位word文档中的位置,从而进行数据的插入修改

当设计好表格,并且设计好书签的名称,便将文档保存为 .dot格式

技术图片
技术图片

二、WordDemo实现

代码中都有详尽的注释

1、mainwindow.ui

技术图片

技术图片

2、mainwindow.h

#ifndef MAINWINDOW_H
#define MAINWINDOW_H

#include <QMainWindow>

QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACE

class MainWindow : public QMainWindow
{
    Q_OBJECT

public:
    MainWindow(QWidget *parent = nullptr);
    ~MainWindow();

    void init_UI();		//初始化界面函数
    void clear_UI();	//重置界面函数


private slots:
    void reshow();			//重置界面的槽函数
    void create_word();		//创建报表的槽函数

private:
    Ui::MainWindow *ui;



};
#endif // MAINWINDOW_H

3、mainwindow.cpp

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QAxObject>
#include <QAxWidget>
#include <QMessageBox>
#include <QFileDialog>
#include <QDebug>

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
    , ui(new Ui::MainWindow)
{
    ui->setupUi(this);
    init_UI();

    connect(ui->btu_create,SIGNAL(clicked(bool)),this,SLOT(create_word()));
    connect(ui->btu_create,SIGNAL(clicked(bool)), this, SLOT(reshow()));
}

MainWindow::~MainWindow()
{
    delete ui;
}

void MainWindow::create_word()
{
    //新建一个word应用程序
    QAxWidget *word = new QAxWidget("Word.Application",0,Qt::MSWindowsOwnDC);
    //并设置为不可见
    word->setProperty("Visible",false);
    //获取所有的工作文档
    QAxObject *documents = word->querySubObject("Documents");
    //以test2.dot为模板新建一个文档
    documents->dynamicCall("Add(QString)",QString::fromLocal8Bit("E:/MyQtWorkSpace/Word/test2.dot"));
    //获取当前激活的文档
    QAxObject *document = word->querySubObject("ActiveDocument");

    /********修改一个位置的内容*********/
    //获取文档中名字为equ的标签
    QAxObject *bookmark_equ = document->querySubObject("Bookmarks(QVariant)","equ");
    //选中标签,将字符textg插入到标签位置
    if(!bookmark_equ->isNull())
    {
        QString sText=ui->lineEdit_equ->text();                          //此处为替换内容
        qDebug()<<sText;
        bookmark_equ->dynamicCall("Select(void)");                             //选中要选中的区域
        bookmark_equ->querySubObject("Range")->setProperty("Text",sText);      //进行替换操作
    }

    /********修改一个位置的内容*********/
    //获取文档中名字为temp的标签
    QAxObject *bookmark_temp = document->querySubObject("Bookmarks(QVariant)","temp");
    //选中标签,将字符textg插入到标签位置
    if(!bookmark_equ->isNull())
    {
        QString pText=ui->lineEdit_temp->text();                          //此处为替换内容
        bookmark_temp->dynamicCall("Select(void)");                             //选中要选中的区域
        bookmark_temp->querySubObject("Range")->setProperty("Text",pText);      //进行替换操作
    }

    /********修改一个位置的内容*********/
    //获取文档中名字为bas的标签
    QAxObject *bookmark_bas = document->querySubObject("Bookmarks(QVariant)","bas");
    //选中标签,将字符textg插入到标签位置
    if(!bookmark_equ->isNull())
    {
        QString bText=ui->lineEdit_bas->text();                                 //此处为替换内容
        bookmark_bas->dynamicCall("Select(void)");                             //选中要选中的区域
        bookmark_bas->querySubObject("Range")->setProperty("Text",bText);      //进行替换操作
    }
    qDebug()<<"方法";

    //修改word中的表格
    QString sheethead = "序号";
    for(int j=1;j<=4;j++)
    {
        QString addrowhead=QString("%1").arg(j);
        QString sheetheadnumber = QString("%1%2").arg(sheethead).arg(addrowhead);
        qDebug()<<sheetheadnumber;

        QAxObject *sheethead = document->querySubObject("Bookmarks(QVariant)",sheetheadnumber);
        QString sheettexthead=ui->tableWidget->item(j-1,0)->text();                             //此处为替换内容
        sheethead->dynamicCall("Select(void)");                                                 //选中要选中的区域
        sheethead->querySubObject("Range")->setProperty("Text",sheettexthead);                  //进行替换操作
    }

    QString sheetfrist = "数据";
    for(int i=1;i<=4;i++)
    {
        for(int j=1;j<5;j++)
        {
            QString addrow=QString("%1").arg(i);
            QString addcolum=QString("%1").arg(j);

            QString sheetlabel = QString("%1%2%3").arg(sheetfrist).arg(addrow).arg(addcolum);
            qDebug()<<sheetlabel;

            QAxObject *sheetdata = document->querySubObject("Bookmarks(QString)",sheetlabel);
            QString sheettext=ui->tableWidget->item(i-1,j)->text();                     //此处为替换内容,必须要加入.text().这样返回值才会正确
            sheetdata->dynamicCall("Select(void)");                                     //选中要选中的区域
            sheetdata->querySubObject("Range")->setProperty("Text",sheettext);          //进行替换操作
        }
    }


    //将文件保存为doc,同样可以生成docx文档
    QString pathsave = QFileDialog::getSaveFileName(this,"Save","../","word(*doc)");
    if(pathsave.isEmpty()==true)
    {
        return;
    }
    document->dynamicCall("SaveAs(const QString&))",QDir::toNativeSeparators(pathsave));
    document->dynamicCall("Close (boolean)",false);
    word->dynamicCall("Quit()");
    QMessageBox::warning(this,"完成","文件已经保存",QMessageBox::Yes);

}

void MainWindow::init_UI()
{
    int col = 5;
    int row = 4;
    ui->tableWidget->setColumnCount(col);
    ui->tableWidget->setRowCount(row);
    QStringList header; //表头写入表格
    header <<QString::fromUtf8("序号")
          <<QString::fromUtf8("测试数据1")<<QString::fromUtf8("测试数据2")
         <<QString::fromUtf8("测试数据3")<<QString::fromUtf8("测试数据4");
    ui->tableWidget->setHorizontalHeaderLabels(header);
    ui->tableWidget->horizontalHeader()->setStretchLastSection(true);   //自动调整宽度
    ui->tableWidget->verticalHeader()->hide();

    QString num[4]={"1","2","3","4"};
    for(int i=0;i<row;i++)  //序号填充
    {
        ui->tableWidget->setItem(i,0,new QTableWidgetItem(num[i]));
    }
    QString data[4][4]={{"5","7","8","6"},
                        {"4","6","5","9"},
                        {"7","5","5","6"},
                        {"8","3","4","6"}};
    for(int i=0;i<4;i++)    //随机数据填充
    {
        for(int j=1;j<5;j++)
        {
            ui->tableWidget->setItem(i,j,new QTableWidgetItem(data[i][j]));
        }
    }
}

void MainWindow::clear_UI()
{
    ui->lineEdit_bas->clear();
    ui->lineEdit_equ->clear();
    ui->lineEdit_temp->clear();
}

void MainWindow::reshow()
{
    clear_UI();
    this->show();
}

三、实现效果

修改数据

技术图片

点击生成

技术图片

点击保存

技术图片

点击Yes

技术图片

完成效果

技术图片

如有不足之处,还望指正 [1]


  1. 如果对您有帮助可以点赞、收藏、关注,将会是我最大的动力 ??





以上是关于QTword文档操作实例——根据word模板生成word报表的主要内容,如果未能解决你的问题,请参考以下文章

QTword文档操作实例——根据word模板生成word报表

跪求POI根据模板生成word文档的例子。 注意啦,是用书签标记的方式,替换书签中的内容。

java如何根据word模板生成word文档

Python 自动化:根据模板批量生成含指定数据的 word 文档

python依据模板生成word文件

java poi-tl 根据模板生成word合并多个word文档