diff options
author | Benjamin Peterson <benjamin@python.org> | 2009-06-14 18:41:18 (GMT) |
---|---|---|
committer | Benjamin Peterson <benjamin@python.org> | 2009-06-14 18:41:18 (GMT) |
commit | 995bb47c1729bb7e62649c5697f5e148e0ec591f (patch) | |
tree | 7909a91044d4d672c7a8acc0ee8020da65df4bc2 | |
parent | 6a38ceda034df6b0be6ed41edbdc28f76e7e7805 (diff) | |
download | cpython-995bb47c1729bb7e62649c5697f5e148e0ec591f.zip cpython-995bb47c1729bb7e62649c5697f5e148e0ec591f.tar.gz cpython-995bb47c1729bb7e62649c5697f5e148e0ec591f.tar.bz2 |
rewrite binary std streams part; note that detach()/buffer will not always work
-rw-r--r-- | Doc/library/sys.rst | 11 |
1 files changed, 8 insertions, 3 deletions
diff --git a/Doc/library/sys.rst b/Doc/library/sys.rst index 1278a7c..ba22dc3 100644 --- a/Doc/library/sys.rst +++ b/Doc/library/sys.rst @@ -784,13 +784,18 @@ always available. The standard streams are in text mode by default. To write or read binary data to these, use the underlying binary buffer. For example, to write bytes to :data:`stdout`, use ``sys.stdout.buffer.write(b'abc')``. Using - :meth:`io.TextIOBase.detach` streams can be made binary by default. For - example, this function sets all the standard streams to binary:: + :meth:`io.TextIOBase.detach` streams can be made binary by default. This + function sets :data:`stdin` and :data:`stdout` to binary:: def make_streams_binary(): sys.stdin = sys.stdin.detach() sys.stdout = sys.stdout.detach() - sys.stderr = sys.stderr.detach() + + Note that the streams can be replaced with objects (like + :class:`io.StringIO`) that do not support the + :attr:`~io.BufferedIOBase.buffer` attribute or the + :meth:`~io.BufferedIOBase.detach` method and can raise :exc:`AttributeError` + or :exc:`io.UnsupportedOperation`. .. data:: __stdin__ |