#include "clientmainwindow.h" #include "ui_clientmainwindow.h" #include #include #include #include #include extern int g_comId; extern QString g_dataRootPath; QString g_auditDate; ClientMainWindow::ClientMainWindow(QWidget *parent) : QMainWindow(parent), ui(new Ui::ClientMainWindow) { ui->setupUi(this); ui->dateEdit->setDate(QDate::currentDate()); g_auditDate = QDate::currentDate().toString("yyyy-MM-dd"); ui->tableWidget->setColumnWidth(0,200); ui->tableWidget->setColumnWidth(1,80); ui->tableWidget->setColumnWidth(2,80); ui->tableWidget->setColumnWidth(4,ui->tableWidget->columnWidth(4)+15); initUi(); searchComName(); } ClientMainWindow::~ClientMainWindow() { delete ui; } void ClientMainWindow::searchComName() { QSqlQuery query; QString sql = QString("select id,name,code from company_info"); if(query.exec(sql)){ qDebug()<<"size:"<comboBox_company->addItem(name); } } } void ClientMainWindow::initUi() { m_searchInfo = new SearchInfo(this); ui->tabWidget->addTab(m_searchInfo,"信息查询"); m_coverInfo = new CoverInfo(this); m_coverInfo->setParent(ui->tab); m_auditPro = new AuditProject(this); m_auditworkload = new AuditWorkload(this); m_problemMon = new ProblemMoney(this); m_problemCnt = new ProblemCount(this); m_probleRect = new ProblemRectification(this); m_problemNotMon = new ProblemNotMoney(this); m_punish = new Punish(this); m_caseClue = new CaseClue(this); ui->stackedWidget->addWidget(m_auditPro); ui->stackedWidget->addWidget(m_auditworkload); ui->stackedWidget->addWidget(m_problemMon); ui->stackedWidget->addWidget(m_problemCnt); ui->stackedWidget->addWidget(m_probleRect); ui->stackedWidget->addWidget(m_problemNotMon); ui->stackedWidget->addWidget(m_punish); ui->stackedWidget->addWidget(m_caseClue); ui->stackedWidget->setCurrentIndex(0); // m_searchInfo = new SearchInfo(this); // ui->tabWidget->addTab(m_searchInfo,"信息查询"); // m_coverInfo = new CoverInfo(this); // m_coverInfo->setParent(ui->tab); // 隐藏掉某个选项 // 按索引来,从大到小 ui->tabWidget->removeTab(3); // OK ui->tabWidget->removeTab(1); // OK 老业务情况表 ui->tabWidget->removeTab(0); // OK 老封面 // 问题整改台账 m_proRecStandingBook = new ProblemRectStandingBook(this); ui->tabWidget->addTab(m_proRecStandingBook,"问题整改台账"); // 关联各个功能槽 connect(m_coverInfo,SIGNAL(sendComName(QString)),m_searchInfo,SLOT(addComName(QString))); connect(this,SIGNAL(sendDataToAuditProject(QVariantList)),m_auditPro,SLOT(showData(QVariantList))); connect(this,SIGNAL(sendDataToAuditWorkLoad(QVariantList)),m_auditworkload,SLOT(showData(QVariantList))); connect(this,SIGNAL(sendDataToProblemMoney(QVariantList)),m_problemMon,SLOT(showData(QVariantList))); connect(this,SIGNAL(sendDataToProblemCount(QVariantList)),m_problemCnt,SLOT(showData(QVariantList))); connect(this,SIGNAL(sendDataToProblemRectification(QVariantList)),m_probleRect,SLOT(showData(QVariantList))); connect(this,SIGNAL(sendDataToProblemNoMoney(QVariantList)),m_problemNotMon,SLOT(showData(QVariantList))); connect(this,SIGNAL(sendDataToPunish(QVariantList)),m_punish,SLOT(showData(QVariantList))); connect(this,SIGNAL(sendDataToCaseClue(QVariantList)),m_caseClue,SLOT(showData(QVariantList))); // 新版本 m_conInfo2 = new ConverInfo2(this); //ui->tabWidget->addTab(m_conInfo2,"基本信息"); ui->tabWidget->insertTab(0,m_conInfo2,"封面信息"); m_problemList = new ProblemList(this); ui->tabWidget->addTab(m_problemList,"问题清单"); m_problemRectifResult = new ProblemRectificationResult(this); ui->tabWidget->addTab(m_problemRectifResult,"整改成果"); m_tableItemDelegate = new TableItemDelegate(); // 代理 禁用编辑 m_editDelegate = new QItemDelegate(this); // 可编辑 ui->tableWidget->setItemDelegateForColumn(0,m_tableItemDelegate); ui->tableWidget->setItemDelegateForColumn(1,m_tableItemDelegate); ui->tableWidget->setItemDelegateForColumn(2,m_tableItemDelegate); // 默认调用一下下拉框的触发操作 on_comboBox_currentIndexChanged("企业(不含金融企业)"); } void ClientMainWindow::readDataFromExcel(QString path) { QAxObject excel("Excel.Application"); excel.setProperty("Visible",false); excel.setProperty("DisplayAlerts",false); qDebug()<<"open:"<querySubObject("Open(QString&)",path); //QAxObject* pWorkBook = excel.querySubObject("ActiveWorkBook"); //QAxObject* pWorkSheets = pWorkBook->querySubObject("Sheets");//获取工作表 QAxObject * shs = wb->querySubObject("Sheets"); // WorkSheets 也可以 int cnt = shs->property("Count").toInt(); qDebug()<<"cnt="<querySubObject("Item(int)", i+1); QString sheetName = sheet->property("Name").toString(); qDebug()<<"sh name:"<querySubObject("UsedRange"); int rows = usedRange->querySubObject("Rows")->property("Count").toInt(); int columns = usedRange->querySubObject("Columns")->property("Count").toInt(); qDebug()<<"r--c:"<dynamicCall("Value"); // 拿到二维表格 QVariantList valRows = val.toList(); // 公司名、统一信用代码 QVariant uniCode = valRows[5].toList().at(1); QVariant comName = valRows[6].toList().at(1); if(comName.isValid()){ if(!readDataFromSQL(comName.toString())){ QMessageBox::information(this,"导入中断","请确认公司基本信息已经存在"); break; //return; } qDebug()<dynamicCall("Close()"); excel.dynamicCall("Quit(void)"); } void ClientMainWindow::on_pushButton_auditPro_clicked() { ui->stackedWidget->setCurrentIndex(0); } void ClientMainWindow::on_pushButton_auditWorkload_clicked() { ui->stackedWidget->setCurrentIndex(1); } void ClientMainWindow::on_pushButton_problemMoney_clicked() { ui->stackedWidget->setCurrentIndex(2); } void ClientMainWindow::on_pushButton_problemCount_clicked() { ui->stackedWidget->setCurrentIndex(3); } void ClientMainWindow::on_pushButton_problemRectification_clicked() { ui->stackedWidget->setCurrentIndex(4); } void ClientMainWindow::on_pushButton_problemNotMoney_clicked() { ui->stackedWidget->setCurrentIndex(5); } void ClientMainWindow::on_pushButton_punish_clicked() { ui->stackedWidget->setCurrentIndex(6); } void ClientMainWindow::on_pushButton_caseClue_clicked() { ui->stackedWidget->setCurrentIndex(7); } void ClientMainWindow::on_pushButton_clicked() { QXlsx::Document doc; doc.write(1,2,"mayibase"); doc.write(2,2,"is good"); doc.write("A1","码蚁软件"); doc.mergeCells("A1:A4"); doc.mergeCells("B1:C1"); if(doc.saveAs("Data/test.xlsx")) { qDebug()<<"save is ok"; }else{ qDebug()<<"save is fail"; } } void ClientMainWindow::on_pushButton_2_clicked() { QXlsx::Document doc("test.xlsx"); qDebug()<listWidget->addItem(f); } } void ClientMainWindow::on_pushButton_importExcel_clicked() { QString path = QFileDialog::getOpenFileName(this,"选择表格:单位内部审计业务情况表","./","excel(*业务情况表*.xls)"); qDebug()<<"path:"< 1){ readDataFromExcel(path); } } bool ClientMainWindow::readDataFromSQL(QString name) { QSqlQuery query; QString sql; if(name.size() > 1){ sql = QString("select id,name from company_info where name='%1'").arg(name); qDebug()<<"查询公司sql:"<tableWidget->rowCount();++i){ int sum = 0; for(int j=4;jtableWidget->columnCount();++j){ sum += ui->tableWidget->item(i,j)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(sum))); if(i==7){ // 学历 int val = 0; for(int j = 8;j<=10;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); ui->tableWidget->setItem(5,3,new QTableWidgetItem(QString::number(val))); // 内部审计人员数量 } if(i==11){ // 职称 int val = 0; for(int j = 12;j<=15;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==20){ // 知识结构 int val = 0; for(int j = 21;j<=28;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==30){ // 审计项目 int val = 0; for(int j = 31;j<=38;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==41){ // 审计发现问题金额 int val = 0; for(int j = 42;j<=43;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==43){ // 合规性问题金额 int val = 0; for(int j = 44;j<=51;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==52){ // 审计发现问题个数 int val = 0; for(int j = 53;j<=54;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==54){ // 非金额类问题个数 int val = 0; for(int j = 55;j<=58;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==59){ // 审计发现问题整改(金额类) int val = 0; for(int j = 60;j<=65;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==66){ // 审计发现问题整改(非金额类) int val = 0; for(int j = 67;j<=70;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } if(i==71){ // 处分 int val = 0; for(int j = 72;j<=74;++j){ val += ui->tableWidget->item(j,3)->text().toInt(); } ui->tableWidget->setItem(i,3,new QTableWidgetItem(QString::number(val))); } } } void ClientMainWindow::on_dateEdit_dateChanged(const QDate &date) { g_auditDate = date.toString("yyyy-MM-dd"); qDebug()<tableWidget->rowCount();++i){ qDebug()<<"data:"<tableWidget->item(i,1)->text()<<" "<tableWidget->item(i,3)->text(); } } void ClientMainWindow::on_comboBox_currentIndexChanged(const QString &arg1) { qDebug()<<"当前"<tableWidget->setItemDelegateForColumn(4,m_editDelegate); }else { ui->tableWidget->setItemDelegateForColumn(4,m_tableItemDelegate); } if(arg1 == "金融企业"){ ui->tableWidget->setItemDelegateForColumn(5,m_editDelegate); }else { ui->tableWidget->setItemDelegateForColumn(5,m_tableItemDelegate); } if(arg1 == "机关"){ ui->tableWidget->setItemDelegateForColumn(6,m_editDelegate); }else { ui->tableWidget->setItemDelegateForColumn(6,m_tableItemDelegate); } if(arg1 == "事业单位"){ ui->tableWidget->setItemDelegateForColumn(7,m_editDelegate); }else{ ui->tableWidget->setItemDelegateForColumn(7,m_tableItemDelegate); } if(arg1 == "其他"){ ui->tableWidget->setItemDelegateForColumn(8,m_editDelegate); }else{ ui->tableWidget->setItemDelegateForColumn(8,m_tableItemDelegate); } }