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

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

27.07.2022, 10:07. Показов 1793. Ответов 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
1568 / 741 / 321
Регистрация: 02.05.2020
Сообщений: 1,660
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
1568 / 741 / 321
Регистрация: 02.05.2020
Сообщений: 1,660
27.07.2022, 12:24
Цитата Сообщение от telnofff Посмотреть сообщение
как перейти к следующему найденному элементу по кнопке Enter
А где при этом будет находиться фокус ввода (в таблице или поле поиска)?
0
 Аватар для Telnow
10 / 10 / 1
Регистрация: 08.04.2022
Сообщений: 187
27.07.2022, 12:27  [ТС]
kapbepucm, в таблице (если Вам не сложно можете показать оба варианта?).
0
 Аватар для kapbepucm
1568 / 741 / 321
Регистрация: 02.05.2020
Сообщений: 1,660
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
Сообщений: 939
27.07.2022, 17:00
Цитата Сообщение от telnofff Посмотреть сообщение
Посоветуйте хороший видеокурс или литературу.
на русском книга по pyqt но мне не очень зашла. А вот на англ.яз. тут прямо вообще норм, не пожалейте 1000 руб.)
1
 Аватар для kapbepucm
1568 / 741 / 321
Регистрация: 02.05.2020
Сообщений: 1,660
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
Сообщений: 939
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
Ответ Создать тему
Новые блоги и статьи
Установка Qt Creator для C и C++: ставим среду, CMake и MinGW без фреймворка Qt
8Observer8 05.04.2026
Среду разработки Qt Creator можно установить без фреймворка Qt. Есть отдельный репозиторий для этой среды: https:/ / github. com/ qt-creator/ qt-creator, где можно скачать установщик, на вкладке Releases:. . .
AkelPad-скрипты, структуры, и немного лирики..
testuser2 05.04.2026
Такая программа, как AkelPad существует уже давно, и также давно существуют скрипты под нее. Тем не менее, прога живет, периодически что-то не спеша дополняется, улучшается. Что меня в первую очередь. . .
Отображение реквизитов в документе по условию и контроль их заполнения
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеСпецтехники", разработанного в конфигурации КА2. Данный документ берёт данные из другого нетипового документа. . .
Фото всей Земли с борта корабля Orion миссии Artemis II
kumehtar 04.04.2026
Это первое подобное фото сделанное человеком за 50 лет. Снимок называют новым вариантом легендарной фотографии «The Blue Marble» 1972 года, сделанной с борта корабля «Аполлон-17». Новое фото. . .
Вывод диалогового окна перед закрытием, если документ не проведён
Maks 04.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать программный контроль на предмет проведения документа. . .
Программный контроль заполнения реквизитов табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: 1. Реализовать контроль заполнения реквизита. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru