模拟 Python 的内置打印功能

Mock Python#39;s built in print function(模拟 Python 的内置打印功能)
本文介绍了模拟 Python 的内置打印功能的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着跟版网的小编来一起学习吧!

问题描述

我试过了

from mock import Mock
import __builtin__

__builtin__.print = Mock()

但这会引发语法错误.我也试过这样修补它

But that raises a syntax error. I've also tried patching it like so

@patch('__builtin__.print')
def test_something_that_performs_lots_of_prints(self, mock_print):

    # assert stuff

有没有办法做到这一点?

Is there any way to do this?

推荐答案

print 是 python 2.x 中的关键字,将其用作属性会引发 SyntaxError.您可以通过在文件开头使用 from __future__ import print_function 来避免这种情况.

print is a keyword in python 2.x, using it as attribute raises a SyntaxError. You can avoid that by using from __future__ import print_function in the beginning of the file.

注意:你不能简单地使用 setattr,因为你修改的打印函数不会被调用,除非 print 语句被禁用.

Note: you can't simply use setattr, because the print function you modified doesn't get invoked unless the print statement is disabled.

您还需要 from __future__ import print_function 在您希望使用修改后的 print 函数的每个文件中,否则它将被 打印语句.

you also need to from __future__ import print_function in every file you want your modified print function to be used, or it will be masked by the print statement.

这篇关于模拟 Python 的内置打印功能的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持跟版网!

本站部分内容来源互联网,如果有图片或者内容侵犯了您的权益,请联系我们,我们会在确认后第一时间进行删除!

相关文档推荐

groupby multiple coords along a single dimension in xarray(在xarray中按单个维度的多个坐标分组)
Group by and Sum in Pandas without losing columns(Pandas中的GROUP BY AND SUM不丢失列)
Group by + New Column + Grab value former row based on conditionals(GROUP BY+新列+基于条件的前一行抓取值)
Groupby and interpolate in Pandas(PANDA中的Groupby算法和插值算法)
Pandas - Group Rows based on a column and replace NaN with non-null values(PANAS-基于列对行进行分组,并将NaN替换为非空值)
Grouping pandas DataFrame by 10 minute intervals(按10分钟间隔对 pandas 数据帧进行分组)