当我运行我正在使用的程序时:
nltk.download('wordnet')
from nltk.corpus import wordnet
我得到以下输出到我的终端:
[nltk_data] Downloading package wordnet to
[nltk_data] /Users/.../nltk_data...
[nltk_data] Package wordnet is already up-to-date!
我的程序依赖于没有将这些信息保存到终端和生成的输出文件,那么如何防止上述行发生,或者将其写入sys.stderr以便它不会被包含而不是通过打印?
最佳答案 根据
source code,nltk下载程序使用简单的print()调用来报告进度.这意味着没有涉及可以控制或预配置的记录器.
其中一个选项是暂时修改sys.stdout –
Python 3.4中有redirect_stdout()
context manager:
from contextlib import redirect_stdout
import os
import nltk
from nltk.corpus import wordnet
with redirect_stdout(open(os.devnull, "w")):
nltk.download('wordnet')
或者其他一些选择:
> Suppress calls to print (python)
> Silence the stdout of a function in Python without trashing sys.stdout and restoring each function call