##// END OF EJS Templates
Add purging of client result cache to parallel.Client...
Add purging of client result cache to parallel.Client The new methods clear the cached values and free some memory. The whole thing is split into different methods to both clear the client and the hub side. Additionally fix some bugs in other parts of the code.

File last commit:

r7739:dff285da
r8409:5d7c7b8a
Show More
Capturing Output.ipynb
208 lines | 4.2 KiB | text/plain | TextLexer

Capturing Output with %%capture

One of IPython's new cell magics is %%capture, which captures stdout/err for a cell, and discards them or stores them in variables in your namespace.

In [ ]:
import sys

By default, it just swallows it up. This is a simple way to suppress unwanted output.

In [ ]:
%%capture
print 'hi, stdout'
print >> sys.stderr, 'hi, stderr'

If you specify a name, then stdout and stderr will be stored in an object in your namespace.

In [ ]:
%%capture captured
print 'hi, stdout'
print >> sys.stderr, 'hi, stderr'
In [ ]:
captured

Calling the object writes the output to stdout/err as appropriate.

In [ ]:
captured()
In [ ]:
captured.stdout
In [ ]:
captured.stderr

%%capture only captures stdout/err, not displaypub, so you can still do plots and use the display protocol inside %%capture

In [ ]:
%pylab inline
In [ ]:
%%capture wontshutup

print "setting up X"
x = np.linspace(0,5,1000)
print "step 2: constructing y-data"
y = np.sin(x)
print "step 3: display info about y"
plt.plot(x,y)
print "okay, I'm done now"
In [ ]:
wontshutup()

And you can selectively disable capturing stdout or stderr by passing --no-stdout/err.

In [ ]:
%%capture cap --no-stderr
print 'hi, stdout'
print >> sys.stderr, "hello, stderr"
In [ ]:
cap.stdout
In [ ]:
cap.stderr