Evgenii Legotckoi
Evgenii Legotckoi15. Juni 2017 02:58

Qt/C++ - Tutorial 067. Verwenden von QMultiMap für ein Synonymwörterbuch

QMultiMap ist eine von QMap abgeleitete Klasse, mit der Sie mehrere Werte für denselben Schlüssel speichern können. Das heißt, der Schlüssel kann wiederholt werden. Diese Klasse kann beispielsweise verwendet werden, um ein Synonymwörterbuch darzustellen.

Lassen Sie uns ein kleines Programm schreiben, das zwei Tabellen enthält:

  1. Tabelle mit Schlüsseln
  2. Eine Tabelle mit Werten, die Synonyme für die Wörter in der ersten Tabelle sein werden.

Zunächst wird die Tabelle mit Schlüsseln gefüllt, während die Tabelle mit Werten leer ist. Wenn Sie in der Schlüsseltabelle auf eine Zeile klicken, wird die Wertetabelle mit Synonymen des Wortes gefüllt, auf deren Zeile geklickt wurde.

Aussehen der Anwendung:


Projektstruktur

  • QMultiMapExample.pro - Projektprofil, wird standardmäßig erstellt und ändert sich nicht
  • main.cpp - Datei mit der Hauptfunktion, die standardmäßig erstellt wird und sich nicht ändert.
  • widget.ui - die Form des Anwendungsfensters, erstellen Sie ein Fenster, wie in der Abbildung oben.
  • widget.h - Header-Datei des Anwendungsfensters
  • widget.cpp - Quellcodedatei des Anwendungsfensters.

Widget.h

Um die Aufgabe zu implementieren, benötigen wir QMultiMap selbst, die das gesamte Wörterbuch enthalten wird. Das Wörterbuch kann aus einer Datei oder manuell über eine spezielle Eingabe, die Sie bereitstellen können, oder auf andere Weise ausgefüllt werden. Und in diesem Fall füllen wir das Synonymwörterbuch beim Start der Anwendung aus. Es wird drei Schlüssel geben und jeder wird drei Synonyme haben.

Wir werden auch Datenmodelle benötigen, um QMultiMap -Schlüssel und -Werte in Tabellen anzuzeigen. Dafür verwenden wir QStandardItemModel.

Und wir schreiben einen Slot für die Verarbeitung von Klicks auf Zeilen in der Schlüsseltabelle. In diesem Slot füllen wir die Wertetabelle aus.

#ifndef WIDGET_H
#define WIDGET_H

#include <QWidget>
#include <QMultiMap>
#include <QStandardItemModel>
#include <QModelIndex>

namespace Ui {
class Widget;
}

class Widget : public QWidget
{
    Q_OBJECT

public:
    explicit Widget(QWidget *parent = 0);
    ~Widget();

public slots:
    void wordsTableViewClicked(const QModelIndex &index);

private:
    Ui::Widget *ui;
    QMultiMap<QString, QString> m_synonymousMap;
    QStandardItemModel m_keysModel;
    QStandardItemModel m_valuesModel;
};

#endif // WIDGET_H

Widget.cpp

Es reicht aus, die Datenmodelle einmal in den Tabellen zu installieren, danach werden wir sie bei Bedarf löschen.

#include "widget.h"
#include "ui_widget.h"

Widget::Widget(QWidget *parent) :
    QWidget(parent),
    ui(new Ui::Widget)
{
    ui->setupUi(this);

    // Заполняем словарь синонимов
    m_synonymousMap.insert("daemon", "demon");
    m_synonymousMap.insert("daemon", "devil");
    m_synonymousMap.insert("daemon", "demonic");

    m_synonymousMap.insert("chief", "head");
    m_synonymousMap.insert("chief", "senior");
    m_synonymousMap.insert("chief", "superior");

    m_synonymousMap.insert("road", "roadway");
    m_synonymousMap.insert("road", "high road");
    m_synonymousMap.insert("road", "highway");

    // Забираем все ключи и заполняем модель данных ключей
    // метод QMultiMap::uniqueKey() возвращает список ключей без повторов
    // обычный метод keys() будет возвращать ключи в данном словаре по три раза
    // тогда как этот метод вернёт каждый ключ один раз
    for (auto key : m_synonymousMap.uniqueKeys())
    {
        m_keysModel.appendRow(new QStandardItem(key));
    }

    // устанавливаем модели данных в таблицы
    ui->wordsTableView->setModel(&m_keysModel);
    ui->synonymsTableView->setModel(&m_valuesModel);

    // Подключаем сигнал клика по строке для обработке этого клика в слоте
    connect(ui->wordsTableView, &QTableView::clicked, this, &Widget::wordsTableViewClicked);
}

Widget::~Widget()
{
    delete ui;
}

void Widget::wordsTableViewClicked(const QModelIndex &index)
{
    // Очищаем модель данных, чтобы не было синонимов предыдущего ключа
    m_valuesModel.clear();

    // и заполняем модель значений синонимами
    // Поскольку в строке используется только одна колонка,
    // то сразу забираем ключ с помощью переданного индекса из модели, которая находится в таблице ключей
    for (auto value : m_synonymousMap.values(ui->wordsTableView->model()->data(index).toString()))
    {
        m_valuesModel.appendRow(new QStandardItem(value));
    }
}

Insgesamt

Als Ergebnis erhalten wir eine Anwendung, die wie in der Abbildung am Anfang des Artikels gezeigt aussieht.

Anwendungsprojekt herunterladen

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Stabiles Hosting des sozialen Netzwerks EVILEG. Wir empfehlen VDS-Hosting für Django-Projekte.

Magst du es? In sozialen Netzwerken teilen!

Kommentare

Nur autorisierte Benutzer können Kommentare posten.
Bitte Anmelden oder Registrieren
Letzte Kommentare
A
ALO1ZE19. Oktober 2024 08:19
Fb3-Dateileser auf Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов5. Oktober 2024 07:51
Django – Lektion 064. So schreiben Sie eine Python-Markdown-Erweiterung Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas55. Juli 2024 11:02
QML - Lektion 016. SQLite-Datenbank und das Arbeiten damit in QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
k
kmssr8. Februar 2024 18:43
Qt Linux - Lektion 001. Autorun Qt-Anwendung unter Linux как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
Qt WinAPI - Lektion 007. Arbeiten mit ICMP-Ping in Qt Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
Jetzt im Forum diskutieren
J
JacobFib17. Oktober 2024 03:27
добавить qlineseries в функции Пользователь может получить любые разъяснения по интересующим вопросам, касающимся обработки его персональных данных, обратившись к Оператору с помощью электронной почты https://topdecorpro.ru…
JW
Jhon Wick1. Oktober 2024 15:52
Indian Food Restaurant In Columbus OH| Layla’s Kitchen Indian Restaurant If you're looking for a truly authentic https://www.laylaskitchenrestaurantohio.com/ , Layla’s Kitchen Indian Restaurant is your go-to destination. Located at 6152 Cleveland Ave, Colu…
КГ
Кирилл Гусарев27. September 2024 09:09
Не запускается программа на Qt: точка входа в процедуру не найдена в библиотеке DLL Написал программу на C++ Qt в Qt Creator, сбилдил Release с помощью MinGW 64-bit, бинарнику напихал dll-ки с помощью windeployqt.exe. При попытке запуска моей сбилженной программы выдаёт три оши…
F
Fynjy22. Juli 2024 04:15
при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …

Folgen Sie uns in sozialen Netzwerken