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

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

08.11.2023, 19:14. Показов 797. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Настройки VS Code
Loafer 13.04.2026
{ "cmake. configureOnOpen": false, "diffEditor. ignoreTrimWhitespace": true, "editor. guides. bracketPairs": "active", "extensions. ignoreRecommendations": true, . . .
Оптимизация кода на разграничение прав доступа к элементам формы
Maks 13.04.2026
Алгоритм из решения ниже реализован на нетиповом документе, разработанного в конфигурации КА2. Задачи, как таковой, поставлено не было, проделанное ниже исключительно моя инициатива. Было так:. . .
Контроль заполнения и очистка дат в зависимости от значения перечислений
Maks 12.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: реализовать контроль корректности заполнения дат назначения. . .
Архитектура слоя интернета для сервера-слоя.
Hrethgir 11.04.2026
В продолжение https:/ / www. cyberforum. ru/ blogs/ 223907/ 10860. html Знаешь что я подумал? Раз мы все источники пишем в голове ветки, то ничего не мешает добавить в голову такой источник, который сам. . .
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru