Подтвердить что ты не робот

Как подавить стороннее предупреждение с помощью warnings.filterwarnings

Я использую 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)

Если вы знаете, как это сделать, пожалуйста, помогите мне отключить это предупреждение.

4b9b3361

Ответ 1

Самый простой способ - в том, что модуль предупреждений предлагает здесь:

with warnings.catch_warnings():
    warnings.simplefilter("ignore")
    import paramiko

Ответ 2

Для фильтрации только определенного предупреждения:

with warnings.catch_warnings():
    warnings.simplefilter('ignore', SpecificWarningObject)

    #do something that raises a Warning

Ответ 3

Аргумент 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