anatoly1712
Апрель 17, 2015 14:16:11
1. Создал контейнер
Workbook = QAxContainer.QAxWidget(…)
2. Установил в нем excel.workbook контролл
Workbook.setControl(…)
При этом как фоновый процесс(Com server) запустился EXCEL.EXE
и он не завершается после выхода из Python QT приложения
? как выгрузить связанный EXCEL.EXE
anatoly1712
Апрель 21, 2015 09:53:11
ау python-гуру
PooH
Апрель 21, 2015 10:23:28
Попробуйте Workbook = None
anatoly1712
Апрель 21, 2015 11:39:59
Workbook.Close Workbook= None
не помогает
PooH
Апрель 21, 2015 11:47:14
Остается где-то ссылка на COM-объект. Если кинете минимальный пример воспроизводящий проблему, то покопаю
anatoly1712
Апрель 21, 2015 12:06:35
Завтра скину(если вы не против).Сейчас занят другим
anatoly1712
Апрель 22, 2015 09:49:39
# coding=utf-8
import sys
from PyQt4 import QtGui,QtCore, uic
import datetime,time
class TestForm(QtGui.QMainWindow):
def __init__(self, parent=None):
# Запускаем родительский конструктор
super(TestForm, self).__init__(parent)
# Загружаем форму “на лету”
self.ui = uic.loadUi(“mainwindow.ui”,self)
self.ui.axWidget.setControl(“{00020820-0000-0000-C000-000000000046}”)
def closeEvent(self, event):
reply = QtGui.QMessageBox.question(self, ‘Message’,
“Желаете завершить работу ?”, QtGui.QMessageBox.Yes, QtGui.QMessageBox.No)
if reply == QtGui.QMessageBox.Yes:
self.ui.axWidget.dynamicCall('Close(bool)',False)
self.ui.axWidget.dynamicCall('Close()')
self.ui.axWidget = None
event.accept()
else:
event.ignore()
if __name__ == “__main__”:
###QtGui.QApplication.setStyle(QtGui.QStyleFactory.create('CDE'))
app = QtGui.QApplication(sys.argv)
myapp = TestForm()
myapp.show()
sys.exit(app.exec_())
PooH
Апрель 22, 2015 17:20:05
Срочно в командировку уезжаю, посмотрю не раньше понедельника
anatoly1712
Апрель 22, 2015 17:36:20
подожду
PooH
Апрель 27, 2015 14:48:33
Почему не закрывается я вроде понял, но до работающего кода пока не дошел, слишком уж давно с этим не работал. Насколько я понимаю, когда вы создаете 00020820-0000-0000-C000-000000000046 - это Worksheet в екселе, автоматом создаются Worbook и Application. Надо видимо до них добраться и закрыть.