pysimpleguiでlogファイルを監視するプログラムを作成しています。
タイトルの通りですが、プログラム起動時にはウィンドウを最小化、
logファイルの変更を感知したらいウィンドウを表示したいのですが
そのような組み方はありますか?
ご教示いただけますと幸いです。
python
1import os 2import time 3import threading 4import winsound 5import win32com.client 6import PySimpleGUI as sg 7 8flag = 0 # global変数 ログにエラーがあった時刻 9Mail_frag =0 10Stop_frag = 0 11# タイマースレッド 12def timer_thread(): 13 print("thread開始") 14 prev_flag = 0 15 beep_count = 0 16 global Stop_frag 17 18 while True: 19 time.sleep(1) 20 if flag > 0: 21 if Stop_frag == 1: 22 while Stop_frag==1: 23 time.sleep(1) 24 continue 25 26 if flag != prev_flag: # 新しいエラーが発生していたら 27 prev_flag = flag 28 beep_count = 0 29 Mail_frag = 0 30 continue 31 32 if time.time() > (prev_flag + beep_count * 10): 33 print("BEEP") 34 beep(800,800) 35 beep_count += 1 36 37 if beep_count == 6: 38 if Mail_frag == 0: 39 print("MAIL") 40 Mail_frag = 1 41 42# ログチェックに相当する処理(とりあえず"log.txt"の有無で代替) 43def log_check(fn): 44 global flag 45 if not os.path.exists(fn): # ファイルをチェック 46 flag = 0 47 else: 48 if flag == 0: # 上書き防止するため flagをチェック 49 flag = time.time() 50 51def beep(freq, dur=100): 52 """ 53 ビープ音を鳴らす. 54 @param freq 周波数 55 @param dur 継続時間(ms) 56 """ 57 # Windowsの場合は、winsoundというPython標準ライブラリを使います. 58 59 winsound.Beep(freq, dur) 60 61def mail(fn, error): 62 outlook = win32com.client.Dispatch("Outlook.Application") 63 64 mail = outlook.CreateItem(0) 65 66 67 mail.to = 'onpu@mahodo.com' 68 mail.bcc = 'momoko@mahodo.com' 69 mail.subject = 'RPAエラー発生' 70 mail.Attachments.Add(fn) 71 mail.bodyFormat = 1 72 mail.body = '''<自動送信メール> 73 RPA実行中にエラーが発生しました。 74 エラー内容は下記の通りです。 75 ''' + error 76 77 mail.Send() 78 print("メール送信完了") 79 80layout = [ 81 [sg.Multiline(size=(70,5),background_color="ivory", border_width=0, key='-Multiline-',autoscroll=True,auto_refresh=True)], 82 [sg.Text("Run/Stop",enable_events=True,key='Run/stop')], 83 ] 84window = sg.Window('LoopChecker',layout,background_color="ivory",no_titlebar=False,alpha_channel=0.5,font='メイリオ',keep_on_top=True,resizable=True, border_depth=0,location=(50,50)) 85 86th = threading.Thread(target=timer_thread,daemon=True) 87th.start() 88fn = r"C:\Users\Desktop\testfolder\log.log" 89 90while True: 91 event,values = window.read(timeout=10) 92 log_check(fn) 93 if event is None: 94 print('exit') 95 break 96 97 if event == "Run/stop": 98 if Stop_frag == 0: 99 Stop_frag = 1 100 window['Run/stop'].update('---Stop----') 101 else: 102 Stop_frag = 0 103 window['Run/stop'].update('---Run-----') 104 105 106
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。