回答編集履歴
3
表記修正
test
CHANGED
@@ -26,7 +26,7 @@
|
|
26
26
|
|
27
27
|
|
28
28
|
|
29
|
-
エラーは MCP3002
|
29
|
+
エラーは `MCP3002#__del__()` で発生していますが、これは MCP3002 InstanceがScopeから消える時に呼び出されるので、本来無限ループしているときには起こらない気がします。
|
30
30
|
|
31
31
|
それが発生するということは、無限ループの中から抜け出す事件が起こっている(CTL+Cで止めるとか、例外が発生するとか)と思います。
|
32
32
|
|
2
追記2
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
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
|
+
解決したのかな...?
|