Kraftstoffnamen anzeigen.
Nach der Bearbeitung von Namensanfragen bilden wir eine Tabelle, um dem Benutzer Informationen anzuzeigen.
Die Angabe des Prozesses zur Ausführung von Abfragen an die Tankstellendatenbanken wird nicht nur für die Anzeige verwendet, sondern auch beim Export nach xlsx und beim Ausführen von Skripten, die Namen ändern. Fügen Sie dazu dem Konstruktor der Dialogklasse ViewFuelNameDialog einen weiteren Parameter hinzu, der weitere Aktionen bestimmt. Lassen Sie uns die Liste der Aktionen als Aufzählung definieren.
tasklist.h
#ifndef TASKLIST_H #define TASKLIST_H enum taskList { //Список задач VIEW_NAME, //Просмотр наименований XLSX_EXPORT, //Экспорт в xlsx UPDATE_FUEL_NAME //Изменение наименований }; #endif // TASKLIST_H
Ändern wir den Signal-Handler Accepted() buttonBoxView:
void FuelNameDialog::on_buttonBoxView_accepted() { //Определяем дальнейший алгоритм работы в зависимости от выбранного checkBox int currentTask = (ui->radioButtonReport->isChecked()) ? VIEW_NAME : XLSX_EXPORT; //Диалог для отображения результатов и прогресса получения данных с АЗС ViewFuelNameDialog *viewFnDlg = new ViewFuelNameDialog(&listTerminals,currentTask, this); viewFnDlg->exec(); }
Im Slot slotGetStatusThread fügen wir eine Überprüfung für den Abschluss von Operationen zum Abrufen von Namen hinzu und rufen je nach Art der Aufgabe die entsprechende Funktion auf.
ui->progressBarGetFuel->setFormat("Обработано %v из %m. Ошибок "+QString::number(colError)); //Проверяем что произошло получение информации от всех АЗС указанных в списке //И в зависимости от типа задачи запускаем соответствующую функцию //Сортируем список азс определив статическую функцию compare std::sort(m_listFuelName.begin(), m_listFuelName.end(),compare); if(ui->progressBarGetFuel->value() == m_connectionsList.size()){ switch (m_currentTask) { case VIEW_NAME: showFuelName(); break; case XLSX_EXPORT: exportXlsx(); break; default: break; } }
Implementierungsfunktion für die Namenszuordnung
//Отображение наименований void ViewFuelNameDialog::showFuelName() { QSqlQuery q; ui->groupBoxProgress->hide(); ui->tableWidgetView->setColumnCount(4); ui->tableWidgetView->setHorizontalHeaderLabels(QStringList() <<"Резервуар"<<"Код"<<"Краткое"<<"Полное"); ui->tableWidgetView->verticalHeader()->hide(); int colAzs = m_listFuelName.size(); for(int i = 0; i<colAzs; ++i ){ //Добавляем строку с номером и адресом АЗС int row = ui->tableWidgetView->rowCount(); ui->tableWidgetView->insertRow(row); QTableWidgetItem *itemAZS = new QTableWidgetItem(QString::number(m_listFuelName.at(i).terminalID())+" "+m_listFuelName.at(i).azsName()); itemAZS->setTextAlignment(Qt::AlignHCenter); itemAZS->setBackground(QColor("#aaff7f")); //Объединяем ячейки ui->tableWidgetView->setSpan(row,0,1,4); ui->tableWidgetView->setItem(row,0,itemAZS); for(int j = 0; j<m_listFuelName.at(i).listFuels().size();++j){ //Заполняем строки наименованиями int rowName = ui->tableWidgetView->rowCount(); ui->tableWidgetView->insertRow(rowName); ui->tableWidgetView->setItem(rowName,0, new QTableWidgetItem(QString::number(m_listFuelName.at(i).listFuels().at(j).tankID()))); ui->tableWidgetView->item(rowName,0)->setTextAlignment(Qt::AlignCenter); ui->tableWidgetView->setItem(rowName,1, new QTableWidgetItem(QString::number(m_listFuelName.at(i).listFuels().at(j).fuelID()))); ui->tableWidgetView->item(rowName,1)->setTextAlignment(Qt::AlignCenter); ui->tableWidgetView->setItem(rowName,2, new QTableWidgetItem(m_listFuelName.at(i).listFuels().at(j).shortName())); ui->tableWidgetView->setItem(rowName,3, new QTableWidgetItem(m_listFuelName.at(i).listFuels().at(j).name())); ui->tableWidgetView->resizeColumnToContents(3); } } ui->tableWidgetView->verticalHeader()->setDefaultSectionSize(ui->tableWidgetView->verticalHeader()->minimumSectionSize()); ui->groupBoxView->show(); }
Ergebnisse in XSLX-Datei exportieren.
Um die Ergebnisse in eine xlsx-Datei zu exportieren, verwenden wir die QXlsx-Bibliothek
https://qtexcel.github.io/QXlsx/
. Ich entschied mich dafür, nachdem ich mir Anwendungsbeispiele und verfügbare Anweisungen zum Verbinden mit dem Projekt angeschaut hatte. Ich habe die Beispiele zusammengestellt und schnell die einfachste Verwendung der Bibliothek herausgefunden.
Verbindungsanweisungen finden Sie hier
https://qtexcel.github.io/QXlsx/HowToSetProject.html
.
In Kürze sieht es so aus:
Quellen von github klonen
git clone https://github.com/j2doll/QXlsx.git
Kopieren Sie den Inhalt des QXlsx-Ordners (Header, Quellordner und QXlsx.pri-, QXlsx.pro-Dateien) in unseren Projektordner.
Zu unserer Projektdatei hinzufügen (*.pro)
# QXlsx code for Application Qt project QXLSX_PARENTPATH=./ # current QXlsx path is . (. means curret directory) QXLSX_HEADERPATH=./header/ # current QXlsx header path is ./header/ QXLSX_SOURCEPATH=./source/ # current QXlsx source path is ./source/ include(./QXlsx.pri)
Fügen Sie in der Datei, in der wir die Bibliothek verwenden, Header-Dateien hinzu.
#include "xlsxdocument.h" #include "xlsxchartsheet.h" #include "xlsxcellrange.h" #include "xlsxchart.h" #include "xlsxrichstring.h" #include "xlsxworkbook.h" using namespace QXlsx;
Die Bibliothek ist einsatzbereit.
void ViewFuelNameDialog::exportXlsx() { Document xlsx; // Будущий документ Format format; // Формат обычных ячеек Format formatMerge; // Формат объединенной ячейки Format formatTitle; // Формат заголовка //Задаем параметры форматирования format.setHorizontalAlignment(Format::AlignHCenter); format.setVerticalAlignment(Format::AlignVCenter); format.setBorderStyle(Format::BorderThin); formatMerge.setPatternBackgroundColor(QColor("#aaff7f")); formatMerge.setHorizontalAlignment(Format::AlignHCenter); formatMerge.setVerticalAlignment(Format::AlignVCenter); formatMerge.setBorderStyle(Format::BorderThin); formatTitle.setHorizontalAlignment(Format::AlignHCenter); formatTitle.setVerticalAlignment(Format::AlignVCenter); formatTitle.setFontBold(true); formatTitle.setBorderStyle(Format::BorderThin); formatTitle.setPatternBackgroundColor(QColor("#A9BCF5")); //Необходимо отметить что нумерация строк и столбцов в xlsx документе начинается с 1 //Устанавливаем ширину столбцов xlsx.setColumnWidth(1,10); xlsx.setColumnWidth(4,30); int columnCount = headers.size(); int colAzs = m_listFuelName.size(); //Заполняем заголовки for(int i =0; i<columnCount; ++i){ xlsx.write(1,i+1, headers.at(i),formatTitle); } //Табличная часть int rowX=2; for(int i=0; i<colAzs; ++i){ xlsx.write(rowX,1, QString::number(m_listFuelName.at(i).terminalID())+" "+m_listFuelName.at(i).azsName()); CellRange cellRange = CellRange(rowX,1,rowX,columnCount); xlsx.mergeCells(cellRange, formatMerge); for(int j = 0; j<m_listFuelName.at(i).listFuels().size(); ++j) { rowX++; xlsx.write(rowX,1,m_listFuelName.at(i).listFuels().at(j).tankID(),format); xlsx.write(rowX,2,m_listFuelName.at(i).listFuels().at(j).fuelID(),format); xlsx.write(rowX,3,m_listFuelName.at(i).listFuels().at(j).shortName(),format); xlsx.write(rowX,4,m_listFuelName.at(i).listFuels().at(j).name(),format); } } QFile xlsxFile; //Создаем абсолютный путь к файлу xlsxFile.setFileName(QApplication::applicationDirPath()+"/"+"FuelName.xlsx"); xlsx.saveAs(xlsxFile.fileName()); // Сохраняем документ #ifdef Q_OS_WIN QDesktopServices::openUrl(QUrl("file:///"+xlsxFile.fileName(), QUrl::TolerantMode)); #else QDesktopServices::openUrl(QUrl("file://"+xlsxFile.fileName(), QUrl::TolerantMode)); #endif this->reject(); }
Wir erhalten die Datei FuelName.xlsx, die standardmäßig vom Programm geöffnet wird.
Projektarchiv
.