質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.37%
Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

Q&A

解決済

1回答

115閲覧

python:thread内でのschedule利用時に多重実行される

keruuuu

総合スコア15

Python 3.x

Python 3はPythonプログラミング言語の最新バージョンであり、2008年12月3日にリリースされました。

0グッド

0クリップ

投稿2024/11/12 14:43

編集2024/11/12 14:46

実現したいこと

毎10秒ごとに実行される処理をthreadで2つ実行させる

発生している問題・分からないこと

毎10秒ごとの処理がスレッドの数だけ多重実行されることがある。

該当のソースコード

Python

1import time 2import datetime 3import schedule 4import threading 5 6class Check(): 7 def __init__(self, i): 8 self.int = i 9 10 def start(self): 11 print(f'started / {self.int}: {datetime.datetime.now()}') 12 13 for i in range(0, 60, 10): 14 schedule.every().minute.at(":{}".format(str(i).zfill(2))).do( 15 self.check 16 ) 17 18 while True: 19 schedule.run_pending() 20 time.sleep(1.5) 21 22 def check(self): 23 print(f'{self.int}: {datetime.datetime.now()}') 24 25 26def main(): 27 checkers = [] 28 for i in range(2): 29 checker = Check(i) 30 checkers.append(checker) 31 32 threads = [] 33 for checker in checkers: 34 checker_thread = threading.Thread(target=checker.start) 35 threads.append(checker_thread) 36 checker_thread.start() 37 38 for thread in threads: 39 thread.join() 40 41main()

console

1started / 0: 2024-11-12 14:28:05.355389 2started / 1: 2024-11-12 14:28:05.355636 30: 2024-11-12 14:28:11.361782 41: 2024-11-12 14:28:11.362020 50: 2024-11-12 14:28:11.361897 61: 2024-11-12 14:28:11.362468 70: 2024-11-12 14:28:20.372013 81: 2024-11-12 14:28:20.372288 90: 2024-11-12 14:28:20.372198 101: 2024-11-12 14:28:20.372359 110: 2024-11-12 14:28:30.882826 121: 2024-11-12 14:28:30.882955 130: 2024-11-12 14:28:41.394638 141: 2024-11-12 14:28:41.394807 150: 2024-11-12 14:28:41.394730 161: 2024-11-12 14:28:41.394881

試したこと・調べたこと

  • teratailやGoogle等で検索した
  • ソースコードを自分なりに変更した
  • 知人に聞いた
  • その他
上記の詳細・結果

ChatGPTでも解決できず。

補足

特になし

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

今のコードでは、schedule.run_pending() が二つのスレッドで実行されているので、そういう動きになってしまいます。(よくない使い方になっています)

やり方としては、二つあると思います。

  1. schedule.run_pending() はメインのスレッドでひとつだけ動かして、そこから起動するものがスレッドで実行されるような形にする。 https://schedule.readthedocs.io/en/stable/parallel-execution.html

  2. スレッドごとに別のスケジューラーを用意する。 https://schedule.readthedocs.io/en/stable/multiple-schedulers.html

今のコードから変更が少ないのは後者だと思います。

python

1class Check(): 2 def __init__(self, i): 3 self.int = i 4 self.scheduler = schedule.Scheduler() 5 6 def start(self): 7 print(f'started / {self.int}: {datetime.datetime.now()}') 8 9 for i in range(0, 60, 10): 10 self.scheduler.every().minute.at(":{}".format(str(i).zfill(2))).do( 11 self.check 12 ) 13 14 while True: 15 self.scheduler.run_pending() 16 time.sleep(1.5) 17 18 def check(self): 19 print(f'{self.int}: {datetime.datetime.now()}')

投稿2024/11/13 01:00

bsdfan

総合スコア4776

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

keruuuu

2024/11/13 04:19

ご提案の方法で解決できました。 ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.37%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問