python windows服务_写一个Python的windows服务

# -*- coding: utf-8 -*-

import sys

import win32event

import win32service

import win32serviceutil

import servicemanager

import subprocess

import logging

import inspect

import os

class ScreenRecorderService(win32serviceutil.ServiceFramework):

_svc_name_ = "ScreenRecorderService"

_svc_display_name_ = "Screen Recorder Service"

_svc_description_ = "Screen Recorder Service"

_svc_data_dir = 'D:\\ScreenRecorder'

_ffmpeg_proc = None

def __init__(self, args):

win32serviceutil.ServiceFramework.__init__(self, args)

self.stop_event = win32event.CreateEvent(None, 0, 0, None)

self.logger = self._getLogger()

def _getLogger(self):

logger = logging.getLogger('[ScreenRecorderService]')

this_file = inspect.getfile(inspect.currentframe())

dirpath = os.path.abspath(os.path.dirname(this_file))

handler = logging.FileHandler(os.path.join(dirpath, self._svc_name_ + ".log"))

formatter = logging.Formatter('%(asctime)s %(name)-12s %(levelname)-8s %(message)s')

handler.setFormatter(formatter)

logger.addHandler(handler)

logger.setLevel(logging.INFO)

return logger

def SvcDoRun(self):

self.ReportServiceStatus(win32service.SERVICE_START_PENDING)

try:

self.ReportServiceStatus(win32service.SERVICE_RUNNING)

self.logger.info('Screen Recorder Service is Starting ...')

self.start()

self.logger.info('Screen Recorder Service Started')

import time

time.sleep(3)

self.logger.info('Screen Recorder Service ffmpeg run')

ffmpeg = r'C:\Windows\System32\ffmpeg.exe'

cmd = r'%s -f gdigrab -framerate 10 -i desktop D:\\output.mkv -y' % ffmpeg

self.logger.info(cmd)

self._ffmpeg_proc = subprocess.Popen(cmd, shell=True)

try:

sys.exit(self._ffmpeg_proc.wait())

except SystemExit as e:

self.logger.warn('Exception : %s' % e)

self.logger.info('Screen Recorder Service ffmpeg stop')

win32event.WaitForSingleObject(self.stop_event, win32event.INFINITE)

self._ffmpeg_proc.kill()

self.logger.info('Screen Recorder Service Done!')

except BaseException as e:

self.logger.warn('Exception : %s' % e)

self.SvcStop()

def SvcStop(self):

self.ReportServiceStatus(win32service.SERVICE_STOP_PENDING)

self.logger.info('Screen Recorder Service is Stopping ...')

self.stop()

self.logger.info('Screen Recorder Service Stopped')

win32event.SetEvent(self.stop_event)

self.ReportServiceStatus(win32service.SERVICE_STOPPED)

def start(self):

if not os.path.exists(self._svc_data_dir):

os.mkdir(self._svc_data_dir)

else:

pass

def stop(self):

pass

def log(self, msg):

servicemanager.LogInfoMsg(str(msg))

if __name__ == "__main__":

if len(sys.argv) == 1:

servicemanager.Initialize()

servicemanager.PrepareToHostSingle(ScreenRecorderService)

servicemanager.StartServiceCtrlDispatcher()

else:

win32serviceutil.HandleCommandLine(ScreenRecorderService)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值