С Новым годом! Форум программистов, компьютерный форум, киберфорум
C++ Qt
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 12.03.2023
Сообщений: 75
1

Как добавить в lineEdit отображение текста из таблицы (sqlLite studio)

29.06.2023, 12:30. Показов 324. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте. Проблема заключается в том что значение из таблицы при выделении строки не отображается в lineEdit, заметил что при запросе JOIN такое происходит, при SELECT * FROM, код корректно работает. За ранее спасибо.

Вот код подключения сигналов и слотов

C++ (Qt)
1
2
3
 connect(ui->lineEdit, &QLineEdit::textChanged, this, Suppliers::onLineEditValueChanged);
  connect(ui->lineEdit_2, &QLineEdit::textChanged, this, Suppliers::onLineEditValue2Changed);
  connect(ui->tableWidget->selectionModel(), &QItemSelectionModel::selectionChanged, this, &Suppliers::onItemSelectionChanged);
Сам код загрузки таблицы из sqlLite studio

C++ (Qt)
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
 void Suppliers::suppliers1()
{
    ui->groupBox->setTitle("Справочник поставщики");
 
    QSqlQuery sup;
     sup.exec("SELECT SupplierName, Organization.Organization AS Organizations "
              "FROM Suppliers JOIN Organization ON Suppliers.Organization = Organization.Organization");
 
     ui->tableWidget->setRowCount(0);
     ui->tableWidget->setColumnCount(2);
     ui->tableWidget->setHorizontalHeaderLabels(QStringList() << "Отвественное лицо" << "Организация");
     ui->tableWidget->setSortingEnabled(true);
 
     int row = 0;
     while (sup.next())
     {
         ui->tableWidget->insertRow(row);
 
         QTableWidgetItem *item = new QTableWidgetItem(sup.value(0).toString());
         item->setTextAlignment(Qt::AlignHCenter);
         ui->tableWidget->setItem(row, 0, item);
 
         QTableWidgetItem *item2 = new QTableWidgetItem(sup.value(1).toString());
         item2->setTextAlignment(Qt::AlignHCenter);
         ui->tableWidget->setItem(row, 1, item2);
 
         row++;
     }
 
     ui->tableWidget->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);
}

Код редактирования таблицы
C++ (Qt)
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
void Suppliers::onItemSelectionChanged() // Редактирование содержимого таблицы
{
    QModelIndexList selectedRows = ui->tableWidget->selectionModel()->selectedRows();
 
        if (selectedRows.count() > 0)
        {
            int selectedRow = selectedRows.at(0).row();
 
            QTableWidgetItem* item1 = ui->tableWidget->item(selectedRow, 0);
            if (item1)
            {
                ui->lineEdit->setText(item1->text());
            }
            else
            {
                ui->lineEdit->clear();
            }
 
            QTableWidgetItem* item2 = ui->tableWidget->item(selectedRow, 1);
            if (item2)
            {
                ui->lineEdit_2->setText(item2->text());
            }
            else
            {
                ui->lineEdit_2->clear();
            }
        }
 
}
И код для lineEdit1 и LineEdit2

C++ (Qt)
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
 void Suppliers::onLineEditValueChanged(const QString &text) // LineEdit
{
    int selectedRow = ui->tableWidget->currentRow();
 
       if (selectedRow >= 0 && selectedRow < ui->tableWidget->rowCount())
       {
           QTableWidgetItem* item = ui->tableWidget->item(selectedRow, 0);
           if (item)
           {
               item->setText(text);
               item->setTextAlignment(Qt::AlignHCenter);
           }
       }
}
void Suppliers::onLineEditValue2Changed(const QString &text) // LineEdit 2
{
    int selectedRow = ui->tableWidget->currentRow();
 
      if (selectedRow >= 0 && selectedRow < ui->tableWidget->rowCount())
      {
          QTableWidgetItem* item = ui->tableWidget->item(selectedRow, 1);
          if (item)
          {
              item->setText(text);
              item->setTextAlignment(Qt::AlignHCenter);
          }
      }
}
Добавлено через 1 час 24 минуты
Все уже исправил.Нужно было сделать выделение всей строки, а не ячейки.
0
IT_Exp
Эксперт
8794 / 1073 / 104
Регистрация: 17.06.2006
Сообщений: 12,602
Блог
29.06.2023, 12:30
Ответы с готовыми решениями:

Как запретить выделение текста в LineEdit
Здравствуйте, как запретить выделение текста в LineEdit

Как сделать кнопку неактивной, если LineEdit пустой, и активной когда в LineEdit введен текст?
Всем привет! Столкнулся с такой ситуацией: в окне есть виджет LineEdit и кнопка. Я хочу чтобы при...

Как при редактировании текста в lineedit кидать месседж?
Как на win32API реализовать? Короче говоря, как при вводе(затирании) буквы в lineedit кидать...

Как менять цвет текста в listWidget, lineEdit итд. PyQt6, PySide6
Как можно для каждого слова отдельно применить свой цвет? Допустим items = str('Привет, как...

0
29.06.2023, 12:30
BasicMan
Эксперт
19315 / 2622 / 84
Регистрация: 17.02.2009
Сообщений: 10,364
Блог
29.06.2023, 12:30
Помогаю со студенческими работами здесь

Обновление таблицы БД SqlLite
Доброго времени суток. У меня стоит задача изменять значения в БД через форму listView используя...

Получение текста из LineEdit
Есть небольшое окошко, на котором находится кнопка. По нажатию на эту кнопку создается окно, где...

Сохранение текста из lineEdit
Когда я пытаюсь сохранить текст из lineEdit в переменную, а потом я вывожу значение с помощью...

Запись текста в файл через lineedit
В общем нужно записывать в текстовый файл txt определенное число с line edit в определенное место...

Передача текста из lineEdit в label в другом окне
Добрый день возникла такая проблема у меня в проекте есть главное окно якобы авторизация, и надо...

Вместо текста в массиве сделать ввод с LineEdit
Добрый вечер! Помогите пожалуйста в такой проблеме. Вот массив должен выводить только цифры...

Передача данных из LineEdit в ячейки таблицы TableView
Добрый день, мне нужно создать строку в TableView и передать значения, которые я введу в Line Edit...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Блоги программистов
Обновление сайта www.historian.b­y
Reglage 05.01.2025
Обещал подвести итоги 2024 года для сайта. Однако начну с того, что изменилось за неделю. Добавил краткий урок по последовательности действий при анализе вредоносных файлов и значительно улучшил урок. . .
Как использовать GraphQL в C# с HotChocolate
Programming 05.01.2025
GraphQL — это современный подход к разработке API, который позволяет клиентам запрашивать только те данные, которые им необходимы. Это делает взаимодействие с API более гибким и эффективным по. . .
Модель полного двоичного суматора с помощью логических операций (python)
AlexSky-coder 04.01.2025
def binSum(x:list, y:list): s=^y] p=x and y for i in range(1,len(x)): s. append((x^y)^p) p=(x and y)or(p and (x or y)) return s x=list() y=list()
Это мы не проходили, это нам не задавали...(аси­­хронный счётчик с управляющим сигналом задержки).
Hrethgir 04.01.2025
Асинхронный счётчик на сумматорах (шестиразрядный по числу диодов на плате, но наверное разрядов будет больше - восемь или шестнадцать, а диоды на старшие), так как триггеры прошли тестирование и. . .
Руководство по созданию бота для Телеграм на Python
IT_Exp 04.01.2025
Боты для Телеграм представляют собой автоматизированные программы, которые выполняют различные задачи, взаимодействуя с пользователями через интерфейс мессенджера. В данной статье мы рассмотрим,. . .
Применение компонентов PrimeVue в Vue.js 3 на TypeScript
BasicMan 04.01.2025
Введение в PrimeVue и настройка окружения PrimeVue представляет собой мощную библиотеку компонентов пользовательского интерфейса для Vue. js 3, которая предоставляет разработчикам богатый набор. . .
Как стать Senior developer
cpp_developer 04.01.2025
В современной индустрии разработки программного обеспечения позиция Senior Developer представляет собой не просто следующую ступень карьерной лестницы, а качественно новый уровень профессионального. . .
Что известно о дате выхода Windows 12 и чего от нее ждать
IT_Exp 04.01.2025
В мире технологий постоянно происходят изменения, и операционные системы не являются исключением. Windows 11, выпущенная в октябре 2021 года, принесла множество инноваций и улучшений, но. . .
Что новенького в .NET Core 9
Programming 04.01.2025
Обзор ключевых изменений в . NET Core 9 Платформа . NET Core продолжает активно развиваться, и версия 9 представляет собой значительный шаг вперед в эволюции этой технологии. Новый релиз. . .
Инструкция по установке python3.13.1 в Debian 12
AlexSky-coder 03.01.2025
sudo apt update sudo apt install build-essential zlib1g-dev libncurses5-dev libgdbm-dev libnss3-dev libssl-dev libreadline-dev libffi-dev wget. . .
Затестил триггеры. архив проекта прилагаю с GOA файлами в настройках архиватора проектов.
Hrethgir 03.01.2025
В этот раз нет закольцованности, потому что от неё только глюки, как я понял, логика не вырезанная. Триггеры очень быстрые если верить измерениям с помощью анализатора от Gowin. Есть ещё регистры,. . .
Python в помощь DevOps
IT_Exp 03.01.2025
Причины использования Python в работе DevOps Python стал неотъемлемой частью мира DevOps, и это не случайно. Этот язык программирования обладает множеством преимуществ, которые делают его. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru