Metadata-Version: 2.1
Name: csvw
Version: 1.5.1
Summary: UNKNOWN
Home-page: https://github.com/cldf/csvw
Author: Robert Forkel
Author-email: forkel@shh.mpg.de
License: Apache 2.0
Description: # csvw
        
        [![Build Status](https://travis-ci.org/cldf/csvw.svg?branch=master)](https://travis-ci.org/cldf/csvw)
        [![codecov](https://codecov.io/gh/cldf/csvw/branch/master/graph/badge.svg)](https://codecov.io/gh/cldf/csvw)
        [![Requirements Status](https://requires.io/github/cldf/csvw/requirements.svg?branch=master)](https://requires.io/github/cldf/csvw/requirements/?branch=master)
        [![PyPI](https://img.shields.io/pypi/v/csvw.svg)](https://pypi.org/project/csvw)
        
        
        CSV on the Web
        
        
        
        ## Links
        
        - GitHub: https://github.com/cldf/csvw
        - PyPI: https://pypi.org/project/csvw
        - Issue Tracker: https://github.com/cldf/csvw/issues
        
        
        ## Installation
        
        This package runs under Python 2.7, and 3.4+, use pip to install:
        
        ```bash
        $ pip install csvw
        ```
        
        
        ## Example
        
        
        ```python
        >>> import csvw
        >>> tg = csvw.TableGroup.from_file('tests/csv.txt-metadata.json')
        
        >>> tg.check_referential_integrity()
        >>> assert len(tg.tables) == 1
        
        >>> assert tg.tables[0] is tg.tabledict['csv.txt']
        >>> tg.tables[0].check_primary_key()
        
        >>> from collections import OrderedDict
        >>> row = next(tg.tables[0].iterdicts())
        >>> assert row == OrderedDict([('ID', 'first'), ('_col.2', 'line')])
        
        >>> assert len(list(tg.tables[0].iterdicts())) == 2
        ```
        
        
        ## Known limitations
        
        - We read **all** data which is specified as UTF-8 encoded using the 
          [`utf-8-sig` codecs](https://docs.python.org/3/library/codecs.html#module-encodings.utf_8_sig).
          Thus, if such data starts with `U+FEFF` this will be interpreted as [BOM](https://en.wikipedia.org/wiki/Byte_order_mark)
          and skipped.
        - Low level CSV parsing is delegated to the `csv` module in Python's standard library. Thus, if a `commentPrefix`
          is specified in a `Dialect` instance, this will lead to skipping rows where the first value starts
          with `commentPrefix`, even if the value was quoted.
        
        
        ## See also
        
        - https://www.w3.org/2013/csvw/wiki/Main_Page
        - https://github.com/CLARIAH/COW
        - https://github.com/CLARIAH/ruminator
        - https://github.com/bloomberg/pycsvw
        - https://github.com/frictionlessdata/goodtables-py
        - https://github.com/frictionlessdata/tableschema-py
        - https://github.com/theodi/csvlint.rb
        - https://github.com/ruby-rdf/rdf-tabular
        - https://github.com/rdf-ext/rdf-parser-csvw
        
        
        ## License
        
        This package is distributed under the [Apache 2.0 license](https://opensource.org/licenses/Apache-2.0).
        
Keywords: csv w3c
Platform: any
Classifier: Development Status :: 4 - Beta
Classifier: Intended Audience :: Developers
Classifier: Intended Audience :: Science/Research
Classifier: License :: OSI Approved :: Apache Software License
Classifier: Operating System :: OS Independent
Classifier: Programming Language :: Python :: 2
Classifier: Programming Language :: Python :: 2.7
Classifier: Programming Language :: Python :: 3
Classifier: Programming Language :: Python :: 3.4
Classifier: Programming Language :: Python :: 3.5
Classifier: Programming Language :: Python :: 3.6
Requires-Python: >=2.7,!=3.0.*,!=3.1.*,!=3.2.*,!=3.3.*
Description-Content-Type: text/markdown
Provides-Extra: dev
Provides-Extra: test
