Update app.py
Browse files
app.py
CHANGED
@@ -14,13 +14,26 @@ import torch
|
|
14 |
from loguru import logger
|
15 |
import nltk
|
16 |
|
|
|
|
|
17 |
import torch.serialization
|
18 |
-
torch.serialization.register_package("utils")
|
19 |
_original_torch_load = torch.load
|
20 |
-
|
21 |
-
|
22 |
-
|
23 |
-
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
24 |
|
25 |
# 設定 HTTPS context 避免證書錯誤
|
26 |
ssl._create_default_https_context = ssl._create_unverified_context
|
|
|
14 |
from loguru import logger
|
15 |
import nltk
|
16 |
|
17 |
+
# ✅ 加入 monkey patch 讓 torch.load 自動允許 utils.HParams
|
18 |
+
import builtins
|
19 |
import torch.serialization
|
|
|
20 |
_original_torch_load = torch.load
|
21 |
+
|
22 |
+
def patched_torch_load(*args, **kwargs):
|
23 |
+
import types
|
24 |
+
|
25 |
+
# 建立假的 utils 模組和 HParams 類別(只需要匹配名稱)
|
26 |
+
class DummyHParams:
|
27 |
+
pass
|
28 |
+
|
29 |
+
dummy_utils = types.ModuleType("utils")
|
30 |
+
dummy_utils.HParams = DummyHParams
|
31 |
+
|
32 |
+
# 用 safe_globals 臨時允許這個類別被 pickle 載入
|
33 |
+
with torch.serialization.safe_globals({"utils.HParams": DummyHParams}):
|
34 |
+
return _original_torch_load(*args, **kwargs)
|
35 |
+
|
36 |
+
torch.load = patched_torch_load
|
37 |
|
38 |
# 設定 HTTPS context 避免證書錯誤
|
39 |
ssl._create_default_https_context = ssl._create_unverified_context
|