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

[B] Excel файл в базу данных и вывести в QTableWidget [/B]

10.06.2021, 19:39. Показов 2531. Ответов 1

Студворк — интернет-сервис помощи студентам
Здравствуйте люди!

PyQt5, Python.

Как можно закинуть excel файл в базу данных то-есть чтоб все данные записались в базу данных и
с базы данных уже в qtablewidget

Вот код вывода excel:

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
import sys
from PyQt5.QtWidgets import QApplication, QWidget, QTableWidget, QTableWidgetItem, QPushButton, QHeaderView, \
    QHBoxLayout, QVBoxLayout
from PyQt5.QtCore import Qt
import pandas as pd  # pip install pandas
 
 
class MyApp(QWidget):
    def __init__(self):
        super().__init__()
        self.window_width, self.window_height = 700, 500
        self.resize(self.window_width, self.window_height)
        self.setWindowTitle('Load Excel (or CSV) data to QTableWidget')
 
        layout = QVBoxLayout()
        self.setLayout(layout)
 
        self.table = QTableWidget()
        layout.addWidget(self.table)
 
        self.button = QPushButton('&Load Data')
        self.button.clicked.connect(
            lambda _, xl_path=excel_file_path, sheet_name=worksheet_name: self.loadExcelData(xl_path, sheet_name))
        layout.addWidget(self.button)
 
    def loadExcelData(self, excel_file_dir, worksheet_name):
        df = pd.read_excel(excel_file_dir, worksheet_name)
        if df.size == 0:
            return
 
        df.fillna('', inplace=True)
        self.table.setRowCount(df.shape[0])
        self.table.setColumnCount(df.shape[1])
        self.table.setHorizontalHeaderLabels(df.columns)
 
        # returns pandas array object
        for row in df.iterrows():
            values = row[1]
            for col_index, value in enumerate(values):
                if isinstance(value, (float, int)):
                    value = '{0:0,.0f}'.format(value)
                tableItem = QTableWidgetItem(str(value))
                self.table.setItem(row[0], col_index, tableItem)
 
        self.table.setColumnWidth(2, 300)
 
 
if __name__ == '__main__':
 
    excel_file_path = 'price2021.xlsx'
    worksheet_name = '07.06.'
 
    app = QApplication(sys.argv)
    app.setStyleSheet('''
        QWidget {
            font-size: 17px;
        }
    ''')
 
    myApp = MyApp()
    myApp.show()
 
    try:
        sys.exit(app.exec())
    except SystemExit:
        print('Closing Window...')
Как можно это сделать! и нет ли решения попроще?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
10.06.2021, 19:39
Ответы с готовыми решениями:

Необходимо с сайта открывать файл Excel, как базу данных
Есть проблема, не знаю, как подступиться, необходимо с сайта открывать файл Excel, как базу данных, чтобы прочитать содержимое, причём файл...

Импорт данных из Excel в базу данных SQL Server 2014
Добрый день! Мне нужно импортировать данные из Excel в базу данных SQL Server 2014, на этом форуме нашла похожую тему и попыталать...

Перенос данных из microsoft excel в какую либо базу данных
Приветствую всех! У меня собственно такой вопрос... Как из microsoft excel файла вытащить все данные для дальнейшего использования? Суть в...

1
262 / 151 / 33
Регистрация: 29.06.2019
Сообщений: 1,515
15.06.2021, 17:01
Цитата Сообщение от gravi-sid Посмотреть сообщение
чтоб все данные записались в базу данных
Цитата Сообщение от gravi-sid Посмотреть сообщение
df = pd.read_excel(excel_file_dir, worksheet_name)
см. функцию df.to_sql()

Добавлено через 43 секунды
Цитата Сообщение от gravi-sid Посмотреть сообщение
с базы данных уже в qtablewidget
см. ORM SQLAlchemy

Добавлено через 15 минут
p.s.
можно и сразу из pandas
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.06.2021, 17:01
Помогаю со студенческими работами здесь

Импорт данных из excel в базу данных MS SQL 2012 с последующим выводом в Word
Доброго времени суток, пожалуйста помогите с переносом данных из определенного документа excel в базу данных sql и последующим...

Импорт данных из excel файла в базу данных PostgreSQL
Приветствую, форумчане! Есть задание написать программу на delphi,которая импортирует данные из файла excel в БД PostgreSQL. Проблема в...

Загрузка данных из Excel в базу данных Access на VBA
Буду очень рад если кто-нибудь приведет более менее понятный код, как можно это реализовать средствами VBA

Импорт данных из Excel в Базу Данных Access
Привет всем !!! Столкнулся вот с какой задачей, нужно сделать импорт в Access из данных Excel. Там записей на 1000 где-то. И...

Добавление данных из excel в базу данных
Добрый день программисты!=) помогите решить проблему. Пишу программу у меня есть БД, и мне нужно что бы с Excel данные добавлялись к уже...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Новые блоги и статьи
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR
ФедосеевПавел 06.01.2026
Owen Logic: О недопустимости использования связки «аналоговый ПИД» + RegKZR ВВЕДЕНИЕ Введу сокращения: аналоговый ПИД — ПИД регулятор с управляющим выходом в виде числа в диапазоне от 0% до. . .
Модель микоризы: классовый агентный подход 2
anaschu 06.01.2026
репозиторий https:/ / github. com/ shumilovas/ fungi ветка по-частям. коммит Create переделка под биомассу. txt вход sc, но sm считается внутри мицелия. кстати, обьем тоже должен там считаться. . . .
Расчёт токов в цепи постоянного тока
igorrr37 05.01.2026
/ * Дана цепь постоянного тока с сопротивлениями и напряжениями. Надо найти токи в ветвях. Программа составляет систему уравнений по 1 и 2 законам Кирхгофа и решает её. Последовательность действий:. . .
Новый CodeBlocs. Версия 25.03
palva 04.01.2026
Оказывается, недавно вышла новая версия CodeBlocks за номером 25. 03. Когда-то давно я возился с только что вышедшей тогда версией 20. 03. С тех пор я давно снёс всё с компьютера и забыл. Теперь. . .
Модель микоризы: классовый агентный подход
anaschu 02.01.2026
Раньше это было два гриба и бактерия. Теперь три гриба, растение. И на уровне агентов добавится между грибами или бактериями взаимодействий. До того я пробовал подход через многомерные массивы,. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru