sqlでセレクトをかけて該当レコードがあれば
root.mainloop()を行い
gui画面を出力するというプログラムなのですが
該当レコードが1けんあると2画面出力されてしまいます。
何故でしょうか。
どなたかご教授の程、お願い致します
追加
最初に動いたjobメソッドで生成されるroot.mainloopの画面がdestroyされずに残ってしまっているのが原因と推測しております。
python
1# -*- coding:utf-8 -*- 2 3import schedule 4import time 5import tkinter as tk 6import datetime 7import sqlite3 8 9def job(): 10 dbfile = sqlite3.connect('schedule.db') 11 sql = dbfile.cursor() 12 13 now = datetime.datetime.now() 14 print("now = {}".format(now)) 15 16 if now.month <= 9: 17 month = "0{}".format(now.month) 18 else: 19 month = now.month 20 21 if now.day <= 9: 22 day = "0{}".format(now.day) 23 else: 24 day = now.day 25 26 YYYYMMDD = "{}-{}-{}".format(now.year, month, day) 27 28 if now.hour <= 9: 29 hour = "0{}".format(now.hour) 30 else: 31 hour = now.hour 32 33 if now.minute <= 9: 34 minute = "0{}".format(now.hour) 35 else: 36 minute = now.minute 37 38 time = "{}:{}".format(hour, minute) 39 40 sql.execute("select * from cl_table where YYYYMMDD = ? and HHMMSS = ? ", (YYYYMMDD,time, )) 41 print("select * from cl_table where YYYYMMDD = {} and HHMMSS = {} ORDER BY HHMMSS ASC".format(YYYYMMDD,time )) 42 list = sql.fetchall() 43 print(len(list)) 44 45 root = tk.Tk() 46 root.title("通知") 47 root.geometry("500x500") 48 i = 0 49 if not len(list) == 0: 50 for out in list: 51 ddmm = tk.Label(root, text="{} {} の時間です".format(out[1],out[2])) 52 ddmm.place(x=180, y=i) 53 i = i + 20 54 root.mainloop() 55 56schedule.every(1).minutes.do(job) 57while True: 58 schedule.run_pending() 59 time.sleep(1)
2画面出力というのはウィンドウが2つ生成されるという事でしょうか?
SQL部分に関しては再現ができない為10~43行目を削除
job関数内でlist = [[1, 2],[3, 4],[5, 6]]と定義し、
テストの為schedule.every(10/60).minutes.do(job)として実行をしてみましたが、
正常に10秒おきにウィンドウが1つ生成されました。
ウィンドウを閉じない限りは次のjobは実行されず、
ウィンドウを閉じる事で更に10秒後にjobが実行されるというテスト結果でした。
>2画面出力というのはウィンドウが2つ生成されるという事でしょうか?
そうゆうことです
schedule.every(1).minutes.do(job)
を
schedule.every(10/60).minutes.do(job)
に編集したらおっしゃる通り1ウィンドウしか出力されないようになりました。
ありがとうございます
every(10/60).minutesに関しては、あくまでも動作テストの為1分間待っていられないからという事で10秒間隔に変えてテストしただけのものであり、本筋の動作とはあまり関係がないものです。
生成される2つのウィンドウはどちらも同じで、ラベルウィジェットがそれぞれ配置されているという感じという事でしょうかね?
また、通知だけという事であればtkinter.messageboxでダイヤログのポップや、plyer.notificationでバルーン通知を起こす事も可能ですので、ご参考下さい。
あなたの回答
tips
プレビュー