Evgenii Legotckoi
Evgenii Legotckoi09 листопада 2019 р. 05:52

PyQt5 - Урок 008. Робота з QTableWidget (Оновлення уроку 006)

Це буде невелике оновлення уроку з використання QTableWidget в PyQt5

В попередньому уроці було показано, як вивести якусь инофрмацию в QTableWidget. А в цьому уроці буде показано також, як зробити деякі осередки редагованими і Нередагована, а також як реагувати на натискання клавіш всередині QTableWidget

Додаток буде виглядати наступним чином


Вступ

Дане доповнення зроблено на прохання одного ізпользователей. Зокрема додавання відстеження клавіш і настройка редагування осередків.

Також було прохання показати, як зробити сортування по колонці. Але цього я робити не став. Справа в тому, що QTableWidget служить в першу чергу для відображення віджетів у вигляді таблиці, а не для табличних даних. Тому настійно рекомендую всім, хто цього потребує відобразити таблицю текстових даних, використовуйте QTableView і вивчайте, як зробити модель даних за допомогою QAbstractItemModel . Там простіше зробити сортування, з помоьщю проксі моделей, і вони для цього краще підходять.

А тепер повернемося до прикладу.

widgets.py

Спочатку потрібно створити кастомний QTableWidget

from PyQt5.QtCore import Qt
from PyQt5.QtGui import QKeyEvent
from PyQt5.QtWidgets import QTableWidget


# Ми створюємо власний QTableWidget для реагування на події натискання клавіш
class CustomTableWidget(QTableWidget):

    # переобумовленої keyPressEvent
    def keyPressEvent(self, e: QKeyEvent) -> None:
        if e.key() == Qt.Key_Enter:
            print("Key enter was pressed")
        elif e.key() == Qt.Key_Return:
            print("Key return was pressed")

init .py

А далі будемо створювати вікно додатка

from PyQt5.QtCore import QSize, Qt
from PyQt5.QtWidgets import QApplication, QMainWindow, QGridLayout, QWidget, QTableWidgetItem

from widgets import CustomTableWidget


# Спадкування від QMainWindow
class MainWindow(QMainWindow):
    # Overriding the class constructor
    def __init__(self):
        # Обов'язково викличте метод суперкласу
        QMainWindow.__init__(self)

        self.setMinimumSize(QSize(480, 80))  # встановити розміри
        self.setWindowTitle("Работа с QTableWidget")  # Встановіть заголовок вікна
        central_widget = QWidget(self)  # Створити центральний віджет
        self.setCentralWidget(central_widget)  # Встановити центральний віджет

        grid_layout = QGridLayout()  # створити QGridLayout
        central_widget.setLayout(grid_layout)  # Встановіть це розміщення в центральному віджеті

        table = CustomTableWidget(self)  # створити таблицю
        table.setColumnCount(3)  # Ми встановлюємо три колони
        table.setRowCount(1)  # і один ряд в таблиці

        # Встановити заголовки таблиці
        table.setHorizontalHeaderLabels(["Header 1", "Header 2", "Header 3"])

        # Встановити підказки для заголовків
        table.horizontalHeaderItem(0).setToolTip("Column 1 ")
        table.horizontalHeaderItem(1).setToolTip("Column 2 ")
        table.horizontalHeaderItem(2).setToolTip("Column 3 ")

        # Встановіть вирівнювання до заголовків
        table.horizontalHeaderItem(0).setTextAlignment(Qt.AlignLeft)
        table.horizontalHeaderItem(1).setTextAlignment(Qt.AlignHCenter)
        table.horizontalHeaderItem(2).setTextAlignment(Qt.AlignRight)

        # заповніть перший рядок
        table.setItem(0, 0, self.createItem("Text in column 1", Qt.ItemIsSelectable | Qt.ItemIsEnabled))
        table.setItem(0, 1, self.createItem("Text in column 2", Qt.ItemIsSelectable | Qt.ItemIsEnabled | Qt.ItemIsEditable))
        table.setItem(0, 2, self.createItem("Text in column 3", Qt.ItemIsSelectable | Qt.ItemIsEnabled | Qt.ItemIsEditable))

        # змінити розмір стовпця за вмістом
        table.resizeColumnsToContents()

        grid_layout.addWidget(table, 0, 0)  # Add a table to the grid

    def createItem(self, text, flags):
        tableWidgetItem = QTableWidgetItem(text)
        tableWidgetItem.setFlags(flags)
        return tableWidgetItem


if __name__ == "__main__":
    import sys

    app = QApplication(sys.argv)
    mw = MainWindow()
    mw.show()
    sys.exit(app.exec())

Висновок

Код даного проекту ви знайдете в репозиторії прикладів. Не забудьте поставити зірочку сховища.

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

b
  • 09 листопада 2019 р. 08:28

спасибо ещё раз. огромное, за уделённое время

C
  • 13 травня 2020 р. 16:28

Добрый день.

Спасибо за статью, очень помогла. По есть вопрос:
А как быть, если значения для 1 столбца нужно брать из словаря?
При таком коде:
for i,entry in enumerate(commands):
ui.tableWidget.setRowCount(i+1)
ui.tableWidget.setItem(0, i, commands)
получаю ошибку:
argument 3 has unexpected type 'dict'

b
  • 13 травня 2020 р. 16:34
  • (відредаговано)

ну setRowCount это не совсем корректно в данном случае, лучше использовать insertRow. Второе, в setItem третий аргумент должен быть типа QTableWidgetItem То есть строка должна выглядеть ui.tableWidget.setItem(0,i, QTableWidgetItem(commands))
Если не прав, админ поправит)

Коментарі

Only authorized users can post comments.
Please, Log in or Sign up
Ua

Qt - Тест 001. Сигналы и слоты

  • Результат:84бали,
  • Рейтинг балів4
Ua

Qt - Тест 001. Сигналы и слоты

  • Результат:42бали,
  • Рейтинг балів-8
ОК

Qt - Тест 001. Сигналы и слоты

  • Результат:47бали,
  • Рейтинг балів-6
Останні коментарі
ИМ
Игорь Максимов22 листопада 2024 р. 22:51
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Evgenii Legotckoi
Evgenii Legotckoi01 листопада 2024 р. 00:37
Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
A
ALO1ZE19 жовтня 2024 р. 18:19
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Игорь Максимов05 жовтня 2024 р. 17:51
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
d
dblas505 липня 2024 р. 21:02
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
n
nkly03 січня 2025 р. 13:52
Нужно запретить перемещение только некоторых итемов, остальные перемещать можно. Вопрос решен. Узнать QModelIndex элемента на который мы перетаскиваем другой элемент, можно с помощью функции indexAt(event->position().toPoint()) представления QTreeViev вызываемой в переопр…
M
Marsel17 серпня 2023 р. 00:26
OAuth2.0 через VK, получение email Спасибо большое за помощь и простите за то что отнял время своей невнимательностью.
Evgenii Legotckoi
Evgenii Legotckoi25 червня 2024 р. 01:11
добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
t
tonypeachey115 листопада 2024 р. 17:04
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
NSProject
NSProject04 червня 2022 р. 13:49
Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…

Слідкуйте за нами в соціальних мережах