Python pywin32 и Python Snap7 соединяются вместе, но не имеют проблем с модулем с именем snap7

Я создаю службу Windows, которая работает на локальном компьютере. Работает хорошо, пока я не объединю две библиотекиpywin32 а также snap7, появится сообщение "Нет модуля с именем snap7".

Но если у меня есть только одна библиотека pywin32 или snap7, которая хорошо работает в моей системе, я использую Windows 7. Я пытаюсь переместить snap7 dll и snap7 lib в папку pywin32, но все равно не работает.

Вопрос, а можно ли запускать эти библиотеки? Что не так с кодом или я должен переместить файл dll?

Код

import win32serviceutil
import servicemanager
import win32service
import win32event
import logging
import snap7 # if include, I got error


class MyWindowsService(win32serviceutil.ServiceFramework):
    _svc_name_          = 'AITM'
    _svc_display_name_  = 'AITM'
    _svc_description_   = 'Service Full Description'
    logging.basicConfig(
        filename    = 'c:\\Temp\\{}.log'.format(_svc_name_),
        level       = logging.DEBUG,
        format      = '%(levelname)-7.7s @ %(asctime)s: %(message)s'
    )

    @classmethod
    def parse_command_line(cls):
        '''
        ClassMethod to parse the command line
        '''
        win32serviceutil.HandleCommandLine(cls)

    def __init__(self, *args):
        self.log('Initializing service {}'.format(self._svc_name_))
        win32serviceutil.ServiceFramework.__init__(self, *args)
        self.stop_event = win32event.CreateEvent(None, 0, 0, None)

    def SvcDoRun(self):
        self.ReportServiceStatus(win32service.SERVICE_START_PENDING)
        try:
            self.log('START: Service start')
            self.ReportServiceStatus(win32service.SERVICE_RUNNING)
            self.start()
            win32event.WaitForSingleObject(self.stop_event, win32event.INFINITE)
        except Exception as e:
            self.log('Exception: {}'.format(e))
            self.SvcStop()

    def SvcStop(self):
        self.log('STOP: Service stopping...')
        self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)
        self.stop()
        win32event.SetEvent(self.stop_event)
        self.ReportServiceStatus(win32service.SERVICE_STOPPED)

    def log(self, msg):
        servicemanager.LogInfoMsg(str(msg))  #system log
        logging.info(str(msg))               #text log

    def start(self):
        pass

    def stop(self):
        self.runflag = False
        self.log('Stop received')


if __name__ == '__main__':
    MyWindowsService.parse_command_line()

0 ответов

Другие вопросы по тегам