#include "clientmainwindow.h" #include "ui_clientmainwindow.h" #include <QDebug> #include <QFileDialog> #include <QMessageBox> #include <QSqlQuery> #include <QSqlRecord> #include <QTimer> #pragma execution_character_set("utf-8") 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(); ui->statusBar->showMessage("å°é¢ä¿¡æ¯åŠ è½½ä¸..."); } 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:"<<query.numRowsAffected(); while(query.next()){ int id = query.value(0).toInt(); QString name = query.value(1).toString(); QString code = query.value(2).toString(); qDebug()<<"com select:"<<id<<name; m_comInfo[name] = id; //m_comCode[name] = code; ui->comboBox_company->addItem(name); } } } void ClientMainWindow::delay(int msec) { QTimer::singleShot(msec, this, [=]{ qDebug()<<"延时完æˆå•¦..."; emit loadExcelSignal(); }); qDebug()<<"å»¶æ—¶æ—¶é•¿..."<<msec; } 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,"å°é¢ä¿¡æ¯"); connect(this,SIGNAL(loadExcelSignal()),m_conInfo2,SLOT(showExcelSlot()),Qt::QueuedConnection); // æŽ§åˆ¶æ˜¾ç¤ºçŠ¶æ€æ çš„ä¿¡æ¯ connect(m_conInfo2,&ConverInfo2::loadFinished,this,[=]{ ui->statusBar->showMessage("å°é¢ä¿¡æ¯åŠ è½½å®Œæˆ",10*1000); }); // æŽ§åˆ¶æ˜¾ç¤ºåŠ è½½è¿›åº¦çš„ä¿¡æ¯ connect(m_conInfo2,&ConverInfo2::loadProgress,this,[=](int val){ ui->statusBar->showMessage(QString("å°é¢ä¿¡æ¯åŠ è½½å·²å®Œæˆ %1 %").arg(val)); }); 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); // 3å’Œ1 m_threeMPList = new ThreeMergeProblemList(this); ui->tabWidget->addTab(m_threeMPList,"三åˆä¸€é—®é¢˜å¤„ç†"); // é»˜è®¤è°ƒç”¨ä¸€ä¸‹ä¸‹æ‹‰æ¡†çš„è§¦å‘æ“作 on_comboBox_currentIndexChanged("ä¼ä¸š(ä¸å«é‡‘èžä¼ä¸š)"); // 最åŽè§¦å‘åŠ è½½ç”µåè¡¨æ ¼çš„ä¿¡å· //emit loadExcelSignal(); //qDebug()<<"å‘å°„åŠ è½½ç”µåè¡¨æ ¼çš„ä¿¡å·"; delay(1000); } void ClientMainWindow::readDataFromExcel(QString path) { QAxObject excel("Excel.Application"); excel.setProperty("Visible",false); excel.setProperty("DisplayAlerts",false); qDebug()<<"open:"<<path; qDebug()<<"excel:"<<excel.className(); QAxObject * wbs = excel.querySubObject("WorkBooks"); QAxObject * wb = wbs->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="<<cnt; for(int i=0;i<cnt;++i){ QAxObject * sheet = shs->querySubObject("Item(int)", i+1); QString sheetName = sheet->property("Name").toString(); qDebug()<<"sh name:"<<sheetName; QAxObject *usedRange = sheet->querySubObject("UsedRange"); int rows = usedRange->querySubObject("Rows")->property("Count").toInt(); int columns = usedRange->querySubObject("Columns")->property("Count").toInt(); qDebug()<<"r--c:"<<rows<<columns; QVariant val = usedRange->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()<<comName<<g_comId; } // 审计项目 QVariantList audit_project; for(int i=10;i<20;++i){ audit_project.append(valRows[i].toList().at(4)); } qDebug()<<audit_project; // å®¡è®¡å·¥ä½œé‡ QVariantList audit_workload; for(int i=20;i<21;++i){ audit_workload.append(valRows[i].toList().at(4)); } // é—®é¢˜é‡‘é¢ QVariantList problem_money; for(int i=21;i<32;++i){ problem_money.append(valRows[i].toList().at(4)); } // 问题个数 QVariantList problem_count; for(int i=32;i<39;++i){ problem_count.append(valRows[i].toList().at(4)); } // 问题整改(金é¢ç±») QVariantList problem_rectification; for(int i=39;i<46;++i){ problem_rectification.append(valRows[i].toList().at(4)); } // 问题整改(éžé‡‘é¢ç±») QVariantList problem_nomoney; for(int i=46;i<51;++i){ problem_nomoney.append(valRows[i].toList().at(4)); } // 处分 QVariantList punish; for(int i=51;i<55;++i){ punish.append(valRows[i].toList().at(4)); } // 案件线索 QVariantList case_clue; for(int i=55;i<57;++i){ case_clue.append(valRows[i].toList().at(4)); } qDebug()<<case_clue; emit sendDataToAuditProject(audit_project); emit sendDataToAuditWorkLoad(audit_workload); emit sendDataToProblemMoney(problem_money); emit sendDataToProblemCount(problem_count); emit sendDataToProblemRectification(problem_rectification); emit sendDataToProblemNoMoney(problem_nomoney); emit sendDataToPunish(punish); emit sendDataToCaseClue(case_clue); } wbs->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()<<doc.read("A1"); qDebug()<<doc.read("B1"); qDebug()<<doc.read("C1"); } void ClientMainWindow::on_pushButton_openXlsxFile_clicked() { QStringList files = QFileDialog::getOpenFileNames(this,"æ‰“å¼€ç”µåæ–‡æ¡£","./","*.xlsx *.xls"); qDebug()<<"files:"<<files; for(auto f:files){ ui->listWidget->addItem(f); } } void ClientMainWindow::on_pushButton_importExcel_clicked() { QString path = QFileDialog::getOpenFileName(this,"é€‰æ‹©è¡¨æ ¼:å•ä½å†…部审计业务情况表","./","excel(*业务情况表*.xls)"); qDebug()<<"path:"<<path; if(path.size() > 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:"<<sql; if(query.exec(sql)){ qDebug()<<"OK sql"<<__FUNCTION__; QSqlRecord res = query.record(); qDebug()<<query.size()<<query.numRowsAffected()<<res.count(); if(!query.next()){ QMessageBox::information(this,"导入失败","å…¬å¸åä¸å˜åœ¨åº“ä¸ï¼Œè¯·å…ˆå¯¼å…¥åŸºæœ¬ä¿¡æ¯è¡¨"); }else{ g_comId = query.value(0).toInt(); return true; } }else{ qDebug()<<"fail sql"<<__FUNCTION__; } } return false; } void ClientMainWindow::calc() { for(int i=1;i<ui->tableWidget->rowCount();++i){ int sum = 0; for(int j=4;j<ui->tableWidget->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()<<g_auditDate; } void ClientMainWindow::on_tableWidget_activated(const QModelIndex &index) { qDebug()<<__FUNCTION__<<index; } void ClientMainWindow::on_tableWidget_clicked(const QModelIndex &index) { qDebug()<<__FUNCTION__<<index; } void ClientMainWindow::on_tableWidget_itemEntered(QTableWidgetItem *item) { qDebug()<<__FUNCTION__<<item; } void ClientMainWindow::on_tableWidget_cellEntered(int row, int column) { qDebug()<<__FUNCTION__<<row<<column; calc(); } void ClientMainWindow::on_tableWidget_cellClicked(int row, int column) { qDebug()<<__FUNCTION__<<row<<column; calc(); } void ClientMainWindow::on_pushButton_save_clicked() { // ä¿å˜æ•°æ®ï¼Œç»“构比较特殊,需è¦å¤šè¡Œå¤šåˆ—åŒæ—¶å†™å…¥ // 得考虑分段å•è¡¨å¤„ç†æ–¹å¯ // 获å–写到文件里é¢ï¼Œæ¯ä¸ªå•ä½ä¸€ä¸ªæ–‡ä»¶ // 把å•ä½ç±»åž‹ä½œä¸ºä¸€ä¸ªåˆ—å³å¯ qDebug()<<"ä¿å˜æ•°æ®"; for(int i=1;i<ui->tableWidget->rowCount();++i){ qDebug()<<"data:"<<ui->tableWidget->item(i,1)->text()<<" "<<ui->tableWidget->item(i,3)->text(); } // 先判æ–å…¬å¸åœ¨ä¸åœ¨ï¼Œä¸åœ¨åˆ™æ–°å¢žï¼Œåœ¨åˆ™ä¿®æ”¹ QString sql = QString("select name from comprehensive_entry_info where name='%1'").arg(ui->comboBox_company->currentText()); qDebug()<<"sql select:"<<sql; QSqlQuery query; bool nameExsit = false; if(query.exec(sql)) { qDebug()<<QString("select comprehensive_entry_info ok..."); while (query.next()) { nameExsit = true; qDebug()<<"å…¬å¸åå˜åœ¨:"<<ui->comboBox_company->currentText(); break; } }else{ qDebug()<<QString("select comprehensive_entry_info fail...")<<query.lastError().text(); } if(!nameExsit){ qDebug()<<"å…¬å¸åä¸å˜åœ¨:"<<ui->comboBox_company->currentText(); // æ’å…¥ sql = QString("insert into comprehensive_entry_info (name,_030000,_030001,_030100,_030101,_030200,_030210,_030220,_030221,_030222,_030223,_030230,\ _030231,\ _030232,\ _030233,\ _030234,\ _030240,\ _030241,\ _030242,\ _030243,\ _030250,\ _030251,\ _030252,\ _030253,\ _030254,\ _030255,\ _030256,\ _030257,\ _030258,\ _030260,\ _030300,\ _030301,\ _030302,\ _030303,\ _030304,\ _030305,\ _030306,\ _030307,\ _030308,\ _030310,\ _030400,\ _030500,\ _030510,\ _030520,\ _030521,\ _030522,\ _030523,\ _030524,\ _030525,\ _030526,\ _030527,\ _030528,\ _030600,\ _030610,\ _030620,\ _030621,\ _030622,\ _030623,\ _030624,\ _030700,\ _030701,\ _030702,\ _030703,\ _030704,\ _030705,\ _030706,\ _030800,\ _030801,\ _030802,\ _030803,\ _030804,\ _030900,\ _030901,\ _030902,\ _030903,\ _031000,\ _031001,\ company_type\ ) values ('%1','%2','%3','%4','%5','%6','%7','%8','%9','%10','%11','%12','%13','%14','%15','%16','%17','%18','%19','%20','%21','%22','%23','%24','%25','%26'" ",'%27','%28','%29','%30','%31','%32','%33','%34','%35','%36','%37','%38','%39','%40','%41','%42','%43','%44','%45','%46','%47','%48','%49','%50','%51'" ",'%52','%53','%54','%55','%56','%57','%58','%59','%60','%61','%62','%63','%64','%65','%66','%67','%68','%69','%70','%71','%72','%73','%74','%75','%76'" ",'%77','%78')").arg(ui->comboBox_company->currentText()).arg(ui->tableWidget->item(1,3)->text()) .arg(ui->tableWidget->item(2,3)->text()).arg(ui->tableWidget->item(3,3)->text()).arg(ui->tableWidget->item(4,3)->text()).arg(ui->tableWidget->item(5,3)->text()).arg(ui->tableWidget->item(6,3)->text()) .arg(ui->tableWidget->item(7,3)->text()).arg(ui->tableWidget->item(8,3)->text()).arg(ui->tableWidget->item(9,3)->text()).arg(ui->tableWidget->item(10,3)->text()).arg(ui->tableWidget->item(11,3)->text()) .arg(ui->tableWidget->item(12,3)->text()).arg(ui->tableWidget->item(13,3)->text()).arg(ui->tableWidget->item(14,3)->text()).arg(ui->tableWidget->item(15,3)->text()).arg(ui->tableWidget->item(16,3)->text()) .arg(ui->tableWidget->item(17,3)->text()).arg(ui->tableWidget->item(18,3)->text()).arg(ui->tableWidget->item(19,3)->text()).arg(ui->tableWidget->item(20,3)->text()).arg(ui->tableWidget->item(21,3)->text()) .arg(ui->tableWidget->item(22,3)->text()).arg(ui->tableWidget->item(23,3)->text()).arg(ui->tableWidget->item(24,3)->text()).arg(ui->tableWidget->item(25,3)->text()).arg(ui->tableWidget->item(26,3)->text()) .arg(ui->tableWidget->item(27,3)->text()).arg(ui->tableWidget->item(28,3)->text()).arg(ui->tableWidget->item(29,3)->text()).arg(ui->tableWidget->item(30,3)->text()).arg(ui->tableWidget->item(31,3)->text()) .arg(ui->tableWidget->item(32,3)->text()).arg(ui->tableWidget->item(33,3)->text()).arg(ui->tableWidget->item(34,3)->text()).arg(ui->tableWidget->item(35,3)->text()).arg(ui->tableWidget->item(36,3)->text()) .arg(ui->tableWidget->item(37,3)->text()).arg(ui->tableWidget->item(38,3)->text()).arg(ui->tableWidget->item(39,3)->text()).arg(ui->tableWidget->item(40,3)->text()).arg(ui->tableWidget->item(41,3)->text()) .arg(ui->tableWidget->item(42,3)->text()).arg(ui->tableWidget->item(43,3)->text()).arg(ui->tableWidget->item(44,3)->text()).arg(ui->tableWidget->item(45,3)->text()).arg(ui->tableWidget->item(46,3)->text()) .arg(ui->tableWidget->item(47,3)->text()).arg(ui->tableWidget->item(48,3)->text()).arg(ui->tableWidget->item(49,3)->text()).arg(ui->tableWidget->item(50,3)->text()).arg(ui->tableWidget->item(51,3)->text()) .arg(ui->tableWidget->item(52,3)->text()).arg(ui->tableWidget->item(53,3)->text()).arg(ui->tableWidget->item(54,3)->text()).arg(ui->tableWidget->item(55,3)->text()).arg(ui->tableWidget->item(56,3)->text()) .arg(ui->tableWidget->item(57,3)->text()).arg(ui->tableWidget->item(58,3)->text()).arg(ui->tableWidget->item(59,3)->text()).arg(ui->tableWidget->item(60,3)->text()).arg(ui->tableWidget->item(61,3)->text()) .arg(ui->tableWidget->item(62,3)->text()).arg(ui->tableWidget->item(63,3)->text()).arg(ui->tableWidget->item(64,3)->text()).arg(ui->tableWidget->item(65,3)->text()).arg(ui->tableWidget->item(66,3)->text()) .arg(ui->tableWidget->item(67,3)->text()).arg(ui->tableWidget->item(68,3)->text()).arg(ui->tableWidget->item(69,3)->text()).arg(ui->tableWidget->item(70,3)->text()).arg(ui->tableWidget->item(71,3)->text()) .arg(ui->tableWidget->item(72,3)->text()).arg(ui->tableWidget->item(73,3)->text()).arg(ui->tableWidget->item(74,3)->text()).arg(ui->tableWidget->item(75,3)->text()).arg(ui->tableWidget->item(76,3)->text()) .arg(ui->comboBox->currentText()); qDebug()<<"comprehensive_entry_info insert sql:"<<sql; if(query.exec(sql)){ qDebug()<<"comprehensive_entry_info insert sql ok"; QMessageBox::information(this,"æ–°æ•°æ®å½•å…¥æˆåŠŸ",QString("新录入公å¸ï¼š%1 ä¿¡æ¯æˆåŠŸã€‚").arg(ui->comboBox_company->currentText())); }else{ qDebug()<<"comprehensive_entry_info insert sql fail:"<<query.lastError().text(); QMessageBox::information(this,"æ–°æ•°æ®å½•入失败",QString("新录入公å¸ï¼š%1 ä¿¡æ¯å¤±è´¥ã€‚").arg(ui->comboBox_company->currentText())); } }else{ // æ›´æ–° sql = QString("update comprehensive_entry_info set _030000='%1',_030001='%2',_030100='%3',_030101='%4',_030200='%5',_030210='%6',_030220='%7',_030221='%8',_030222='%9',_030223='%10',_030230='%11'" ",_030231='%12',_030232='%13',_030233='%14',_030234='%15',_030240='%16',_030241='%17',_030242='%18',_030243='%19',_030250='%20',_030251='%21'" ",_030252='%22',_030253='%23',_030254='%24',_030255='%25',_030256='%26',_030257='%27',_030258='%28',_030260='%29',_030300='%30',_030301='%31'" ",_030302='%32',_030303='%33',_030304='%34',_030305='%35',_030306='%36',_030307='%37',_030308='%38',_030310='%39',_030400='%40',_030500='%41'" ",_030510='%42',_030520='%43',_030521='%44',_030522='%45',_030523='%46',_030524='%47',_030525='%48',_030526='%49',_030527='%50',_030528='%51'" ",_030600='%52',_030610='%53',_030620='%54',_030621='%55',_030622='%56',_030623='%57',_030624='%58',_030700='%59',_030701='%60',_030702='%61'" ",_030703='%62',_030704='%63',_030705='%64',_030706='%65',_030800='%66',_030801='%67',_030802='%68',_030803='%69',_030804='%70',_030900='%71'" ",_030901='%72',_030902='%73',_030903='%74',_031000='%75',_031001='%76',company_type='%77' where name='%78'").arg(ui->tableWidget->item(1,3)->text()) .arg(ui->tableWidget->item(2,3)->text()).arg(ui->tableWidget->item(3,3)->text()).arg(ui->tableWidget->item(4,3)->text()).arg(ui->tableWidget->item(5,3)->text()).arg(ui->tableWidget->item(6,3)->text()) .arg(ui->tableWidget->item(7,3)->text()).arg(ui->tableWidget->item(8,3)->text()).arg(ui->tableWidget->item(9,3)->text()).arg(ui->tableWidget->item(10,3)->text()).arg(ui->tableWidget->item(11,3)->text()) .arg(ui->tableWidget->item(12,3)->text()).arg(ui->tableWidget->item(13,3)->text()).arg(ui->tableWidget->item(14,3)->text()).arg(ui->tableWidget->item(15,3)->text()).arg(ui->tableWidget->item(16,3)->text()) .arg(ui->tableWidget->item(17,3)->text()).arg(ui->tableWidget->item(18,3)->text()).arg(ui->tableWidget->item(19,3)->text()).arg(ui->tableWidget->item(20,3)->text()).arg(ui->tableWidget->item(21,3)->text()) .arg(ui->tableWidget->item(22,3)->text()).arg(ui->tableWidget->item(23,3)->text()).arg(ui->tableWidget->item(24,3)->text()).arg(ui->tableWidget->item(25,3)->text()).arg(ui->tableWidget->item(26,3)->text()) .arg(ui->tableWidget->item(27,3)->text()).arg(ui->tableWidget->item(28,3)->text()).arg(ui->tableWidget->item(29,3)->text()).arg(ui->tableWidget->item(30,3)->text()).arg(ui->tableWidget->item(31,3)->text()) .arg(ui->tableWidget->item(32,3)->text()).arg(ui->tableWidget->item(33,3)->text()).arg(ui->tableWidget->item(34,3)->text()).arg(ui->tableWidget->item(35,3)->text()).arg(ui->tableWidget->item(36,3)->text()) .arg(ui->tableWidget->item(37,3)->text()).arg(ui->tableWidget->item(38,3)->text()).arg(ui->tableWidget->item(39,3)->text()).arg(ui->tableWidget->item(40,3)->text()).arg(ui->tableWidget->item(41,3)->text()) .arg(ui->tableWidget->item(42,3)->text()).arg(ui->tableWidget->item(43,3)->text()).arg(ui->tableWidget->item(44,3)->text()).arg(ui->tableWidget->item(45,3)->text()).arg(ui->tableWidget->item(46,3)->text()) .arg(ui->tableWidget->item(47,3)->text()).arg(ui->tableWidget->item(48,3)->text()).arg(ui->tableWidget->item(49,3)->text()).arg(ui->tableWidget->item(50,3)->text()).arg(ui->tableWidget->item(51,3)->text()) .arg(ui->tableWidget->item(52,3)->text()).arg(ui->tableWidget->item(53,3)->text()).arg(ui->tableWidget->item(54,3)->text()).arg(ui->tableWidget->item(55,3)->text()).arg(ui->tableWidget->item(56,3)->text()) .arg(ui->tableWidget->item(57,3)->text()).arg(ui->tableWidget->item(58,3)->text()).arg(ui->tableWidget->item(59,3)->text()).arg(ui->tableWidget->item(60,3)->text()).arg(ui->tableWidget->item(61,3)->text()) .arg(ui->tableWidget->item(62,3)->text()).arg(ui->tableWidget->item(63,3)->text()).arg(ui->tableWidget->item(64,3)->text()).arg(ui->tableWidget->item(65,3)->text()).arg(ui->tableWidget->item(66,3)->text()) .arg(ui->tableWidget->item(67,3)->text()).arg(ui->tableWidget->item(68,3)->text()).arg(ui->tableWidget->item(69,3)->text()).arg(ui->tableWidget->item(70,3)->text()).arg(ui->tableWidget->item(71,3)->text()) .arg(ui->tableWidget->item(72,3)->text()).arg(ui->tableWidget->item(73,3)->text()).arg(ui->tableWidget->item(74,3)->text()).arg(ui->tableWidget->item(75,3)->text()).arg(ui->tableWidget->item(76,3)->text()) .arg(ui->comboBox->currentText()).arg(ui->comboBox_company->currentText()); qDebug()<<"update sql:"<<sql; if(query.exec(sql)){ qDebug()<<"update ok:comprehensive_entry_info"; QMessageBox::information(this,"更新录入æˆåŠŸ",QString("录入公å¸ï¼š%1 ä¿¡æ¯æˆåŠŸã€‚").arg(ui->comboBox_company->currentText())); }else{ qDebug()<<"update fail:comprehensive_entry_info"<<query.lastError().text(); QMessageBox::information(this,"更新录入失败",QString("新录入公å¸ï¼š%1 ä¿¡æ¯å¤±è´¥ã€‚").arg(ui->comboBox_company->currentText())); } } } void ClientMainWindow::on_comboBox_currentIndexChanged(const QString &arg1) { qDebug()<<"当å‰"<<arg1; if(arg1 == "ä¼ä¸š(ä¸å«é‡‘èžä¼ä¸š)"){ ui->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); } } void ClientMainWindow::on_pushButton_reset_clicked() { // é‡ç½®æŸä¸€åˆ—æ•°æ® QString curText = ui->comboBox_2->currentText(); int index = 4; if(curText == "ä¼ä¸š(ä¸å«é‡‘èžä¼ä¸š)"){ index = 4; }else if(curText == "金èžä¼ä¸š"){ index = 5; }else if(curText == "机关"){ index = 6; }else if(curText == "事业å•ä½"){ index = 7; }else if(curText == "å…¶ä»–"){ index = 8; } qDebug()<<"é‡ç½®åˆ—索引:"<<index; QMessageBox::StandardButton rb = QMessageBox::question ( \ this, "é‡è¦æç¤º", QString("ä½ ç¡®å®šè¦é‡ç½®:%1 当å‰åˆ—æ•°æ®å—").arg(curText), \ QMessageBox::Yes | QMessageBox::No, QMessageBox::Yes ); if ( rb == QMessageBox::Yes ) { for(int i=1;i<ui->tableWidget->rowCount();++i){ ui->tableWidget->item(i,index)->setData(Qt::EditRole,"0"); } qDebug()<<"é‡ç½®"; }else{ qDebug()<<"ä¸é‡ç½®"; } }