python自动更新window服务的exe程序

该博客介绍了一个用于自动化安装和更新Windows服务EXE的批处理模板。通过下载新应用并重命名,然后创建并运行批处理文件来实现服务的平滑升级。批处理文件包括停止服务、删除旧EXE、重命名新EXE以及启动服务的步骤。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近一直在研究怎么自动化安装exe成服务,还有就是需要考虑到后面的更新问题,因为这个项目牵扯到的终端有点多,所以准备用自动更新,后台去自动化控制,这里简单写了个自动更新服务exe的模板


# 这个文件主要用于集成到系统里面,用于批处理文件的自动化升级,
# 思路:先下载exe应用,给新的exe应用命名后面添加.new,再运行批处理文件
# 批处理文件的思路,停止服务,删除旧的exe文件,修改新的exe文件名称,启动exe服务

import os,sys

# 假设已经下载好了新的应用,
new_file_name = 'SMWinservice.exe.new'
def create_update_bat(file_name,new_name):
    # 获取当前路径
    file_path = os.path.dirname(os.path.abspath(__file__))
    exe = file_name.split('.')[0]
    dat_path = file_path+os.sep+exe+'_update_service.bat'
    if os.path.isfile(dat_path):
        os.remove(dat_path)
    b = open(dat_path,'w',encoding='ANSI')
    TempList = '''@echo off
    
    echo ----------         stop           --------
    taskkill /f /t /im {}
    IF ERRORLEVEL 0 echo 服务停止成功
    echo.
    if not exist {} exit 

    echo.
    echo ----------         delete删除旧程序        --------
    del {}
    
    echo.
    echo ----------         修改新程序包名称        --------
    copy  {}  {}
    echo.
    echo ----------         start          --------
    .\{}  start
    IF ERRORLEVEL 0 echo 服务启动成功

    echo.
    echo 安装成功,打开服务查看
    exit
    '''.format(file_name,file_name,file_name,new_name,file_name,file_name)

    b.write(TempList)
    b.close()
    # subprocess.Popen("upgrade.bat") #不显示cmd窗口
    # os.system('start upgrade.bat')  #显示cmd窗口

# 根据程序名称自动生成对应的bat文件
create_update_bat("SMWinservice.exe",new_file_name)

 

在进行自动化测试时,针对可执行文件(.exe)或桌面应用程序的测试通常需要模拟用户与界面的交互行为。Python 提供了一些库来支持这种类型的应用程序自动化测试,其中 `pywinauto` 和 `uiautomation` 是较为常用的工具。 ### 使用 `pywinauto` 进行 EXE 应用程序自动化测试 `pywinauto` 是一个用于自动化 Windows GUI 的 Python 库,可以用来对 `.exe` 文件或基于 Win32 API 的应用程序进行操作。它支持两种后端:`win32` 和 `uia`(UI Automation),后者更适合现代的 WPF 和 UWP 应用。 #### 示例代码: ```python from pywinauto.application import Application # 启动应用程序 app = Application(backend="uia").start("notepad.exe") # 连接到已运行的应用程序 app = Application(backend="uia").connect(title_re=".*Notepad.*", timeout=10) # 获取主窗口 window = app.window(title_re=".*Notepad.*") # 输入文本到记事本中 window.type_keys("Hello, this is an automated test!", with_spaces=True) # 关闭记事本 window.close() ``` 上述代码演示了如何启动记事本、输入文本并关闭它的过程[^1]。 ### 使用 `uiautomation` 进行更精细的控制 对于某些复杂的 UI 控件结构,可以使用 `uiautomation` 模块,它是专门为 Windows 平台设计的 UI 自动化模块,能够处理更多的控件类型和事件触发。 #### 示例代码: ```python import uiautomation as auto # 查找记事本窗口 window = auto.WindowControl(searchDepth=1, Name='Untitled - Notepad', WindowType='Window') if window: # 找到编辑框并输入内容 edit_box = window.FindControl(lambda c: isinstance(c, auto.EditControl), searchDepth=5) if edit_box: edit_box.Click() edit_box.SendKeys("Automated input using uiautomation library.", charMode=True) else: print("Notepad window not found.") ``` 此示例展示了如何通过 `uiautomation` 定位记事本中的编辑控件,并向其发送文本输入[^3]。 ### 测试框架集成 为了更好地组织和管理测试用例,可以将这些自动化脚本整合进测试框架中,如 `pytest` 或 `unittest`。这样可以利用框架提供的功能,例如断言、测试报告生成等。 #### 与 `unittest` 集成的简单示例: ```python import unittest from pywinauto.application import Application class TestNotepad(unittest.TestCase): def setUp(self): self.app = Application(backend="uia").start("notepad.exe") self.window = self.app.window(title_re=".*Notepad.*") def test_type_text(self): self.window.type_keys("Testing pywinauto") text = self.window.get_value() self.assertIn("Testing pywinauto", text) def tearDown(self): self.window.close() if __name__ == '__main__': unittest.main() ``` 该测试类包含了一个基本的测试方法,验证是否可以在记事本中正确输入文本[^1]。 ---
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值