Ответ 1
Самый простой способ - в том, что модуль предупреждений предлагает здесь:
with warnings.catch_warnings():
warnings.simplefilter("ignore")
import paramiko
Я использую Paramiko в моем коде python (для sftp). Все работает отлично, за исключением того, что каждый раз я импортирую или вызываю функцию paramiko. Это предупреждение появится:
C:\Python26\lib\site-packages\Crypto\Util\randpool.py:40: RandomPool_Deprecation
Warning: This application uses RandomPool, which is BROKEN in older releases. S
ee http://www.pycrypto.org/randpool-broken
RandomPool_DeprecationWarning)
Я знаю, что это связано с тем, что Paramiko использует некоторые устаревшие функции PyCrypto.
Мой вопрос в том, есть ли способ подавить это предупреждение программно? Я пробовал это:
warnings.filterwarnings(action='ignore', \
category=DeprecationWarning, module='paramiko')
и даже это:
warnings.filterwarnings(action='ignore', \
category=DeprecationWarning, module='randpool')
перед операцией "import paramiko" и перед вызовом функции paramiko, но ничего не работает. Это предупреждение продолжает проявляться несмотря ни на что. Если это помогает, вот код в сторонней библиотеке, который печатает предупреждение:
в randpool.py:
from Crypto.pct_warnings import RandomPool_DeprecationWarning
import Crypto.Random
import warnings
class RandomPool:
"""Deprecated. Use Random.new() instead.
See http://www.pycrypto.org/randpool-broken
"""
def __init__(self, numbytes = 160, cipher=None, hash=None, file=None):
warnings.warn("This application uses RandomPool, which is BROKEN in older releases. See http://www.pycrypto.org/randpool-broken",
RandomPool_DeprecationWarning)
Если вы знаете, как это сделать, пожалуйста, помогите мне отключить это предупреждение.
Самый простой способ - в том, что модуль предупреждений предлагает здесь:
with warnings.catch_warnings():
warnings.simplefilter("ignore")
import paramiko
Для фильтрации только определенного предупреждения:
with warnings.catch_warnings():
warnings.simplefilter('ignore', SpecificWarningObject)
#do something that raises a Warning
Аргумент module
в warnings.filterwarnings
принимает регистрозависимое регулярное выражение, которое должно соответствовать полному имени модуля, поэтому
warnings.filterwarnings(
action='ignore',
category=DeprecationWarning,
module=r'.*randpool'
)
или же
warnings.filterwarnings(
action='ignore',
category=DeprecationWarning,
module=r'Crypto\.Utils\.randpool'
)
должно сработать. Вы, возможно, придется написать RandomPool_DeprecationWarning
явно вместо DeprecationWarning
, если по какой - то причине RandomPool_DeprecationWarning
не подкласс DeprecationWarning
.
Вы также можете отключить предупреждение в командной строке при вызове сценария, передав -W
интерпретатору следующим образом:
$ python -W ignore::RandomPool_DeprecationWarning:Crypto.Utils.randpool: my_script.py
-W
принимает фильтры в формате action:message:category:module:lineno
, где этот временной module
должен точно соответствовать (полностью определенному) имени action:message:category:module:lineno
, в котором action:message:category:module:lineno
предупреждение.
См. Https://docs.python.org/2/library/warnings.html?highlight=warnings#the-Warnings-filter и https://docs.python.org/2/using/cmdline.html#cmdoption -W