Kaydet (Commit) fb8b0673 authored tarafından R David Murray's avatar R David Murray

Really merge #7198

Changeset ab27f16f707a was messed up by a rebase (as were
959f666470cc and 9d1b1a95bc8f) and the patch only got applied
to default.
...@@ -52,7 +52,7 @@ The :mod:`csv` module defines the following functions: ...@@ -52,7 +52,7 @@ The :mod:`csv` module defines the following functions:
*csvfile* can be any object which supports the :term:`iterator` protocol and returns a *csvfile* can be any object which supports the :term:`iterator` protocol and returns a
string each time its :meth:`!__next__` method is called --- :term:`file objects string each time its :meth:`!__next__` method is called --- :term:`file objects
<file object>` and list objects are both suitable. If *csvfile* is a file object, <file object>` and list objects are both suitable. If *csvfile* is a file object,
it should be opened with ``newline=''``. [#]_ An optional it should be opened with ``newline=''``. [1]_ An optional
*dialect* parameter can be given which is used to define a set of parameters *dialect* parameter can be given which is used to define a set of parameters
specific to a particular CSV dialect. It may be an instance of a subclass of specific to a particular CSV dialect. It may be an instance of a subclass of
the :class:`Dialect` class or one of the strings returned by the the :class:`Dialect` class or one of the strings returned by the
...@@ -79,7 +79,8 @@ The :mod:`csv` module defines the following functions: ...@@ -79,7 +79,8 @@ The :mod:`csv` module defines the following functions:
Return a writer object responsible for converting the user's data into delimited Return a writer object responsible for converting the user's data into delimited
strings on the given file-like object. *csvfile* can be any object with a strings on the given file-like object. *csvfile* can be any object with a
:func:`write` method. An optional *dialect* :func:`write` method. If csvfile is a file object, it should be opened with
newline='' [1]_. An optional *dialect*
parameter can be given which is used to define a set of parameters specific to a parameter can be given which is used to define a set of parameters specific to a
particular CSV dialect. It may be an instance of a subclass of the particular CSV dialect. It may be an instance of a subclass of the
:class:`Dialect` class or one of the strings returned by the :class:`Dialect` class or one of the strings returned by the
...@@ -96,7 +97,7 @@ The :mod:`csv` module defines the following functions: ...@@ -96,7 +97,7 @@ The :mod:`csv` module defines the following functions:
A short usage example:: A short usage example::
>>> import csv >>> import csv
>>> spamWriter = csv.writer(open('eggs.csv', 'w'), delimiter=' ', >>> spamWriter = csv.writer(open('eggs.csv', 'w', newline=''), delimiter=' ',
... quotechar='|', quoting=csv.QUOTE_MINIMAL) ... quotechar='|', quoting=csv.QUOTE_MINIMAL)
>>> spamWriter.writerow(['Spam'] * 5 + ['Baked Beans']) >>> spamWriter.writerow(['Spam'] * 5 + ['Baked Beans'])
>>> spamWriter.writerow(['Spam', 'Lovely Spam', 'Wonderful Spam']) >>> spamWriter.writerow(['Spam', 'Lovely Spam', 'Wonderful Spam'])
...@@ -427,7 +428,7 @@ The simplest example of reading a CSV file:: ...@@ -427,7 +428,7 @@ The simplest example of reading a CSV file::
Reading a file with an alternate format:: Reading a file with an alternate format::
import csv import csv
with open('passwd') as f: with open('passwd', newline='') as f:
reader = csv.reader(f, delimiter=':', quoting=csv.QUOTE_NONE) reader = csv.reader(f, delimiter=':', quoting=csv.QUOTE_NONE)
for row in reader: for row in reader:
print(row) print(row)
...@@ -435,7 +436,7 @@ Reading a file with an alternate format:: ...@@ -435,7 +436,7 @@ Reading a file with an alternate format::
The corresponding simplest possible writing example is:: The corresponding simplest possible writing example is::
import csv import csv
with open('some.csv', 'w') as f: with open('some.csv', 'w', newline='') as f:
writer = csv.writer(f) writer = csv.writer(f)
writer.writerows(someiterable) writer.writerows(someiterable)
...@@ -457,7 +458,7 @@ Registering a new dialect:: ...@@ -457,7 +458,7 @@ Registering a new dialect::
import csv import csv
csv.register_dialect('unixpwd', delimiter=':', quoting=csv.QUOTE_NONE) csv.register_dialect('unixpwd', delimiter=':', quoting=csv.QUOTE_NONE)
with open('passwd') as f: with open('passwd', newline='') as f:
reader = csv.reader(f, 'unixpwd') reader = csv.reader(f, 'unixpwd')
A slightly more advanced use of the reader --- catching and reporting errors:: A slightly more advanced use of the reader --- catching and reporting errors::
...@@ -482,7 +483,7 @@ done:: ...@@ -482,7 +483,7 @@ done::
.. rubric:: Footnotes .. rubric:: Footnotes
.. [#] If ``newline=''`` is not specified, newlines embedded inside quoted fields .. [1] If ``newline=''`` is not specified, newlines embedded inside quoted fields
will not be interpreted correctly. It should always be safe to specify will not be interpreted correctly, and on platforms that use ``\r\n`` linendings
``newline=''``, since the csv module does its own universal newline handling on write an extra `\\r` will be added. It should always be safe to specify
on input. ``newline=''``, since the csv module does its own (universal) newline handling.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment