python-3.x - Python 抑制特定的输出消息
问题描述
我正在使用 tldextract 库在 Python 中解析 URL。当我运行它时,它会生成许多我想要抑制的 FILELOCK 消息。我不想抑制任何其他标准输出消息(我有很多日志消息 - 我想查看的信息)。我正在使用多处理并使用笔记本电脑的所有 8 个内核在大量 URL 上运行。
有什么建议么?以下是详细信息:
示例代码如下。我尝试使用 contextlib(https://docs.python.org/3/library/contextlib.html#contextlib.redirect_stdout)。但是,也许我没有正确使用它。
import io, tldextract, contextlib, os
def get_sld(self, reg_domain_name):
"""
Get only the second-level domain.
:param reg_domain_name: sports.cnn.com
:return: cnn
"""
domain = reg_domain_name
#f = io.StringIO()
with contextlib.redirect_stdout(os.devnull):
if reg_domain_name:
try:
ext = tldextract.extract(reg_domain_name)
except:
logger.info(f'Unable to extract domain from {reg_domain_name}. Using given fqdn.')
else:
domain = ext.domain
return domain
上面的代码生成了许多类似下面的消息..我想禁止:
2020-10-29 20:00:11,750 - filelock - filelock - INFO - Lock 4992537872 released on /Users/sri/p37/lib/python3.7/site-packages/tldextract/.suffix_cache/urls/62bf135d1c2f3d4db4228b9ecaf507a2.tldextract.json.lock
2020-10-29 20:00:11,765 - filelock - filelock - INFO - Lock 4992398992 released on /Users/sri/p37/lib/python3.7/site-packages/tldextract/.suffix_cache/publicsuffix.org-tlds/de84b5ca2167d4c83e38fb162f2e8738.tldextract.json.lock
2020-10-29 20:00:11,790 - filelock - filelock - INFO - Lock 4992506640 acquired on /Users/sri/p37/lib/python3.7/site-packages/tldextract/.suffix_cache/publicsuffix.org-tlds/de84b5ca2167d4c83e38fb162f2e8738.tldextract.json.lock
2020-10-29 20:00:11,796 - filelock - filelock - INFO - Lock 4992529872 acquired on /Users/sri/p37/lib/python3.7/site-packages/tldextract/.suffix_cache/urls/62bf135d1c2f3d4db4228b9ecaf507a2.tldextract.json.lock
2020-10-29 20:00:11,802 - filelock - filelock - INFO - Lock 4992529872 released on /Users/sri/p37/lib/python3.7/site-packages/tldextract/.suffix_cache/urls/62bf135d1c2f3d4db4228b9ecaf507a2.tldextract.json.lock
解决方案
推荐阅读
- javascript - 按 id 组合对象数组并减少其嵌套对象
- javascript - Node Red 中的 Javascript Else If 语句有问题
- javascript - 过滤数组的子数组
- c - 我们可以在内核中打开文件之前检查文件的读写权限吗
- python - 基于内部值的 Numpy 数组操作
- java - 如何从常规类访问控制器类的字段?- JavaFX胶子
- excel - Excel vba - 从模块或类调用时,RegOpenKeyExA& 函数返回不同的值
- reactjs - CamanJS 与 React
- python - 可以确定是否总是在有向图中访问给定节点?
- python - 在不同机器上分配大型 ndarray 时,MemoryError 与“ValueError:数组太大”