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

Ошибка запуска программы после компиляции в exe файл

15.11.2022, 00:09. Показов 948. Ответов 5

Студворк — интернет-сервис помощи студентам
Здравствуйте! Возникла такая проблема: при открытии exe файла всплывает окно с ошибкой: "this application failed to start because no qt platform plugin could be initialized". Компилировал файл через команду pyinstaller —onefile —icon=name.ico —noconsole <название.py> (Всё нужное для этой команды установил). Хотелось бы запускать программу на пк без установленного Python или QT. Помогите пожалуйста!
Код самой программы прилагаю ниже:
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
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
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
class MainFuncWindow(QWidget):
 
    def __init__(self):
        super().__init__()
        self.start()
        self.set()
        self.count = 0
 
    def start(self):
        self.ui = uic.loadUi("Main_window.ui")
        self.ui.show()
        self.serial = QSerialPort()
        self.serial.setBaudRate(19200)  # Задаём скорость (Как на Arduino)
 
    def on_open(self):
        self.serial.setPortName("COM3")
        self.serial.open(QIODevice.ReadWrite)
 
    def on_close(self):
        self.serial.close()
 
    def write_serial(self, data: list):
        txs = ""
        for value in data:
            txs += str(value)
            txs += ","
        txs = txs[:-1]
        txs += ";\n"
        self.serial.write(txs.encode())
 
    def click_off(self):
        self.write_serial([2, 0, 0, 0])
 
    def click_on(self):
        self.write_serial([2, 1, 0, 0])
 
    def frequency_control_slider(self):
        self.write_serial([1, self.ui.freq_dial.value(), 0, 0])
        self.ui.spinBox.setValue(self.ui.freq_dial.value())
 
    def frequency_control_spinbox(self):
        self.write_serial([1, self.ui.spinBox.value(), 0, 0])
        self.ui.freq_dial.setValue(self.ui.spinBox.value())
 
    def rgb_control(self):
        self.write_serial([0, self.ui.red_slider.value(), self.ui.green_slider.value(), self.ui.blue_slider.value()])
        self.ui.spinBox_red.setValue(self.ui.red_slider.value())
        self.ui.spinBox_green.setValue(self.ui.green_slider.value())
        self.ui.spinBox_blue.setValue(self.ui.blue_slider.value())
 
    def rgb_control_spinbox_red(self):
        self.write_serial([0, self.ui.spinBox_red.value(), self.ui.spinBox_green.value(), self.ui.spinBox_blue.value()])
        self.ui.red_slider.setValue(self.ui.spinBox_red.value())
 
    def rgb_control_spinbox_green(self):
        self.write_serial([0, self.ui.spinBox_red.value(), self.ui.spinBox_green.value(), self.ui.spinBox_blue.value()])
        self.ui.green_slider.setValue(self.ui.spinBox_green.value())
 
    def rgb_control_spinbox_blue(self):
        self.write_serial([0, self.ui.spinBox_red.value(), self.ui.spinBox_green.value(), self.ui.spinBox_blue.value()])
        self.ui.blue_slider.setValue(self.ui.spinBox_blue.value())
 
    def back_start_win(self):
        start_w = StartWindow()
        widget.addWidget(start_w)
        widget.setCurrentIndex(widget.currentIndex() - 1)
        self.ui.close()
 
    def set_count(self):
        self.count += 1
        self.making_points()
        if 7 - self.count == 0:
            self.ui.point_label.setText("Всё!")
        elif 7 - self.count == 1:
            self.ui.point_label.setText("Последняя точка!")
        else:
            self.ui.point_label.setText("Осталось точек:" + str(7 - self.count))
 
    def making_points(self):
        try:
            db = sqlite3.connect("database.db")
            cursor = db.cursor()
            if self.count <= 7:
                values = f"{self.ui.spinBox_red.value()} {self.ui.spinBox_green.value()}" \
                         f" {self.ui.spinBox_blue.value()} {self.ui.spinBox.value()}"
 
                if self.count == 1:
                    cursor.execute("UPDATE users SET color_and_freq1 = ? WHERE flag = ?", [values, 1])
                    db.commit()
                elif self.count == 2:
                    cursor.execute("UPDATE users SET color_and_freq2 = ? WHERE flag = ?", [values, 1])
                    db.commit()
                elif self.count == 3:
                    cursor.execute("UPDATE users SET color_and_freq3 = ? WHERE flag = ?", [values, 1])
                    db.commit()
                elif self.count == 4:
                    cursor.execute("UPDATE users SET color_and_freq4 = ? WHERE flag = ?", [values, 1])
                    db.commit()
                elif self.count == 5:
                    cursor.execute("UPDATE users SET color_and_freq5 = ? WHERE flag = ?", [values, 1])
                    db.commit()
                elif self.count == 6:
                    cursor.execute("UPDATE users SET color_and_freq6 = ? WHERE flag = ?", [values, 1])
                    db.commit()
                elif self.count == 7:
                    cursor.execute("UPDATE users SET color_and_freq7 = ? WHERE flag = ?", [values, 1])
                    db.commit()
 
        except sqlite3.Error as err:
            print("Error: ", err)
        finally:
            cursor.close()
            db.close()
 
    def making_graph(self):
        try:
            db = sqlite3.connect("database.db")
            cursor = db.cursor()
            x1 = cursor.execute("SELECT color_and_freq1 FROM users WHERE flag = ?", [1]).fetchone()
            x2 = cursor.execute("SELECT color_and_freq2 FROM users WHERE flag = ?", [1]).fetchone()
            x3 = cursor.execute("SELECT color_and_freq3 FROM users WHERE flag = ?", [1]).fetchone()
            x4 = cursor.execute("SELECT color_and_freq4 FROM users WHERE flag = ?", [1]).fetchone()
            x5 = cursor.execute("SELECT color_and_freq5 FROM users WHERE flag = ?", [1]).fetchone()
            x6 = cursor.execute("SELECT color_and_freq6 FROM users WHERE flag = ?", [1]).fetchone()
            x7 = cursor.execute("SELECT color_and_freq7 FROM users WHERE flag = ?", [1]).fetchone()
            data_values = [int(x1[0].split()[3]), int(x2[0].split()[3]), int(x3[0].split()[3]), int(x4[0].split()[3]),
                           int(x5[0].split()[3]), int(x6[0].split()[3]), int(x7[0].split()[3])]
            xs = range(len(data_values))
 
            y1 = cursor.execute("SELECT color_and_freq1 FROM users WHERE flag = ?", [1]).fetchone()
            y2 = cursor.execute("SELECT color_and_freq2 FROM users WHERE flag = ?", [1]).fetchone()
            y3 = cursor.execute("SELECT color_and_freq3 FROM users WHERE flag = ?", [1]).fetchone()
            y4 = cursor.execute("SELECT color_and_freq4 FROM users WHERE flag = ?", [1]).fetchone()
            y5 = cursor.execute("SELECT color_and_freq5 FROM users WHERE flag = ?", [1]).fetchone()
            y6 = cursor.execute("SELECT color_and_freq6 FROM users WHERE flag = ?", [1]).fetchone()
            y7 = cursor.execute("SELECT color_and_freq7 FROM users WHERE flag = ?", [1]).fetchone()
            data_names = [y1[0].split()[:3], y2[0].split()[:3], y3[0].split()[:3], y4[0].split()[:3], y5[0].split()[:3],
                          y6[0].split()[:3], y7[0].split()[:3]]
            fig = plt.figure()
            ax = plt.axes()
            ax.yaxis.grid(True, zorder=1)
            plt.bar([x + 0.05 for x in xs], data_values)
            plt.xticks(xs, data_names)
            canvas = FigureCanvas(fig)
            canvas.draw()
            self.ui.horizontalLayout_6.addWidget(canvas)
        except sqlite3.Error as err:
            print("Error: ", err)
        finally:
            cursor.close()
            db.close()
 
    def set(self):
        self.ui.open_port_but.clicked.connect(self.on_open)
        self.ui.close_port_but.clicked.connect(self.on_close)
        self.ui.freq_dial.valueChanged.connect(self.frequency_control_slider)
        self.ui.spinBox.valueChanged.connect(self.frequency_control_spinbox)
        self.ui.red_slider.valueChanged.connect(self.rgb_control)
        self.ui.green_slider.valueChanged.connect(self.rgb_control)
        self.ui.blue_slider.valueChanged.connect(self.rgb_control)
        self.ui.spinBox_red.valueChanged.connect(self.rgb_control_spinbox_red)
        self.ui.spinBox_green.valueChanged.connect(self.rgb_control_spinbox_green)
        self.ui.spinBox_blue.valueChanged.connect(self.rgb_control_spinbox_blue)
        self.ui.on_b.clicked.connect(self.click_on)
        self.ui.off_b.clicked.connect(self.click_off)
        self.ui.fix_point_button.clicked.connect(self.set_count)
        self.ui.save_button.clicked.connect(self.making_graph)
        self.ui.escape_but.clicked.connect(self.back_start_win)
 
 
class StartWindow(QWidget):
    def __init__(self):
        super().__init__()
        self.start_sw()
        self.set_sw()
 
    def start_sw(self):
        self.ui_sw = uic.loadUi("Start_window.ui")
        self.ui_sw.show()
 
    def open_main_func_win(self):
        main_func_win = MainFuncWindow()
        # noinspection PyTypeChecker
        widget.addWidget(main_func_win)
        widget.setCurrentIndex(widget.currentIndex() + 1)
        self.ui_sw.close()
 
    def open_file_cabinet(self):
        file_cab = FileCabinetWindow()
        widget.addWidget(file_cab)
        widget.setCurrentIndex(widget.currentIndex() + 2)
        self.ui_sw.close()
 
    def set_sw(self):
        self.ui_sw.start_but.clicked.connect(self.open_main_func_win)
        self.ui_sw.Cabin_but.clicked.connect(self.open_file_cabinet)
 
 
if __name__ == "__main__":
    app = QApplication(sys.argv)
    ex = StartWindow()
    widget = QStackedWidget()
    widget.addWidget(ex)
    widget.setFixedWidth(400)
    widget.setFixedHeight(300)
    app.exec()
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.11.2022, 00:09
Ответы с готовыми решениями:

После компиляции программы Kivy на Python не запускается exe файл
Скомпилировал прогу через PyInstaller. spec файл прикреплен, точне его код. Помогите, очень нужно... Вот spec файл # -*- mode: python ;...

После компиляции проекта exe файл весит 14 755 кб. Это слишком много для программы с 3 функциями
Меня смущает, что после компиляции проекта exe файл весит 14 755 кб. Это слишком много для программы с 3 функциями. Как можно уменьшить вес...

Ошибка при попытке компиляции и последующего запуска программы
Доброго времени суток! Недавно появился один глюк, который очень сильно напрягает и который я уже длительное время не могу решить. При...

5
Эксперт PythonЭксперт Java
19530 / 11067 / 2931
Регистрация: 21.10.2017
Сообщений: 23,294
15.11.2022, 08:53
Цитата Сообщение от s1f0n4ik Посмотреть сообщение
Хотелось бы запускать программу на пк без установленного Python или QT.
Пиши на С++ и собирай статически.

Не по теме:

Когда ж вы поймете, что пиинсталлер - это извращение?

0
0 / 0 / 0
Регистрация: 19.12.2020
Сообщений: 14
15.11.2022, 10:54  [ТС]
Великолепный конечно совет, а главное информативный! Сейчас быстренько за вечер выучу С++, и будет всё в шоколаде!
0
 Аватар для kapbepucm
1566 / 739 / 321
Регистрация: 02.05.2020
Сообщений: 1,656
15.11.2022, 11:44
Такая ошибка указывает нанередкую проблему в C++ Qt, когда уже скомпилированный *.exe не может запустится, потомучто не находит одну или несколько *.dll по стандатным путям (лечится переназначением путей или добавлением куда надо нужных *.dll). Как это дело компонует pyinstaller вопрос ещё тот.
Приведённый вами код скорее всего не вызывает эту ошибку, проблема гдето глубже, так что великолепный совет в каком то смысле таки имеет место быть
1
Эксперт Python
1356 / 653 / 207
Регистрация: 23.03.2014
Сообщений: 3,057
15.11.2022, 12:03
s1f0n4ik, так все ж понятно написано не хватает библиотек QT? причем, чтоб программа заработала, прийдется к ней добавить очень много сторонних библиотек.
Рекомендую ознакомиться:Как добавить что-либо из QT
1
290 / 205 / 68
Регистрация: 18.09.2019
Сообщений: 407
Записей в блоге: 58
15.11.2022, 12:45
s1f0n4ik, наверное, для начала не мешало бы проверить, а собирается ли в вашем операционном окружении хоть что-нибудь самое элементарное в работоспособный exe, например, такое:
Python
1
2
3
4
5
6
7
8
import sys
from PyQt5.QtWidgets import QApplication, QMainWindow
 
if __name__ == "__main__":
    app = QApplication(sys.argv)
    mwin = QMainWindow()
    mwin,show()
    app.exec()
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.11.2022, 12:45
Помогаю со студенческими работами здесь

В IDE Geany после компиляции и запуска возникает ошибка
см. рисунок помогите исправить ошибку

После компиляции и запуска программы в java вместо русских букв выдаёт странные знаки
После компиляции и запуска программы в java вместо русских букв выдаёт странные знаки. Я начинающий

EXE файл завершает работу сразу после запуска
Привет всем, столкнулся с следующей проблемой Написал небольшую програмку на паскале. Чтобы запустить турбо паскаль на 7-ке пришлось...

Python3 ошибка после компиляции .py в .exe
Всем привет, написал программу, она создает и декодирует qrcode, все это на граф интерфейса благодаря tkinter. Программа работает в формате...

Ошибка в .exe после компиляции pyinstaller
На pyton 3.4 установил pyside, чтобы на qt designer сделать прогу с интерфейсом. Все готово, .py программа запускается, все работает, но...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): сборка C/C++ проекта из консоли
8Observer8 30.01.2026
Содержание блога Если вы откроете примеры для начинающих на официальном репозитории SDL3 в папке: examples, то вы увидите, что все примеры используют следующие четыре обязательные функции, а. . .
Установка Emscripten SDK (emsdk) и CMake на Windows для сборки C и C++ приложений в WebAssembly (Wasm)
8Observer8 30.01.2026
Чтобы скачать Emscripten SDK (emsdk) необходимо сначало скачать и уставить Git: Install for Windows. Следуйте стандартной процедуре установки Git через установщик. Система контроля версиями Git. . .
Подключение Box2D v3 к SDL3 для Android: физика и отрисовка коллайдеров
8Observer8 29.01.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами. Версия v3 была полностью переписана на Си, в. . .
Инструменты COM: Сохранение данный из VARIANT в файл и загрузка из файла в VARIANT
bedvit 28.01.2026
Сохранение базовых типов COM и массивов (одномерных или двухмерных) любой вложенности (деревья) в файл, с возможностью выбора алгоритмов сжатия и шифрования. Часть библиотеки BedvitCOM Использованы. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 28.01.2026
Содержание блога SDL3 имеет собственные средства для загрузки и отображения PNG-файлов с альфа-каналом и базовой работы с ними. В этой инструкции используется функция SDL_LoadPNG(), которая. . .
Загрузка PNG с альфа-каналом на SDL3 для Android: с помощью SDL3_image
8Observer8 27.01.2026
Содержание блога SDL3_image - это библиотека для загрузки и работы с изображениями. Эта пошаговая инструкция покажет, как загрузить и вывести на экран смартфона картинку с альфа-каналом, то есть с. . .
Влияние грибов на сукцессию
anaschu 26.01.2026
Бифуркационные изменения массы гриба происходят тогда, когда мы уменьшаем массу компоста в 10 раз, а скорость прироста биомассы уменьшаем в три раза. Скорость прироста биомассы может уменьшаться за. . .
Воспроизведение звукового файла с помощью SDL3_mixer при касании экрана Android
8Observer8 26.01.2026
Содержание блога SDL3_mixer - это библиотека я для воспроизведения аудио. В отличие от инструкции по добавлению текста код по проигрыванию звука уже содержится в шаблоне примера. Нужно только. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru