前提・実現したいこと
計測した値をPythonでPOSTするプログラムを書いています。
以下のような結果を想定しているのですが、その下のような結果になってしまいます。
cnt
の値は関数mesure
の初めでしか書き換えていないつもりなのですが、それを引数にしてprintwすると不明に減った値が 表示されてしまいます。
原因はどこにあるのでしょうか?
想定している結果
POSTしました。 1 POSTしました。 2 POSTしました。 3 (中略) POSTしました。 100 POSTしました。 101 POSTしました。 102 (後略)
実際の結果
POSTしました。 1 POSTしました。 2 POSTしました。 3 (中略) POSTしました。 100 POSTしました。 3 POSTしました。 5 POSTしました。 7 POSTしました。 13 (後略)
該当のソースコード
Python
1cnt = 0 2list = [] 3URL = "http://example.com/" 4def mesure(arg1, arg2): 5 global cnt 6 global list 7 cnt += 1 8 9 data_x = 1 #仮の値 10 data_y = 2 #仮の値 11 12 list.append([cnt, data_x, ldata_y]) 13 14 if cnt % 100 == 0: 15 for cnt, data_x, data_y in list: 16 post(cnt, data_x, ldata_y) 17 list = [] 18 19def post(arg1, arg2, arg3): 20 data = { 21 "x":data_x, 22 "y":data_y 23 } 24 from requests.exceptions import Timeout 25 try: 26 requests.post(URL, json=measure, timeout=0.5) 27 print("POSTしました。", arg1) 28 except Timeout: 29 print("タイムアウトしました。再実行します。") 30 post(arg1, arg2, arg3) 31 except Exception as e: 32 logging.error(e) 33 34while 1: 35 try: 36 signal.signal(signal.SIGALRM, measure) 37 signal.setitimer(signal.ITIMER_REAL, 1, 1) 38 while True: 39 time.sleep(1) 40 41 except KeyboardInterrupt: 42 break 43
補足情報(FW/ツールのバージョンなど)
Python 3.5.3
回答1件
あなたの回答
tips
プレビュー
バッドをするには、ログインかつ
こちらの条件を満たす必要があります。