Skip to main content

Backport of Python 3 csv module

Project description

Latest Version https://travis-ci.org/ryanhiebert/backports.csv.svg?branch=master Join the chat at https://gitter.im/ryanhiebert/backports.csv Requirements Status

The API of the csv module in Python 2 is drastically different from the csv module in Python 3. This is due, for the most part, to the difference between str in Python 2 and Python 3.

The semantics of Python 3’s version are more useful because they support unicode natively, while Python 2’s csv does not.

Installation

pip install backports.csv

Usage

First make sure you’re starting your file off right:

from backports import csv

Then be careful with your files to handle the encoding. If you’re working with a binary file-like object, io.TextIOWrapper can be very helpful. If you’re dealing with a file, you can just use io.open instead of Python 2’s open builtin, and it works just like Python 3’s builtin open.

from backports import csv
import io

def read_csv(filename):
    with io.open(filename, newline='', encoding='utf-8') as f:
        for row in csv.reader(f):
            yield row

def write_csv(filename, rows):
    with io.open(filename, 'w', newline='', encoding='utf-8') as f:
        writer = csv.writer(f)
        for row in rows:
            writer.writerow(row)

Note: It should always be safe to specify newline='', since the csv module does its own (universal) newline handling.

1.0.5 (2017-05-29)

  • Fix bug in README example. (#22) - thanks to @tantale for the bug report

  • Allow None as quotechar when using QUOTE_NONE. (#23) - thanks to @thanatos for the bug report

1.0.4 (2017-02-17)

  • Return write value from writerow. (#20) - thanks to @therg

1.0.3 (2017-01-23)

  • Add LICENSE file (#18).

1.0.2 (2016-09-15)

  • Avoid quoting any numeric types when using QUOTE_NONNUMERIC. - thanks to @torfsen for the bug report

1.0.1 (2016-02-11)

  • Better error messages for invalid dialects. - thanks to @kengruven for the bug report

1.0 (2016-02-11)

  • Initial Release

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

backports.csv-1.0.5.tar.gz (12.1 kB view details)

Uploaded Source

Built Distribution

backports.csv-1.0.5-py2.py3-none-any.whl (13.2 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file backports.csv-1.0.5.tar.gz.

File metadata

File hashes

Hashes for backports.csv-1.0.5.tar.gz
Algorithm Hash digest
SHA256 8c421385cbc6042ba90c68c871c5afc13672acaf91e1508546d6cda6725ebfc6
MD5 81e6ace26f9a37f5c45b9acb33e808bd
BLAKE2b-256 6a0b2071ad285e87dd26f5c02147ba13abf7ec777ff20416a60eb15ea204ca76

See more details on using hashes here.

File details

Details for the file backports.csv-1.0.5-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for backports.csv-1.0.5-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 d3b0cefaaca92be3d2d4ceec140827cae1d871da7fff5db70697d72328357d65
MD5 2b3dc8b5ca0a6f50ed50595a074ed870
BLAKE2b-256 23010b1fce3fd8199fe32338dc66747baad52c7183b7f587128bc77cefde0620

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page