回答編集履歴

3

表記修正

2019/08/13 02:05

投稿

mokemokechicken
mokemokechicken

スコア948

test CHANGED
@@ -26,7 +26,7 @@
26
26
 
27
27
 
28
28
 
29
- エラーは MCP3002.__del__() で発生していますが、これは MCP3002 InstanceがScopeから消える時に呼び出されるので、本来無限ループしているときには起こらない気がします。
29
+ エラーは `MCP3002#__del__()` で発生していますが、これは MCP3002 InstanceがScopeから消える時に呼び出されるので、本来無限ループしているときには起こらない気がします。
30
30
 
31
31
  それが発生するということは、無限ループの中から抜け出す事件が起こっている(CTL+Cで止めるとか、例外が発生するとか)と思います。
32
32
 

2

追記2

2019/08/13 02:05

投稿

mokemokechicken
mokemokechicken

スコア948

test CHANGED
@@ -19,3 +19,43 @@
19
19
  過去にも似たような投稿がありますね: https://teratail.com/questions/171880
20
20
 
21
21
  解決したのかな...?
22
+
23
+
24
+
25
+ ■ 追記2
26
+
27
+
28
+
29
+ エラーは MCP3002.__del__() で発生していますが、これは MCP3002 InstanceがScopeから消える時に呼び出されるので、本来無限ループしているときには起こらない気がします。
30
+
31
+ それが発生するということは、無限ループの中から抜け出す事件が起こっている(CTL+Cで止めるとか、例外が発生するとか)と思います。
32
+
33
+
34
+
35
+ ここからは大予想(完全な推測)なんですが、
36
+
37
+
38
+
39
+ - 1) 1時間くらいしてspreadsheetのトークンの有効期限が切れる
40
+
41
+ - 2) wks.update_cell(...) で例外発生
42
+
43
+ - 3) except: pass でそれは握りつぶされる
44
+
45
+ - 4) MCP3002 が後処理 (__del__() の呼び出し)されるときに、weakrefのエラー → 最終的なエラーはこれにみえる
46
+
47
+
48
+
49
+ という気がします。
50
+
51
+ なので、
52
+
53
+
54
+
55
+ 対策1: 単に例外を握りつぶすだけの Try-Catch を削除して、他のエラーが発生している可能性を探る
56
+
57
+ 対策2: それに対して対策する(時間が経過して wks.update_cell() でエラーになるなら、認証を再度実行するようなWrapperを作ったりする)
58
+
59
+
60
+
61
+ とするのが良い気がしました。

1

追記1

2019/08/13 02:04

投稿

mokemokechicken
mokemokechicken

スコア948

test CHANGED
@@ -9,3 +9,13 @@
9
9
 
10
10
 
11
11
  通常は、誰かが参照している間はObjectは消えないのですが、弱参照という軽め?の参照のみが残っている場合は消えることがあります(Garbage Collectionされてしまう)。
12
+
13
+
14
+
15
+ ------------
16
+
17
+ ■ 追記1
18
+
19
+ 過去にも似たような投稿がありますね: https://teratail.com/questions/171880
20
+
21
+ 解決したのかな...?