Форум программистов, компьютерный форум, киберфорум
Python: Базы данных
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 29.09.2023
Сообщений: 1

Добавление слов в базу данных и вывод их в таблицу PyQt5

08.11.2023, 19:14. Показов 731. Ответов 0

Студворк — интернет-сервис помощи студентам
Нужно создать таблицу выученных слов. С помощью PyQt5 вводятся новые слова, они записываются в базу данных и выводятся в таблицу QTableWidget. Я пытался это сделать, но не, помогите пожалуйста
Код:
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
class Learnt_words(QWidget):
    def __init__(self):
        super().__init__()
        uic.loadUi('project//ui/learnt_words.ui', self)
 
        self.tableWidget.setColumnWidth(0, 231)
        self.tableWidget.setColumnWidth(1, 231)
        
        self.add_but.clicked.connect(self.add_row)
        self.setFixedSize(800, 600)
 
        self.home_but.clicked.connect(self.home)
        
    def loaddata(self): 
        con = sqlite3.connect('learnt_words.db')
        cur = con.cursor()
        words = cur.execute('''SELECT * FROM words''')
        translates = cur.execute('''SELECT * FROM translates''')
        
        row = 0
        self.tableWidget.setRowCount(len(words))
        for word in words:
            self.tableWidget.setItem(row, 0, QTableWidgetItem(word["word"]))
            for j in translates:
                self.tableWidget.setItem(row, 1, QTableWidgetItem(word["translate"]))
            row += 1
 
    def add_row(self):
        
        new_word, ok_pressed = QInputDialog.getText(self, 'Введите слово',
                                             'Какое слово вы выучили?')
        
        if ok_pressed:
            new_word_translate, ok_pressed = QInputDialog.getText(self, 'Введите слово', 'Как переводится это слово?')
 
        con = sqlite3.connect('learnt_words.db')
        cur = con.cursor()
        cur.execute(f"INSERT INTO words (word) VALUES ({new_word})")
        cur.execute(f"INSERT INTO translates (translate) VALUES ({new_word_translate})")
        con.close()
        self.loaddata()
XML
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
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
<?xml version="1.0" encoding="UTF-8"?>
<ui version="4.0">
 <class>Form</class>
 <widget class="QWidget" name="Form">
  <property name="geometry">
   <rect>
    <x>0</x>
    <y>0</y>
    <width>800</width>
    <height>600</height>
   </rect>
  </property>
  <property name="windowTitle">
   <string>Form</string>
  </property>
  <property name="styleSheet">
   <string notr="true">background-color: rgb(174, 198, 112)</string>
  </property>
  <widget class="QWidget" name="horizontalLayoutWidget">
   <property name="geometry">
    <rect>
     <x>30</x>
     <y>40</y>
     <width>721</width>
     <height>511</height>
    </rect>
   </property>
   <layout class="QHBoxLayout" name="horizontalLayout">
    <item>
     <layout class="QVBoxLayout" name="verticalLayout_3">
      <item>
       <widget class="QPushButton" name="home_but">
        <property name="sizePolicy">
         <sizepolicy hsizetype="Maximum" vsizetype="Fixed">
          <horstretch>0</horstretch>
          <verstretch>0</verstretch>
         </sizepolicy>
        </property>
        <property name="styleSheet">
         <string notr="true">background: rgb(26, 41, 2);
color: white;
border-radius: 5px;
padding: 4px</string>
        </property>
        <property name="text">
         <string>На главный экран</string>
        </property>
       </widget>
      </item>
      <item>
       <spacer name="verticalSpacer_2">
        <property name="orientation">
         <enum>Qt::Vertical</enum>
        </property>
        <property name="sizeHint" stdset="0">
         <size>
          <width>20</width>
          <height>40</height>
         </size>
        </property>
       </spacer>
      </item>
     </layout>
    </item>
    <item>
     <layout class="QVBoxLayout" name="verticalLayout">
      <item>
       <widget class="QTableWidget" name="tableWidget">
        <property name="sizePolicy">
         <sizepolicy hsizetype="Expanding" vsizetype="Expanding">
          <horstretch>0</horstretch>
          <verstretch>0</verstretch>
         </sizepolicy>
        </property>
        <property name="styleSheet">
         <string notr="true">background-color: #778D45
</string>
        </property>
        <property name="gridStyle">
         <enum>Qt::SolidLine</enum>
        </property>
        <row>
         <property name="text">
          <string>1</string>
         </property>
        </row>
        <column>
         <property name="text">
          <string>Слово</string>
         </property>
        </column>
        <column>
         <property name="text">
          <string>Перевод</string>
         </property>
        </column>
       </widget>
      </item>
     </layout>
    </item>
    <item>
     <layout class="QVBoxLayout" name="verticalLayout_2">
      <item>
       <widget class="QPushButton" name="add_but">
        <property name="styleSheet">
         <string notr="true">background: rgb(26, 41, 2);
color: white;
border-radius: 5px;
padding: 4px</string>
        </property>
        <property name="text">
         <string>Добавить слово</string>
        </property>
       </widget>
      </item>
      <item>
       <spacer name="verticalSpacer">
        <property name="orientation">
         <enum>Qt::Vertical</enum>
        </property>
        <property name="sizeHint" stdset="0">
         <size>
          <width>20</width>
          <height>40</height>
         </size>
        </property>
       </spacer>
      </item>
     </layout>
    </item>
   </layout>
  </widget>
 </widget>
 <resources/>
 <connections/>
</ui>
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
08.11.2023, 19:14
Ответы с готовыми решениями:

PyQT5 TableWidget добавление данных в Базу данных при нажатии на кнопку
Здравствуйте. У меня есть Таблица в приложение (QTableWidget). База данных postgreSQL, python Я сделал чтоб при выборе (нажатии)...

Добавление записей в таблицу (Базу Данных)
Здравствуйте, так уж вышло, что я полный новичок в этой СУБД, скачал только вчера и возник вопрос. Он заключается в следующем, нужно...

Добавление колонки в базу данных и таблицу
У меня есть база данных созданная в Access, её я подключил через источник данных к проекту в Visual Studio. Хочу по нажатию на батон...

0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
08.11.2023, 19:14
Помогаю со студенческими работами здесь

PyQt5 не выгружает базу данных
PyQt5 не выгружает базу данных. Имя, пароль и тд намеренно убрал. Подскажите, почему база данных не выгружается? Код: import sys ...

Добавление записей из базу данных Access в базу данных SQL
Здравствуйте,пытаюсь добавить записи из базы данных Access в базу данных SQL,но не могу разобраться с подключениями,может ли кто подсказать...

Загрузка файла на сервер, добавление в базу данных ссылки и вывод ссылки из базы
Добрый вечер. Изучаю php, появился вопрос, а решить уже дня 3 не могу своими силами, поэтому прошу помощи. Есть форма, в которой вносятся...

Вывод данных из файла excel в GUI pyqt5
Добрый день. Есть готовая гуи &quot;собранная&quot; с помощью pyqt. Есть файлик ексель где забиты дата в первый столбец и запись во второй. ...

Выбор данных из полей со списком, занесение этих данных в список и добавление данных в таблицу
Подскажите пожалуйста, как что то подобное сделать в Access или посоветуйте хорошую литературу где это описывается.


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
Новые блоги и статьи
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Access
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru