python 自动化 win11 编程 实现 一键 启动多个软件,QQ浏览器,snipaste,pycharm软件

python 复制代码
import time
import logging
import os
import subprocess
import winreg
from datetime import datetime

# 配置日志
logging.basicConfig(level=logging.INFO, format='%(asctime)s - %(levelname)s - %(message)s')

# 应用程序路径
APP_PATHS = {
    'qqbrowser': r'C:\Program Files\Tencent\QQBrowser\QQBrowser.exe',
    'snipaste': r'C:\Program Files\Snipaste\Snipaste.exe',
    'pycharm': r'C:\Program Files\JetBrains\PyCharm Community Edition X.Y.Z\bin\pycharm64.exe'
}

# 备忘录文件路径
NOTEPAD_PATH = r'C:\Windows\system32\notepad.exe'
NOTES_FILE_PATH = r'C:\Users\YourUsername\Documents\notes.txt'

# 工作日志文件路径
WORKLOG_FILE_PATH = r'C:\Users\YourUsername\Documents\worklog.txt'

def launch_app(app_name):
    """启动指定的应用程序"""
    if app_name in APP_PATHS:
        app_path = APP_PATHS[app_name]
        logging.info(f"Launching {app_name}...")
        try:
            subprocess.Popen([app_path], shell=True)
            logging.info(f"{app_name} launched successfully.")
        except FileNotFoundError:
            logging.error(f"File not found: {app_path}")
        except Exception as e:
            logging.error(f"An error occurred while launching {app_name}: {e}")
    else:
        logging.error(f"Application {app_name} is not supported.")

def open_notes():
    """打开备忘录文件"""
    try:
        subprocess.Popen([NOTEPAD_PATH, NOTES_FILE_PATH])
        logging.info("Notepad opened with notes file.")
    except FileNotFoundError:
        logging.error(f"File not found: {NOTES_FILE_PATH}")
    except Exception as e:
        logging.error(f"An error occurred while opening notes: {e}")

def write_log_entry(log_file_path):
    """写入今天的日期、时间和编程记录"""
    current_time = datetime.now().strftime("%Y-%m-%d %H:%M:%S")
    log_entry = (
        f"Date and Time: {current_time}\n"
        f"Action: 开始编程\n"
        f"Note: 今天开始进行编程工作的记录。\n\n"
    )
    try:
        with open(log_file_path, 'a') as log_file:
            log_file.write(log_entry)
        logging.info(f"Log entry written to {log_file_path}")
    except IOError as e:
        logging.error(f"Failed to write to log file: {e}")

def open_log_file():
    """打开工作日志文件,并写入今天的日期和时间"""
    try:
        subprocess.Popen([NOTEPAD_PATH, WORKLOG_FILE_PATH])
        logging.info("Notepad opened with work log file.")
        write_log_entry(WORKLOG_FILE_PATH)
    except FileNotFoundError:
        logging.error(f"File not found: {WORKLOG_FILE_PATH}")
    except Exception as e:
        logging.error(f"An error occurred while opening log file: {e}")

def launch_all_apps():
    """等待一段时间后启动所有应用程序并打开备忘录和工作日志"""
    logging.info("Waiting 30 seconds before launching applications and opening notes/log...")
    time.sleep(30)  # Wait for 30 seconds
    open_notes()
    open_log_file()
    for app_name in APP_PATHS.keys():
        launch_app(app_name)

def set_startup(exe_path):
    """设置程序开机启动"""
    key = winreg.OpenKey(winreg.HKEY_CURRENT_USER,
                         r'Software\Microsoft\Windows\CurrentVersion\Run', 0,
                         winreg.KEY_ALL_ACCESS)
    winreg.SetValueEx(key, "LaunchAppsAtStartup", 0, winreg.REG_SZ, exe_path)
    winreg.CloseKey(key)
    logging.info("Setup complete. Your application will now start at login.")

def main():
    # 获取当前脚本的绝对路径
    script_path = os.path.abspath(__file__)
    # 设置开机启动
    set_startup(script_path)
    # 立即启动所有应用程序、打开备忘录和工作日志(仅用于测试)
    # launch_all_apps()

if __name__ == "__main__":
    main()

改进点

  1. 代码结构

    • 将不同功能封装到单独的函数中,提高了代码的可读性和可维护性。
  2. 日志记录

    • 使用 logging 模块记录详细的日志信息,包括启动成功、失败和错误信息。
  3. 错误处理

    • 增强了错误处理机制,确保在文件不存在或写入失败时能够记录错误信息。
  4. 路径变量命名

    • 更改了工作日志文件路径变量名,使其更具描述性。
  5. 测试模式

    • 可以通过取消注释 launch_all_apps() 来立即启动所有应用程序、打开备忘录和工作日志,用于测试。

打包 .exe 文件

使用 PyInstaller 将脚本打包成 .exe 文件:

bash 复制代码
pyinstaller --onefile --icon=your_icon.ico launch_apps.py

这将在 dist 文件夹中生成一个 .exe 文件。

测试与验证

  1. 生成 .exe 文件

    • 确保 .exe 文件生成成功。
  2. 设置开机启动

    • 第一次运行 .exe 文件时,会自动设置开机启动。
  3. 测试开机启动

    • 重启计算机,等待 30 秒后检查应用程序是否自动启动,并检查备忘录和工作日志是否自动打开并写入记录。

这样,代码更加清晰、模块化,并且具有更好的错误处理机制,易于维护和扩展。

相关推荐
sleepybear11132 分钟前
在Ubuntu上从零开始编译并运行Home Assistant源码并集成HACS与小米开源的Ha Xiaomi Home
python·智能家居·小米·home assistant·米家·ha xiaomi home
纪伊路上盛名在7 分钟前
(鱼书)深度学习入门1:python入门
人工智能·python·深度学习
夏末蝉未鸣0124 分钟前
python transformers笔记(TrainingArguments类)
python·自然语言处理·transformer
德育处主任Pro28 分钟前
「py数据分析」04如何将 Python 爬取的数据保存为 CSV 文件
数据库·python·数据分析
咸鱼鲸38 分钟前
【PyTorch】PyTorch中数据准备工作(AI生成)
人工智能·pytorch·python
Python×CATIA工业智造1 小时前
列表页与详情页的智能识别:多维度判定方法与工业级实现
爬虫·深度学习·pycharm
遇见你很高兴1 小时前
Pycharm中体验通义灵码来AI辅助编程
python
大虫小呓1 小时前
50个Python处理Excel示例代码,覆盖95%日常使用场景-全网最全
python·excel
大模型真好玩1 小时前
做题王者,实战拉跨!是时候给马斯克的Grok4泼盆冷水了!(Grok 4模型详细测评报告)
人工智能·python·mcp
羊八井1 小时前
使用 Earth2Studio 和 AI 模型进行全球天气预测:太阳辐照
pytorch·python·nvidia