对于以前版本的TensorFlow,我们已经覆盖了tf.logging._logger在我们的python代码库的其余部分中使用自定义日志记录行为的处理程序:
例如,在TF 1.7上,以下代码段(省略了一些日志记录样板)
import tensorflow as tf
tf.logging.set_verbosity(tf.logging.INFO)
tf_logging = tf.logging._logger
tf_logging.handlers = [_std_out_handler()]
tf_logging.propagate = False
_logging.info("EXPECTED LOG FORMAT")
tf.logging.info("TF LOG FORMAT")
Run Code Online (Sandbox Code Playgroud)
产生
[INFO |mrtx] 2018-05-18 15:10:07,613 /merantix_core/common/util/logging.py:189 --- EXPECTED LOG FORMAT
[INFO |mrtx] 2018-05-18 15:10:07,614 /usr/local/lib/python2.7/dist-packages/tensorflow/python/platform/tf_logging.py:116 --- TF LOG FORMAT
Run Code Online (Sandbox Code Playgroud)
在TF 1.8中,tf.logging._logger不再可访问.根据这个帖子,我尝试了设置
tf_logging = _logging.getLogger('tensorflow')
Run Code Online (Sandbox Code Playgroud)
在上面的代码片段中,输出是
[INFO |mrtx] 2018-05-18 15:20:34,043 /merantix_core/common/util/logging.py:190 --- EXPECTED LOG FORMAT
INFO:tensorflow:TF LOG FORMAT
Run Code Online (Sandbox Code Playgroud)
我没有看到TF 1.7和1.8之间的tf_logging.py有任何变化.我假设之前没有强制执行tf_export调用,但现在正在执行.还有一些方法可以覆盖处理程序tf.logging吗?或者,是否有更规范的方式来获得上述功能?
小智 6
您仍然可以通过直接导入日志记录模块来访问tensorflow记录器:
from tensorflow.python.platform import tf_logging
tf_logger = tf_logging._get_logger()
tf_logger.handlers = handlers
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1024 次 |
| 最近记录: |