首页 > 其他分享 >QtableWidget 表头增加复选框简单实现方法

QtableWidget 表头增加复选框简单实现方法

时间:2024-03-25 20:23:13浏览次数:22  
标签:pItem exe QtableWidget 表头 复选框 tableWidget ui QString signature

1.最近再开发一个批量查询上传的小工具,要增加一个批量选择的复选框,全选或者全不选;

QCheckBox *checkBox = new QCheckBox(ui.tableWidget);
        checkBox->resize(40, 24);
        ui.tableWidget->setCellWidget(0, 0, checkBox);
        checkBox->setStyleSheet("margin-left:4px;");//左侧的偏移量,不设置QCheckBox会紧靠左边,没有和下面的对齐;
        checkBox->setChecked(false);
        ui.tableWidget->setColumnWidth(0, 24);
        ui.tableWidget->setColumnWidth(1, 40);
        connect(checkBox, &QCheckBox::clicked, this, &signature::SelectAllFiles);

 

 

其他函数实现如下

#include "signature.h"
#include "MultiFileDirDialog.h"
#include <QFileInfoList>
#include "curl.h"
#include<QProcess>
#include <QMessageBox>
#include <QCheckBox>
#pragma execution_character_set("utf-8")
signature::signature(QWidget *parent)
    : QMainWindow(parent)
{
    ui.setupUi(this);
    setWindowTitle(tr("批量数字签名工具"));
        connect(ui.pBSouuce, &QPushButton::clicked, this, [=]() {
            QString strPath = SlotGetPath();
            ui.lineEditInputPath->setText(strPath);
            StartSearchFile();
            
    });
        connect(ui.pBTarget, &QPushButton::clicked, this, [=]() {
            QString strPath = SlotGetPath();
            ui.lineEditOutPutPath->setText(strPath);
            m_strTargetPath = strPath;
        });
        ui.tableWidget->setColumnCount(3);
        ui.tableWidget->verticalHeader()->setVisible(false);
        /*connect(ui.pBSearch, &QPushButton::clicked, this, [=]() {
            StartSearchFile();
        });*/
        connect(ui.pushCopyFile, &QPushButton::clicked, this, [=]() {
            StartCopyFile();
        });
        /*connect(ui.pushReturn, &QPushButton::clicked, this, [=]() {
            CopyFileToSourcePath();
        });*/
        connect(ui.pBUpload, &QPushButton::clicked, this, [=]() {
            StartUploadFileToSignature();
        });
        m_mapExceptFile["vcredist_x86_2015.exe"] = "vcredist_x86_2015.exe";
        m_mapExceptFile["vcredist_x86_2008.exe"] = "vcredist_x86_2008.exe";
        m_mapExceptFile["vcredist_x64_2015.exe"] = "vcredist_x64_2015.exe";
        m_mapExceptFile["vcredist_x64_2008.exe"] = "vcredist_x64_2008.exe";
        m_mapExceptFile["JITComVCTK_S.exe"] = "JITComVCTK_S.exe";
        m_mapExceptFile["7za.exe"] = "7za.exe";
        m_mapExceptFile["openssl.exe"] = "openssl.exe";
        m_mapExceptFile["iDentifyCmd.exe"] = "iDentifyCmd.exe";
        m_mapExceptFile["WinPcap_4_1_3.exe"] = "WinPcap_4_1_3.exe";
        m_mapExceptFile["unins000.exe"] = "unins000.exe";
        //curl_global_init(CURL_GLOBAL_ALL);
        ui.widgetProgress->hide();
        connect(&m_UploadFileThread, &UploadFileThread::signalProgress, this, [=](int progrss) {
            ui.progressBar->setValue(progrss);
        }, Qt::QueuedConnection);
        connect(&m_UploadFileThread, &UploadFileThread::finished, this, [=]() {
            QMessageBox::information(NULL, "提示", QString("已完成%1程序文件的数字签名!").arg(m_mapInfo.size()), QMessageBox::Ok);
            ui.widgetProgress->hide();
            ui.pBUpload->setDisabled(false);
            ui.pushCopyFile->setDisabled(false);
            //ui.pushReturn->setDisabled(false);
            ui.pBSouuce->setDisabled(false);
            //ui.pBSearch->setDisabled(false);
            ui.pBTarget->setDisabled(false);
        }, Qt::QueuedConnection);
        QCheckBox *checkBox = new QCheckBox(ui.tableWidget);
        checkBox->resize(40, 24);
        ui.tableWidget->setCellWidget(0, 0, checkBox);
        checkBox->setStyleSheet("margin-left:4px;");
        checkBox->setChecked(false);
        ui.tableWidget->setColumnWidth(0, 24);
        ui.tableWidget->setColumnWidth(1, 40);
        connect(checkBox, &QCheckBox::clicked, this, &signature::SelectAllFiles);
        
}

signature::~signature()
{
    //curl_global_cleanup();
}
//获取文件夹路径
QString signature::SlotGetPath()
{
    MultiFileDirDialog fileDialog(NULL);
    fileDialog.setOption(QFileDialog::ShowDirsOnly, true);
    fileDialog.setWindowTitle("选择文件夹");
    //m_pMultiFileDialog->setFileMode(QFileDialog::Directory);
    if (fileDialog.exec() == QDialog::Accepted)
    {
        QStringList selectFiles = fileDialog.selectedFiles();
        if (selectFiles.size() > 0)
        {
            return selectFiles[0];
        }
    }
    return "";
}
/*查询源文件夹exe文件*/
void signature::StartSearchFile()
{
    QString strInputPath = ui.lineEditInputPath->text();
    if (strInputPath=="")
    {
        return;
    }
    QStringList listFile;
    RecursiveInputDirFiles(strInputPath, listFile);
    if (listFile.size()==0)
    {
        return;
    }
    while (ui.tableWidget->rowCount() > 0) {
        ui.tableWidget->removeRow(0);
    }
    QTableWidgetItem* pItem = NULL;
    for (int i = 0; i < listFile.size(); i++)
    {
        QTableWidgetItem *check = new QTableWidgetItem();
        check->setCheckState(Qt::Unchecked);  //是否设置选中框
        ui.tableWidget->insertRow(i);
        ui.tableWidget->setItem(i, 0, check); //插入复选框
        pItem = new QTableWidgetItem();
        pItem->setText(QString::number(i+1));
        ui.tableWidget->setItem(i, 1, pItem);
        pItem = new QTableWidgetItem();
        pItem->setText(listFile[i]);
        ui.tableWidget->setItem(i,2, pItem);
        
    }
}
/*复制源文件夹exe到目标文件夹下*/
void signature::StartCopyFile()
{
    if (m_strTargetPath=="")
    {
        QMessageBox::warning(NULL, "提示", "目标文件夹为空,请选择目标文件夹", QMessageBox::Ok);
        return;
    }
    GetAllSelectFile();
    if (m_mapInfo.size()==0)
    {
        QMessageBox::warning(NULL, "提示", "请选择要复制的文件", QMessageBox::Ok);
        return;
    }
    RemoveAllFile(m_strTargetPath);
    ui.textEdit->setText("");
    QString strExeName = "";
    for (auto it= m_mapInfo.begin();it!=m_mapInfo.end();it++)
    {
        QString strTargetPath="";
        QString strPath = it.key();
        QFileInfo file(strPath);
        strTargetPath = m_strTargetPath + "/" + file.fileName();
        QFile::copy(strPath, strTargetPath);//从源路径将文件复制到目标路径
        strExeName += file.fileName();
        strExeName += "\n";
    }
    ui.textEdit->setText(strExeName);
}
/*开始上传文件进行签名*/
void signature::StartUploadFileToSignature()
{
    GetAllSelectFile();
    if (m_mapInfo.size()==0)
    {
        QMessageBox::warning(NULL, "提示","未选中的需要上传的exe文件!",QMessageBox::Ok);
        return;
    }
    ui.progressBar->setValue(0);
    ui.widgetProgress->show();
    m_UploadFileThread.SetFiles(m_mapInfo);
    ui.pBUpload->setDisabled(true);
    ui.pushCopyFile->setDisabled(true);
    //ui.pushReturn->setDisabled(true);
    ui.pBSouuce->setDisabled(true);
    //ui.pBSearch->setDisabled(true);
    ui.pBTarget->setDisabled(true);
}
//选择或这全不选
void signature::SelectAllFiles(bool isChecked)
{
    int count = ui.tableWidget->rowCount();
    QTableWidgetItem* pItem = NULL;
    QString strExeName = "";
    for (int i = 0; i < count; i++)
    {
        pItem = ui.tableWidget->item(i, 0);
        if (pItem == NULL)
        {
            continue;
        }
        pItem->setCheckState(isChecked? Qt::Checked:Qt::Unchecked);
    }
}
//查找所有勾选的文件
void signature::GetAllSelectFile()
{
    m_mapInfo.clear();
    int count = ui.tableWidget->rowCount();
    QTableWidgetItem* pItem = NULL;
    QString strExeName = "";
    for (int i = 0; i < count; i++)
    {
        pItem = ui.tableWidget->item(i, 0);
        if (pItem == NULL)
        {
            continue;
        }
        if (pItem->checkState() != Qt::Checked)
        {
            continue;
        }
        pItem = ui.tableWidget->item(i, 2);
        QString strTargetPath = "";
        if (pItem != NULL)
        {
            QString strPath = pItem->text();
            QFileInfo file(strPath);
            m_mapInfo.insert(strPath, file.fileName());    
        }
    }
}

/*递归遍历文件夹下面的子文件夹,查找exe程序*/
void signature::RecursiveInputDirFiles(QString strDir, QStringList& ExeFiles)
{
    QDir dirFile(strDir);
    QDir dirDir(strDir);
    if (!dirDir.exists())
    {
        return;
    }

    dirFile.setSorting(QDir::Time);//优先显示目录
    dirDir.setSorting(QDir::Time);

    //列出dir(path)目录文件下所有文件和目录信息,存储到file_list容器
    QStringList fileNameFilter;
    //视频格式
    fileNameFilter << "*.exe";
    dirFile.setNameFilters(fileNameFilter);
    QFileInfoList file_list = dirFile.entryInfoList(QDir::Files );//| QDir::Hidden | QDir::NoSymLinks
    //列出dir(path)目录下所有子文件夹
    QFileInfoList folder_list = dirDir.entryInfoList(QDir::Dirs | QDir::Hidden | QDir::NoDotAndDotDot);
    if (file_list.size() == 0 && folder_list.size() == 0)
    {
        return;
    }
    //添加视频文件到列表
    QString strfilepath = "";
    for (int i = 0; i < file_list.size(); i++)
    {
        strfilepath = file_list[i].absoluteFilePath();
        QFileInfo file(strfilepath);
        QString strFileName = file.fileName();
        if (m_mapExceptFile.find(strFileName) != m_mapExceptFile.end())
        {
            continue;
        }
        ExeFiles.append(strfilepath);
    }

    //进行子文件夹folder_list递归遍历,将内容存入file_list容器
    for (int i = 0; i != folder_list.size(); i++)
    {
        RecursiveInputDirFiles(folder_list.at(i).absoluteFilePath(), ExeFiles);
    }
}
/*先清空目标文件夹下的exe文件*/
void signature::RemoveAllFile(QString strPath)
{
    QDir dirFile(strPath);
    QFileInfoList file_list = dirFile.entryInfoList(QDir::Files);//| QDir::Hidden | QDir::NoSymLinks
                                                                 //列出dir(path)目录下所有子文件夹
    
    //添加视频文件到列表
    QString strfilepath = "";
    for (int i = 0; i < file_list.size(); i++)
    {
        strfilepath = file_list[i].absoluteFilePath();
        QFile::remove(strfilepath);
    }
}
/*用目标文件夹下的签名文件反向替换源文件夹下的未签名文件*/
void signature::CopyFileToSourcePath()
{
    for (auto it=m_mapInfo.begin();it!=m_mapInfo.end();it++)
    {
        QString strTartget = m_strTargetPath + "/"+it.value();
        QString strSource = it.key();
        QFile::remove(strSource);
        QFile::copy(strTartget, strSource);//从源路径将文件复制到目标路径
    }
}

 

标签:pItem,exe,QtableWidget,表头,复选框,tableWidget,ui,QString,signature
From: https://www.cnblogs.com/bclshuai/p/18095232

相关文章

  • python之自定义表头、列表内容导出excel文件例子
    函数三个参数outputfile:导出excel文件的位置,没有的话在该位置建该文件title:表头args:列的内容,每列是一个列表importxlsxwriterdefwriteExcel(outputfile,title,*args):wb=xlsxwriter.Workbook(outputfile)#创建sheetsheet=wb.add_worksheet("Sh......
  • element plus table将复选框更改为只能选一条数据后,有部分数据无法选中
    只有前两个可以选中,下面三条数据都无法选中,一开始以为是代码写的有问题,还看了半天逻辑最后发现,这个表格的数据有一个字段名是children,而table组件识别到这个字段会认为表格是一个树形表格,前两条数据可以选中是因为children:[]给table添加了row-key="id",表格实际是下图所示 ......
  • elementui 表格复选框根据列表状态设置禁用效果
    el-table表格type="selection"复选框需要根据状态来设置是否禁用,需要加selectable属性返回为false时则为禁用注意selectable要是一个方法不能设置变量checkSelectable(row){if(row.status==="0"){returntrue;}else{......
  • Python教程:生成Excel并更改表头
    简介在数据处理和报告生成中,Excel文件是一种常见的格式。Python提供了许多库来处理Excel文件,其中包括openpyxl,它是一个功能强大且易于使用的库,可以用来生成、修改和读取Excel文件。本文将介绍如何使用Python的openpyxl库生成Excel文件,并且演示如何更改表头。生成Excel文件首先......
  • Qt QTableWidget 设置列宽行高大小的几种方式及其他常用属性设置
    效果:1.列宽、行高自动分配1//列宽自动分配2tableWidget.horizontalHeader().sectionResizeMode(QHeaderView::Stretch)3//行高自动分配4tableWidget.verticalHeader().SectionResizeMode(QHeaderView::Stretch)2.固定值tableWidget.horizontalHeader().SectionResi......
  • vue页面纯前端导出excel表格(多级表头,exceljs)
    查找对比因为是第一次实现这样的功能,先在网上进行了查找,发现了三种比较常用的方法:1.安装file-saverxlsxscript-loader如果想设置表格样式的话,需要同时安装依赖xlsx-style,通常情况下安装此依赖会报错,需要进行修改;2.安装vue-json-excel这个插件看起来比较好上手,但是好像只......
  • Qt QTableView、QTableWidget设置表头
    以下是两个设置表头的不同方法:QTableWidget:1//设置表头2QStringListheardList;//表头3heardList<<QString::fromLocal8Bit("接收")<<QString::fromLocal8Bit("发送");4ui.tableWidget>setColumnCount(heardList.count());5ui.tabl......
  • Qt QTableView和QTableWidget之间的联系 和 区别?什么时候该用QTableView,什么时候该用Q
    QTableView和QTableWidget是Qt中用于显示和编辑表格数据的两个不同的部件,它们之间存在一些重要的区别:一、主要区别是:QTableView可以使用自定义的数据模型来显示内容(也就意味着使用时先要通过setModel来绑定数据源),而QTableWidget则只能使用标准的数据模型。二、不同角度......
  • Qt QCheckBox设置复选框的大小
    Qt设计QCheckBox样式表QCheckBox的各部分代表的样式表1QCheckBox2{3background-color:rgb(85,170,255);4color:yellow;5}67QCheckox::indicator:unchecked8{9/*设置边框的风格*/10border-style:solid;11border-width......
  • el-table 根据窗框大小 高度变化 固定表头
     <el-table:data="tableData"style="width:100%":height="tableHeight"><el-table-columnprop="date"label="日期"width="180"></el-table-column></el-table>......