Найти - Пользователи
Полная версия: Python+EXCEL
Начало » Python для экспертов » Python+EXCEL
1 2
AntonSlepnev
Пытаюсь писать в текущий активный лист Excel в заданную ячейку строку посредством Thread-а. Вылетает сообщение об ошибке, которое без поллитра не поймешь..

Кто-нибудь знает, что за ошибка и как устранить?

скрипт:

import sys, time
import threading
import pythoncom
from win32com.client import Dispatch

class coterwriter(threading.Thread):
def __init__(self,i):
threading.Thread.__init__(self)
self.xlApp = Dispatch('Excel.Application')
self.xlApp.ActiveWorkbook.ActiveSheet.Cells(1,1).Value = “blablabla”
def put_mark(self,mark):
self.xlApp.ActiveWorkbook.ActiveSheet.Cells(1,1).Value = mark
def run(self):
self.put_mark(“blablabla”)

a = coterwriter(1)
a.start()
bw
Ну а что за ошибка то?

http://msdn.microsoft.com/en-us/library/aa909149.aspx

Попробуй это. Виндой давно не пользовался в таком ключе, да и вообще. Помню что раньше было необходимо вызывать указанную функцию в потоке, что бы в нем заработало COM объекты.

p.s. Естественно ищи порт в pywin32. У меня его нет и нет документации по нему.
p.p.s. Вроде это подойдет http://aspn.activestate.com/ASPN/docs/ActivePython/2.4/pywin32/pythoncom__CoInitializeEx_meth.html.

..bw
AntonSlepnev
bw
Ну а что за ошибка то?

http://msdn.microsoft.com/en-us/library/aa909149.aspx

Попробуй это. Виндой давно не пользовался в таком ключе, да и вообще. Помню что раньше было необходимо вызывать указанную функцию в потоке, что бы в нем заработало COM объекты.

p.s. Естественно ищи порт в pywin32. У меня его нет и нет документации по нему.

..bw
ошибка:
Exception in thread Thread-1:
Traceback (most recent call last):
File “C:\Python25\lib\threading.py”, line 460, in __bootstrap
self.run()
File “C:\Documents and Settings\a.slepnev-sokolinsky\Desktop\coter_writer.py”, line 14, in run
self.put_mark(“blablabla”)
File “C:\Documents and Settings\a.slepnev-sokolinsky\Desktop\coter_writer.py”, line 12, in put_mark
self.xlApp.ActiveWorkbook.ActiveSheet.Cells(1,1).Value = mark
File “C:\Python25\lib\site-packages\win32com\client\dynamic.py”, line 491, in __getattr__
raise pythoncom.com_error, details
com_error: (-2147221008, ‘\xcd\xe5 \xe1\xfb\xeb \xef\xf0\xee\xe8\xe7\xe2\xe5\xe4\xe5\xed \xe2\xfb\xe7\xee\xe2 CoInitialize.’, None, None)
bw
> com_error: (-2147221008, ‘Не был произведен вызов CoInitialize.’, None, None)
bw> Помню что раньше было необходимо вызывать указанную функцию в потоке, что бы в нем заработало COM объекты.
bw> p.p.s. Вроде это подойдет http://aspn.activestate.com/ASPN/docs/ActivePython/2.4/pywin32/pythoncom__CoInitializeEx_meth.html.

..bw
AntonSlepnev
bw
> com_error: (-2147221008, ‘Не был произведен вызов CoInitialize.’, None, None)
bw> Помню что раньше было необходимо вызывать указанную функцию в потоке, что бы в нем заработало COM объекты.
bw> p.p.s. Вроде это подойдет http://aspn.activestate.com/ASPN/docs/ActivePython/2.4/pywin32/pythoncom__CoInitializeEx_meth.html.

..bw
ссылка не работает:(
bw
Убери точку в конце ссылки :-).

..bw
AntonSlepnev
import sys, time
import threading
from win32com.client import Dispatch
import pythoncom

class coterwriter(threading.Thread):
def __init__(self,i):
pythoncom.CoInitialize()
threading.Thread.__init__(self)
self.xlApp = Dispatch('Excel.Application')
self.xlApp.ActiveWorkbook.ActiveSheet.Cells(1,1).Value = “blablabla”
def put_mark(self,mark):
self.xlApp.ActiveWorkbook.ActiveSheet.Cells(1,1).Value = mark
def run(self):
try:
self.put_mark(“blablabla”)
finally:
pythoncom.CoUninitialize()

a = coterwriter(1)
a.start()


выдает ровно ту-же ошибку
или я туплю со страшной силой
bw
Второе ;-).
    def run(self):
        pythoncom.CoInitialize()
        try:
            self.xlApp = Dispatch('Excel.Application')
            self.xlApp.ActiveWorkbook.ActiveSheet.Cells(1,1).Value = "blablabla"
            self.put_mark("blablabla")
        finally:
            pythoncom.CoUninitialize()

В потоке выполняется метод run, инициализация объекта происходит в том потоке, в котором ты его создаешь. И я в поток вынес всю работу с COM.

..bw
AntonSlepnev
it works!

Спасибо большое!

А неужели нельзя указать на COM-объект в одном месте (метод init) а использовать в другом (run)?
Если можно, как тогда играться с этими CoInitialize-ами?
spSerg
А разве CoInitialize не нужно для каждого потока в отдельности делать?
This is a "lo-fi" version of our main content. To view the full version with more information, formatting and images, please click here.
Powered by DjangoBB