50

Python コード (sftp 用) で Paramiko を使用しています。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)

これを回避する方法を知っている場合は、この警告を止めるのを手伝ってください。

4

4 に答える 4

48

最も簡単な方法は、警告モジュールがここで示唆しているようなものです:

with warnings.catch_warnings():
    warnings.simplefilter("ignore")
    import paramiko
于 2010-10-13T04:59:48.483 に答える