Fiddler Classic 定时执行脚本程序 - 自动化测试工具
以下是融合后的代码:
import time import pygetwindow import pyautogui import schedule import threading import tkinter as tk from tkinter import messagebox import subprocess import os
def is_fiddler_window_active(): try: # 获取当前活动窗口 active_window = pygetwindow.getActiveWindow() if active_window.title == 'Progress Telerik Fiddler Classic': return True else: return False except Exception as e: print('获取窗口信息失败:', str(e)) return False
def open_fiddler(fiddler_path): try: if not os.path.exists(fiddler_path): print('Fiddler Classic 路径不存在') return False
# 启动 Fiddler Classic
subprocess.Popen(fiddler_path)
# 判断 Fiddler Classic 是否启动成功
for _ in range(10):
if is_fiddler_window_active():
print('成功激活 Fiddler Classic')
return True
time.sleep(1)
print('启动 Fiddler Classic 失败')
return False
except Exception as e:
print('启动 Fiddler Classic 失败:', str(e))
return False
def simulate_shortcut(success_var, failure_var): global success_count, failure_count
if is_fiddler_window_active():
try:
# 模拟按下 Ctrl + X 组合键
pyautogui.hotkey('ctrl', 'x')
time.sleep(0.5) # 等待操作完成
if not is_fiddler_window_active():
print('模拟按下 Ctrl + X 后不在 Fiddler Classic 窗口中')
failure_count += 1
failure_var.set(f'执行失败{failure_count}次')
else:
print('成功模拟按下 Ctrl + X')
success_count += 1
success_var.set(f'执行成功{success_count}次')
except Exception as e:
print('模拟按键操作失败:', str(e))
failure_count += 1
failure_var.set(f'执行失败{failure_count}次')
else:
print('当前不在 Fiddler Classic 窗口中')
failure_count += 1
failure_var.set(f'执行失败{failure_count}次')
def run_script(seconds, countdown_label, success_var, failure_var, window): seconds -= 1
if seconds < 0:
seconds = int(window.seconds_var.get())
open_fiddler(window.path_var.get())
simulate_shortcut(success_var, failure_var)
if not window.stop_flag:
countdown_label.config(text=f'距离下次执行还有 {seconds} 秒')
if not window.stop_flag:
threading.Timer(1, run_script, args=(seconds, countdown_label, success_var, failure_var, window)).start()
def start_script(seconds, countdown_label, success_var, failure_var, window): global success_count, failure_count
success_count = 0
failure_count = 0
if not seconds.isdigit():
messagebox.showerror('错误', '输入无效,请重新输入整数类型的秒数!')
elif window.stop_flag:
window.stop_flag = False
window.running_flag = True
seconds = int(seconds)
countdown_label.config(text=f'距离下次执行还有 {seconds} 秒')
success_var.set('执行成功0次')
failure_var.set('执行失败0次')
threading.Timer(1, run_script, args=(seconds, countdown_label, success_var, failure_var, window)).start()
elif window.running_flag:
messagebox.showinfo('提示', '已经有倒计时在执行中,请稍后再试!')
else:
seconds = int(seconds)
countdown_label.config(text=f'距离下次执行还有 {seconds} 秒')
success_var.set('执行成功0次')
failure_var.set('执行失败0次')
window.stop_flag = False
window.running_flag = True
threading.Timer(1, run_script, args=(seconds, countdown_label, success_var, failure_var, window)).start()
def stop_script(countdown_label, window): window.seconds_var.set('10')
countdown_label.config(text='停止运行') # 更新文本内容
window.seconds_entry.delete(0, tk.END) # 清除文本框中的内容
window.stop_flag = True
window.running_flag = False
def start_fiddler(window, fiddler_path): if window.running_flag: messagebox.showinfo('提示', '已经有 Fiddler Classic 启动中,请稍后再试!') return
if not open_fiddler(fiddler_path):
messagebox.showerror('错误', '无法启动 Fiddler Classic,请检查路径是否正确!')
return
for _ in range(10):
if is_fiddler_window_active():
simulate_shortcut()
break
time.sleep(1)
window.running_flag = True
def stop_fiddler(window): window.running_flag = False
if name == 'main': window = tk.Tk() window.title('Fiddler Classic 定时执行脚本程序')
label = tk.Label(window, text='欢迎使用 Fiddler Classic 定时执行脚本程序!')
label.pack(pady=10)
window.seconds_var = tk.StringVar(value='10')
seconds_label = tk.Label(window, text='请输入定时执行的时间间隔(秒):')
seconds_label.pack()
window.seconds_entry = tk.Entry(window, textvariable=window.seconds_var)
window.seconds_entry.pack(pady=5)
path_label = tk.Label(window, text='请输入 Fiddler Classic 路径:')
path_label.pack()
window.path_var = tk.StringVar()
path_entry = tk.Entry(window, textvariable=window.path_var)
path_entry.pack(pady=5)
countdown_label = tk.Label(window, text='')
countdown_label.pack(pady=5)
success_var = tk.StringVar(value='执行成功0次')
success_label = tk.Label(window, textvariable=success_var)
success_label.pack(pady=5)
failure_var = tk.StringVar(value='执行失败0次')
failure_label = tk.Label(window, textvariable=failure_var)
failure_label.pack(pady=5)
start_button = tk.Button(
window,
text='开始执行',
command=lambda: start_script(
window.seconds_var.get(),
countdown_label,
success_var,
failure_var,
window
)
)
start_button.pack(pady=10)
stop_button = tk.Button(
window,
text='停止运行',
command=lambda: stop_script(countdown_label, window)
)
stop_button.pack(pady=10)
fiddler_start_button = tk.Button(
window,
text='启动 Fiddler Classic',
command=lambda: start_fiddler(window, window.path_var.get())
)
fiddler_start_button.pack(pady=10)
fiddler_stop_button = tk.Button(
window,
text='停止 Fiddler Classic',
command=lambda: stop_fiddler(window)
)
fiddler_stop_button.pack(pady=10)
window.stop_flag = False
window.running_flag = False
window.mainloop()
原文地址: https://www.cveoy.top/t/topic/qg3X 著作权归作者所有。请勿转载和采集!