Форум программистов, компьютерный форум, киберфорум
Python: GUI, графика
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 5.00/7: Рейтинг темы: голосов - 7, средняя оценка - 5.00
 Аватар для Telnow
10 / 10 / 1
Регистрация: 08.04.2022
Сообщений: 187
PyQt6

Реализация поиска в tableWidget

27.07.2022, 10:07. Показов 1717. Ответов 13
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Привет!

Доработайте пожалуйста мой код, каким образом можно реализовать поиск только по первой колонке, но при этом выделять всю строку?

Python
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
79
80
81
82
83
84
85
86
from PyQt6 import QtCore, QtGui, QtWidgets
from PyQt6.QtCore import Qt
 
class Ui_MainWindow(QtWidgets.QMainWindow):
 
    def __init__(self):
        super().__init__()
        self.setupUi(self)
        self.add_data()
        self.lineEdit.textChanged.connect(self.search_user)
 
    def add_data(self):
        self.tableWidget.setItem(0,0, QtWidgets.QTableWidgetItem("Анна"))
        self.tableWidget.setItem(1,0, QtWidgets.QTableWidgetItem("Федор"))
        self.tableWidget.setItem(2,0, QtWidgets.QTableWidgetItem("Ирина"))
        self.tableWidget.setItem(0,1, QtWidgets.QTableWidgetItem("Anna"))
        self.tableWidget.setItem(1,1, QtWidgets.QTableWidgetItem("Fedor"))
        self.tableWidget.setItem(2,1, QtWidgets.QTableWidgetItem("Irina"))
        self.tableWidget.setItem(0,2, QtWidgets.QTableWidgetItem("566342"))
        self.tableWidget.setItem(1,2, QtWidgets.QTableWidgetItem("785123"))
        self.tableWidget.setItem(2,2, QtWidgets.QTableWidgetItem("086343"))
 
    def search_user(self, user):
        self.tableWidget.setCurrentItem(None)
        if not user:
            return
        matching_items = self.tableWidget.findItems(user, Qt.MatchFlag.MatchContains)
        if matching_items:
            item = matching_items[0]
            self.tableWidget.setCurrentItem(item.setBackground(QtGui.QColor("yellow")))
 
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(369, 309)
        self.centralwidget = QtWidgets.QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.verticalLayout = QtWidgets.QVBoxLayout(self.centralwidget)
        self.verticalLayout.setObjectName("verticalLayout")
        self.tableWidget = QtWidgets.QTableWidget(self.centralwidget)
        self.tableWidget.setObjectName("tableWidget")
        self.tableWidget.setColumnCount(3)
        self.tableWidget.setRowCount(3)
        item = QtWidgets.QTableWidgetItem()
        self.tableWidget.setVerticalHeaderItem(0, item)
        item = QtWidgets.QTableWidgetItem()
        self.tableWidget.setVerticalHeaderItem(1, item)
        item = QtWidgets.QTableWidgetItem()
        self.tableWidget.setVerticalHeaderItem(2, item)
        item = QtWidgets.QTableWidgetItem()
        self.tableWidget.setHorizontalHeaderItem(0, item)
        item = QtWidgets.QTableWidgetItem()
        self.tableWidget.setHorizontalHeaderItem(1, item)
        item = QtWidgets.QTableWidgetItem()
        self.tableWidget.setHorizontalHeaderItem(2, item)
        self.verticalLayout.addWidget(self.tableWidget)
        self.lineEdit = QtWidgets.QLineEdit(self.centralwidget)
        self.lineEdit.setObjectName("lineEdit")
        self.verticalLayout.addWidget(self.lineEdit)
        MainWindow.setCentralWidget(self.centralwidget)
 
        self.retranslateUi(MainWindow)
        QtCore.QMetaObject.connectSlotsByName(MainWindow)
 
    def retranslateUi(self, MainWindow):
        _translate = QtCore.QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        item = self.tableWidget.verticalHeaderItem(0)
        item.setText(_translate("MainWindow", "1"))
        item = self.tableWidget.verticalHeaderItem(1)
        item.setText(_translate("MainWindow", "2"))
        item = self.tableWidget.verticalHeaderItem(2)
        item.setText(_translate("MainWindow", "3"))
        item = self.tableWidget.horizontalHeaderItem(0)
        item.setText(_translate("MainWindow", "Пользователь"))
        item = self.tableWidget.horizontalHeaderItem(1)
        item.setText(_translate("MainWindow", "Логин"))
        item = self.tableWidget.horizontalHeaderItem(2)
        item.setText(_translate("MainWindow", "Пароль"))
 
 
if __name__ == "__main__":
    import sys
    app = QtWidgets.QApplication(sys.argv)
    w = Ui_MainWindow()
    w.show()
    sys.exit(app.exec())
0
Лучшие ответы (1)
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
27.07.2022, 10:07
Ответы с готовыми решениями:

Не получается добавить итем из tablewidget основного окна в tablewidget дочернего окна
Здравствуйте, я не могу разобраться, как при помощи функции add_cpu добавить в таблицу дочернего окна из таблицы основного окна ячейку,...

Реализация поиска по сайту - переход по станицам с сохранением запроса поиска
Всем известно что все запросы пользователя в данном случае хранятся в _GET массиве. Проблема такова что когда пользователь ввел какие-то...

Реализация функции поиска нужной услуги по заданным критериям поиска.
Получил задание на тему ArrayList, не получается сделать целиком...Вот задание помогите кто чем сможет.Спасибо. Необходимо разработать...

13
 Аватар для kapbepucm
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,656
27.07.2022, 12:04
Python
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
    def search_user(self, user):
        self.tableWidget.setCurrentItem(None)
        if not user:
            return
        matching_items = self.tableWidget.findItems(user, Qt.MatchFlag.MatchContains)
        if matching_items:
            for column in range(self.tableWidget.columnCount()):
              for row in range(self.tableWidget.rowCount()):
                self.tableWidget.item(row, column).setBackground(QtGui.QBrush())
            for item in matching_items:
              if item.column()==0:
                for i in range(self.tableWidget.columnCount()):
                  self.tableWidget.item(item.row(), i).setBackground(QtGui.QColor("yellow"))
                self.tableWidget.setCurrentItem(item)
                break
1
 Аватар для Telnow
10 / 10 / 1
Регистрация: 08.04.2022
Сообщений: 187
27.07.2022, 12:12  [ТС]
kapbepucm, Благодарю Вас!

И еще вопрос в тему, как перейти к следующему найденному элементу по кнопке Enter когда в колонке будут два пользователя с одинаковым именем?
0
 Аватар для kapbepucm
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,656
27.07.2022, 12:24
Цитата Сообщение от telnofff Посмотреть сообщение
как перейти к следующему найденному элементу по кнопке Enter
А где при этом будет находиться фокус ввода (в таблице или поле поиска)?
0
 Аватар для Telnow
10 / 10 / 1
Регистрация: 08.04.2022
Сообщений: 187
27.07.2022, 12:27  [ТС]
kapbepucm, в таблице (если Вам не сложно можете показать оба варианта?).
0
 Аватар для kapbepucm
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,656
27.07.2022, 14:27
Лучший ответ Сообщение было отмечено telnofff как решение

Решение

Наверно, оба варианта будут работать:
Python
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
from PyQt6.QtWidgets import QTableWidgetItem, QMainWindow, QApplication, QWidget
from PyQt6.QtWidgets import QTableWidget, QVBoxLayout, QLineEdit
from PyQt6.QtGui import QBrush, QColor
from PyQt6.QtCore import Qt, QCoreApplication, QMetaObject
 
class Ui_MainWindow(QMainWindow):
    def __init__(self):
        super().__init__()
        self.setupUi(self)
        self.tableWidget.matching_items = []
        self.tableWidget.match_line = -1
        self.add_data()
        self.lineEdit.textChanged.connect(self.search_user)
    def add_data(self):
        self.tableWidget.setItem(0,0, QTableWidgetItem("Анна"))
        self.tableWidget.setItem(1,0, QTableWidgetItem("Федор"))
        self.tableWidget.setItem(2,0, QTableWidgetItem("Ирина"))
        self.tableWidget.setItem(0,1, QTableWidgetItem("Anna"))
        self.tableWidget.setItem(1,1, QTableWidgetItem("Fedor"))
        self.tableWidget.setItem(2,1, QTableWidgetItem("Irina"))
        self.tableWidget.setItem(0,2, QTableWidgetItem("566342"))
        self.tableWidget.setItem(1,2, QTableWidgetItem("785123"))
        self.tableWidget.setItem(2,2, QTableWidgetItem("086343"))
        self.tableWidget.setItem(3,0, QTableWidgetItem("Федор"))
        self.tableWidget.setItem(3,1, QTableWidgetItem(""))
        self.tableWidget.setItem(3,2, QTableWidgetItem(""))
    def search_user(self, user):
        self.tableWidget.setCurrentItem(None)
        if not user:
            return
        self.tableWidget.matching_items = []
        self.tableWidget.match_line = -1
        matching_items = self.tableWidget.findItems(user, Qt.MatchFlag.MatchContains)
        if matching_items:
          for item in matching_items:
            if item.column()==0:
              self.tableWidget.matching_items.append(item)
          self.select_match()
    def select_match(self):
      if len(self.tableWidget.matching_items) > 0:
        for column in range(self.tableWidget.columnCount()):
          for row in range(self.tableWidget.rowCount()):
            self.tableWidget.item(row, column).setBackground(QBrush())
        if self.tableWidget.match_line == len(self.tableWidget.matching_items)-1:
          self.tableWidget.match_line = 0
        else:
          self.tableWidget.match_line = self.tableWidget.match_line + 1
        item = self.tableWidget.matching_items[self.tableWidget.match_line]
        item.setBackground(QColor("yellow"))
        for i in range(self.tableWidget.columnCount()):
          self.tableWidget.item(item.row(), i).setBackground(QColor("yellow"))
        self.tableWidget.setCurrentItem(item)
    def keyPressEvent(self, event):
      if event.key() == Qt.Key.Key_Return:
        self.select_match()
      super().keyPressEvent(event)
    def setupUi(self, MainWindow):
        MainWindow.setObjectName("MainWindow")
        MainWindow.resize(369, 309)
        self.centralwidget = QWidget(MainWindow)
        self.centralwidget.setObjectName("centralwidget")
        self.verticalLayout = QVBoxLayout(self.centralwidget)
        self.verticalLayout.setObjectName("verticalLayout")
        self.tableWidget = QTableWidget(self.centralwidget)
        self.tableWidget.setObjectName("tableWidget")
        self.tableWidget.setColumnCount(3)
        self.tableWidget.setRowCount(4)
        item = QTableWidgetItem()
        self.tableWidget.setVerticalHeaderItem(0, item)
        item = QTableWidgetItem()
        self.tableWidget.setVerticalHeaderItem(1, item)
        item = QTableWidgetItem()
        self.tableWidget.setVerticalHeaderItem(2, item)
        item = QTableWidgetItem()
        self.tableWidget.setHorizontalHeaderItem(0, item)
        item = QTableWidgetItem()
        self.tableWidget.setHorizontalHeaderItem(1, item)
        item = QTableWidgetItem()
        self.tableWidget.setHorizontalHeaderItem(2, item)
        self.verticalLayout.addWidget(self.tableWidget)
        self.lineEdit = QLineEdit(self.centralwidget)
        self.lineEdit.setObjectName("lineEdit")
        self.verticalLayout.addWidget(self.lineEdit)
        MainWindow.setCentralWidget(self.centralwidget)
        self.retranslateUi(MainWindow)
        QMetaObject.connectSlotsByName(MainWindow)
    def retranslateUi(self, MainWindow):
        _translate = QCoreApplication.translate
        MainWindow.setWindowTitle(_translate("MainWindow", "MainWindow"))
        item = self.tableWidget.verticalHeaderItem(0)
        item.setText(_translate("MainWindow", "1"))
        item = self.tableWidget.verticalHeaderItem(1)
        item.setText(_translate("MainWindow", "2"))
        item = self.tableWidget.verticalHeaderItem(2)
        item.setText(_translate("MainWindow", "3"))
        item = self.tableWidget.horizontalHeaderItem(0)
        item.setText(_translate("MainWindow", "Пользователь"))
        item = self.tableWidget.horizontalHeaderItem(1)
        item.setText(_translate("MainWindow", "Логин"))
        item = self.tableWidget.horizontalHeaderItem(2)
        item.setText(_translate("MainWindow", "Пароль"))
 
if __name__ == "__main__":
    import sys
    app = QApplication(sys.argv)
    w = Ui_MainWindow()
    w.show()
    sys.exit(app.exec())
1
 Аватар для Telnow
10 / 10 / 1
Регистрация: 08.04.2022
Сообщений: 187
27.07.2022, 14:46  [ТС]
kapbepucm, Большое Вам спасибо! Вы сколько месяцев/лет изучаете PyQt? Посоветуйте хороший видеокурс или литературу.
0
 Аватар для Михалыч
1011 / 355 / 59
Регистрация: 28.02.2013
Сообщений: 937
27.07.2022, 17:00
Цитата Сообщение от telnofff Посмотреть сообщение
Посоветуйте хороший видеокурс или литературу.
на русском книга по pyqt но мне не очень зашла. А вот на англ.яз. тут прямо вообще норм, не пожалейте 1000 руб.)
1
 Аватар для kapbepucm
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,656
28.07.2022, 08:53
Цитата Сообщение от telnofff Посмотреть сообщение
Вы сколько месяцев/лет изучаете PyQt? Посоветуйте хороший видеокурс или литературу.
Ничего толком от себя посоветовать не могу, разве что видеолекции МФТИ, что я смотрел, по чистому Python, а Qt мне знаком из мира C++ со времён Qt3-Qt4.
0
28.07.2022, 09:13

Не по теме:

Цитата Сообщение от kapbepucm Посмотреть сообщение
разве что видеолекции МФТИ
это лекции Хирьянова?

0
28.07.2022, 09:14

Не по теме:

Цитата Сообщение от Михалыч Посмотреть сообщение
это лекции Хирьянова?
именно :)

0
 Аватар для Михалыч
1011 / 355 / 59
Регистрация: 28.02.2013
Сообщений: 937
28.07.2022, 09:16
Цитата Сообщение от telnofff Посмотреть сообщение
Посоветуйте хороший видеокурс или литературу.
Вспомнил еще вот на русском http://it.kgsu.ru/Python_Qt/oglav.html
2
 Аватар для Telnow
10 / 10 / 1
Регистрация: 08.04.2022
Сообщений: 187
28.07.2022, 09:18  [ТС]
Михалыч, Ошибка 404, при переходе на Вашей ссылке
0
28.07.2022, 09:19

Не по теме:

Поправил)

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
28.07.2022, 09:19
Помогаю со студенческими работами здесь

Реализация поиска
Хотел сделать поиск по таблице поступления Вот код : begin help1:='%'+Form16.Edit1.Text+'%'; help2:=QuotedStr(help1); ...

Реализация поиска
Доброго времени суток. Пытаюсь сделать поиск на сайте. Сам по себе поиск работает, он выбает список материалов на сайте. К примеры посты...

Реализация поиска на сайте
Ребята, скинули франкенштейна на плечи в виде сайта предприятия, который до этого вёлся не понятно кем и не понятно как. Сам я до этого...

Реализация поиска по Select
Доброго времени суток! Передо мной стоит задача: реализовать поиск по выборке данных из Select наглядно: выбираем название болезни...

Реализация поиска в приложении
Не могу реализовать простейший поиск в приложении. В приложении таб из 3-х вкладов, на 1 и на 2 лист вью с несколькими элементами. так я...


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

Или воспользуйтесь поиском по форуму:
14
Ответ Создать тему
Новые блоги и статьи
Загрузка PNG-файла с альфа-каналом с помощью библиотеки SDL3_image на Android
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
Установка Android SDK, NDK, JDK, CMake и т.д.
8Observer8 25.01.2026
Содержание блога Перейдите по ссылке: https:/ / developer. android. com/ studio и в самом низу страницы кликните по архиву "commandlinetools-win-xxxxxx_latest. zip" Извлеките архив и вы увидите. . .
Вывод текста со шрифтом TTF на Android с помощью библиотеки SDL3_ttf
8Observer8 25.01.2026
Содержание блога Если у вас не установлены Android SDK, NDK, JDK, и т. д. то сделайте это по следующей инструкции: Установка Android SDK, NDK, JDK, CMake и т. д. Сборка примера Скачайте. . .
Использование SDL3-callbacks вместо функции main() на Android, Desktop и WebAssembly
8Observer8 24.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
моя боль
iceja 24.01.2026
Выложила интерполяцию кубическими сплайнами www. iceja. net REST сервисы временно не работают, только через Web. Написала за 56 рабочих часов этот сайт с нуля. При помощи perplexity. ai PRO , при. . .
Модель сукцессии микоризы
anaschu 24.01.2026
Решили писать научную статью с неким РОманом
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru