Форум сайта python.su
1. Создал контейнер
Workbook = QAxContainer.QAxWidget(…)
2. Установил в нем excel.workbook контролл
Workbook.setControl(…)
При этом как фоновый процесс(Com server) запустился EXCEL.EXE
и он не завершается после выхода из Python QT приложения
? как выгрузить связанный EXCEL.EXE
Офлайн
ау python-гуру
Офлайн
Попробуйте Workbook = None
Отредактировано PooH (Апрель 21, 2015 10:23:41)
Офлайн
Workbook.Close Workbook= None
не помогает
Офлайн
Остается где-то ссылка на COM-объект. Если кинете минимальный пример воспроизводящий проблему, то покопаю
Офлайн
Завтра скину(если вы не против).Сейчас занят другим
Офлайн
# 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_())
Прикреплённый файлы:
mainwindow.ui (4,3 KБ)
Офлайн
Срочно в командировку уезжаю, посмотрю не раньше понедельника
Офлайн
подожду
Офлайн
Почему не закрывается я вроде понял, но до работающего кода пока не дошел, слишком уж давно с этим не работал. Насколько я понимаю, когда вы создаете 00020820-0000-0000-C000-000000000046 - это Worksheet в екселе, автоматом создаются Worbook и Application. Надо видимо до них добраться и закрыть.
Офлайн