Как подавить стороннее предупреждение с помощью warnings.filterwarnings - PullRequest
30 голосов
/ 13 октября 2010

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

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

Ответы [ 3 ]

35 голосов
/ 13 октября 2010

Проще всего было бы, как подсказывает модуль предупреждений здесь :

with warnings.catch_warnings():
    warnings.simplefilter("ignore")
    import paramiko
4 голосов
/ 15 сентября 2017

Чтобы отфильтровать только определенное предупреждение:

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

    #do something that raises a Warning
3 голосов
/ 10 декабря 2018

Аргумент 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 должно точно соответствовать (полностью определенному)) имя модуля, в котором выдается предупреждение.

См. https://docs.python.org/2/library/warnings.html?highlight=warnings#the-warnings-filter и https://docs.python.org/2/using/cmdline.html#cmdoption-w

...