gpt4 book ai didi

python - 删除借用代码中未使用的导入是否一定安全?

转载 作者:行者123 更新时间:2023-11-28 22:52:24 24 4
gpt4 key购买 nike

我正在研究来自 paramiko 的演示脚本包 ( forward.py ) 来熟悉 Python 中的 SSH 隧道。当我在我的 IDE 中打开演示脚本时,我注意到一些未使用的导入警告:

import getpass
import os # <--- IDE warning: "'os' imported but unused"
import socket # <--- IDE warning: "'socket' imported but unused"
import select
import SocketServer
import sys
from optparse import OptionParser

果然,脚本中没有明确引用这两个模块。我是一个整洁的怪胎,所以我想删除这些困惑 - 但我也没有经验,无法确定它们是否无关紧要。

对我来说,最直接的做法是删除导入,然后尝试在没有它们的情况下运行脚本,但我不知道我是否能够判断是否有什么地方不能正常工作,因为我我仍在努力理解脚本的工作原理。

我找到了 a conversation这让我觉得可能有理由在不使用模块的情况下导入它。但是在investigating further在我看来,那个对话中的例子与代码的功能无关,用户只是想遵循一种风格惯例。

如果从来没有引用任何导入的内容,如何证明导入是合理的?我想可能有代码在导入时运行,例如:

"""
silly.py: this is very silly
"""

class ManBearPig(Man, Bear, Pig):
def __init__(self, name):
self.name = name

@classmethod
def summon(cls):
"""summon Gary"""
global Gary
Gary = cls('Gary')

ManBearPig.summon()

这似乎是个糟糕的主意,但我对我的 python-fu 没有足够的信心来确定。 socket 已经在 SocketServer 中导入,如果您没有明确使用它,那么在此处导入它有什么意义呢?

最佳答案

是的,删除您的代码在当前模块中未使用的导入或本身没有副作用的导入是足够安全的。

Python 导入模块一次 并将它们存储在sys.modules 中以供将来引用;随后的导入将重新使用已经导入的模块对象。有副作用的模块利用了它,但它们仍然必须导入一次。

对于“常规”模块,您所拥有的只是对模块对象或该模块内对象的额外引用。这需要一点额外的内存(除了模块对象本身),所以成本不是那么高。

但是您随后必须跟踪您使用了哪些模块,以及因此可以在您的代码中使用哪些可能导致错误的全局名称。

关于python - 删除借用代码中未使用的导入是否一定安全?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20482480/

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