QT 商品删除与导出数据(库存管理系统)

商品删除

cpp 复制代码
void MainWidget::on_pushButton_DeleteGoods_clicked()
{
    // 1:首先:提醒用户是否确认删除此记录
    // 1:获取QMessageBox选择按钮:Yes 或 No
    int iClick=QMessageBox::warning(this,"警告","警告:删除操作是根据商品编号进行删除,请确认是否安全?",QMessageBox::Yes|QMessageBox::No);

    // 2:判断用户是否单击Yes按钮
    if(iClick==QMessageBox::Yes)
    {
        // 3:获取当前选择行进行删除:商品记录数据
        int iRow=ui->tableWidget_ListData->currentRow();

        // 4:根据index(行,列)获取对应商品编号
        QString strValue=ui->tableWidget_ListData->model()->index(iRow,0).data().toString();
        // QMessageBox::information(this,"测试","获取数据为:"+strValue);

        QSqlQuery result;
        QString strid=strValue;

        // 5:判断删除商品编号是否为空???
        if(strid==NULL)
        {
            QMessageBox::critical(this,"错误","提示:请选择要删除商品编号,请重新检查?");
            return;
        }


        // 6:实现删除
        QString sqlquery=QString("delete from commoditydatatable where StockId = %1").arg(strid);
        if(result.exec(sqlquery))
        {
            // 删除提示
            QMessageBox::information(this,"提示","删除商品记录成功!");

            // 清空表格控件数据
            ui->tableWidget_ListData->clear();

            // 设置表格控件标题(表头)
            ui->tableWidget_ListData->setHorizontalHeaderLabels(QStringList()<<"编号"<<"名称"<<"数量"<<"单价"<<"供应商家"<<"负责人"<<"入库时间"<<"出库时间"<<"备注");

            // 调用函数将数据表中数据再次展示到表格控件当中
            InitTableWidgetFunc();
        }

    }
    else
    {
        return;
    }
}

导出数据为excel

cpp 复制代码
// 导出数据
#include <QFileDialog>
#include <QAxObject>
#include <QDesktopServices>

// 该函数功能:导出表格控件数据,直接生成Excel文件保存
void MainWidget::on_pushButton_LoadData_clicked()
{
    // 保存文件扩展名为:.xls
    QDateTime time;
    QString strTemp;

    // 1:获取当前系统当时作为文件名称进行保存
    time=QDateTime::currentDateTime();
    strTemp=time.toString("yyyy-MM-dd-hhmmss");
    // QMessageBox::information(this,"测试",strTemp);

    // 2:应用文件对话框来保存要导出文件名称(设置保存的文件名称)及数据信息
    QString strFileName=QFileDialog::getSaveFileName(this,tr("Excel Files"),QString("./%1%2.xls").arg(strTemp).arg("_kcgl"),tr("Excel Files(*.xls)"));
    // QMessageBox::information(this,"测试",strFileName);

    // 3:处理工作簿
    if(strFileName!=NULL)
    {
        QAxObject *excel=new QAxObject;
        if(excel->setControl("Excel.Application"));
        {
            excel->dynamicCall("SetVisible (bool Visible)",false);
            excel->setProperty("DisplayAlerts",false);

            QAxObject *workbooks=excel->querySubObject("WorkBooks"); // 获得工作簿集合
            workbooks->dynamicCall("Add"); // 创建一个工作簿
            QAxObject *workbook=excel->querySubObject("ActiveWorkBook"); // 获得当前工作簿
            QAxObject *worksheet=workbook->querySubObject("Worksheets(int)",1);
            QAxObject *cell;

            // 1:添加Excel文件表头数据
            for(int i=1;i<=ui->tableWidget_ListData->columnCount();i++)
            {
                cell=worksheet->querySubObject("Cells(int,int)",1,i);
                cell->setProperty("RowHeight",25);
                cell->dynamicCall("SetValue(const QString&)",ui->tableWidget_ListData->horizontalHeaderItem(i-1)->data(0).toString());
            }

            // 2:将表格数据保存到Excel文件当中
            for(int j=2;j<=ui->tableWidget_ListData->rowCount()+1;j++)
            {
                for(int k=1;k<=ui->tableWidget_ListData->columnCount();k++)
                {
                    cell=worksheet->querySubObject("Cells(int,int)",j,k);
                    cell->dynamicCall("SetValue(const QString&",ui->tableWidget_ListData->item(j-2,k-1)->text()+"\t");

                }
            }

            // 3:将刚才创建的Excel文件直接保存到指定的目录下
            workbook->dynamicCall("SaveAs(const QString&)",QDir::toNativeSeparators(strFileName)); // 保存到strFileName
            workbook->dynamicCall("Close()");
            excel->dynamicCall("Quit()");
            delete excel;
            excel=NULL;
        }
    }
}
相关推荐
好开心3322 分钟前
axios的使用
开发语言·前端·javascript·前端框架·html
又蓝1 小时前
使用 Python 操作 Excel 表格
开发语言·python·excel
余~~185381628001 小时前
稳定的碰一碰发视频、碰一碰矩阵源码技术开发,支持OEM
开发语言·人工智能·python·音视频
Am心若依旧4092 小时前
[c++11(二)]Lambda表达式和Function包装器及bind函数
开发语言·c++
明月看潮生2 小时前
青少年编程与数学 02-004 Go语言Web编程 20课题、单元测试
开发语言·青少年编程·单元测试·编程与数学·goweb
大G哥2 小时前
java提高正则处理效率
java·开发语言
VBA63372 小时前
VBA技术资料MF243:利用第三方软件复制PDF数据到EXCEL
开发语言
轩辰~2 小时前
网络协议入门
linux·服务器·开发语言·网络·arm开发·c++·网络协议
小_太_阳2 小时前
Scala_【1】概述
开发语言·后端·scala·intellij-idea
向宇it2 小时前
【从零开始入门unity游戏开发之——unity篇02】unity6基础入门——软件下载安装、Unity Hub配置、安装unity编辑器、许可证管理
开发语言·unity·c#·编辑器·游戏引擎