gpt4 book ai didi

python - 如何保持导入轻量级并且仍然正确键入注释?

转载 作者:行者123 更新时间:2023-12-04 09:19:04 26 4
gpt4 key购买 nike

Tensorflow 是一个超重的导入。我只想在需要时导入它。但是,我有一个像这样的模型加载功能:

from typing import Dict, Any
from keras.models import Model # Heavy import! Takes 2 seconds or so!

# Model loading is a heavy task. Only do it once and keep it in memory
model = None # type: Optional[Model]

def load_model(config: Dict[str, Any], shape) -> Model:
"""Load a model."""
if globals()['model'] is None:
globals()['model'] = create_model(wili.n_classes, shape)
print(globals()['model'].summary())
return globals()['model']

最佳答案

也许 TYPE_CHECKING 常数会帮助你:

if the import is only needed for type annotations in forward references (string literals) or comments, you can write the imports inside if TYPE_CHECKING: so that they are not executed at runtime.


The TYPE_CHECKING constant defined by the typing module is False at runtime but True while type checking.


例子:
# foo.py
from typing import List, TYPE_CHECKING

if TYPE_CHECKING:
import bar

def listify(arg: 'bar.BarClass') -> 'List[bar.BarClass]':
return [arg]
# bar.py
from typing import List
from foo import listify

class BarClass:
def listifyme(self) -> 'List[BarClass]':
return listify(self)
TYPE_CHECKING也可以用来避免 import cycles .

关于python - 如何保持导入轻量级并且仍然正确键入注释?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63127784/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com