Skip to main content

Utilities for extracting XML, HTML, CSV, XLSX, and RDF data with a common interface

Project description

I-analyzer Readers

Python package Documentation Status

ianalyzer-readers is a python module to extract data from XML, HTML, CSV, JSON, XLSX or RDF (Linked Data) files.

This module was originally created for I-analyzer, a web application that extracts data from a variety of datasets, indexes them and presents a search interface. To do this, we wanted a way to extract data from source files without having to write a new script "from scratch" for each dataset, and an API that would work the same regardless of the source file type.

The basic usage is that you will use the utilities in this package to create a "reader" class. You specify what your data looks like, and then call the documents() method of the reader to get an iterator of documents - where each document is a flat dictionary of key/value pairs.

Prerequisites

Requires Python 3.9 or later.

Contents

ianalyzer_readers contains the source code for the package. tests contains unit tests.

When to use this package

This package is not a replacement for more general-purpose libraries like csv or Beautiful Soup - it is a high-level interface on top of those libraries.

Our primary use for this package is to pre-process data for I-analyzer, but you may find other uses for it.

Using this package makes sense if you want to extract data in the shape that it is designed for (i.e., a list of flat dictionaries).

What we find especially useful is that all subclasses of Reader have the same interface - regardless of whether they are processing CSV, JSON, XML, HTML, RDF or XLSX data. That common interface is crucial in an application that needs to process corpora from different source types, like I-analyzer.

Usage

Typical usage of this package would be to make a custom Python class for a dataset from which you want to extract a list of documents. We call this a Reader. This package provides the base classes to structure readers, and provides extraction utilities for several file types.

For detailed usage documention and examples, visit ianalyzer-readers.readthedocs.io

If this site is unavailable, you can also generate the documentation site locally; see the contributing guide for insttructions.

Licence

This code is shared under an MIT licence. See LICENSE for more information.

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

ianalyzer_readers-0.3.2.tar.gz (23.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

ianalyzer_readers-0.3.2-py3-none-any.whl (25.7 kB view details)

Uploaded Python 3

File details

Details for the file ianalyzer_readers-0.3.2.tar.gz.

File metadata

  • Download URL: ianalyzer_readers-0.3.2.tar.gz
  • Upload date:
  • Size: 23.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for ianalyzer_readers-0.3.2.tar.gz
Algorithm Hash digest
SHA256 6a9822ba8e525576fad1687e9960b10e8daa8e5c4b2c5d87fe17e41b52d872cb
MD5 954b9ddecbeaaa70a52e05a7af5a38aa
BLAKE2b-256 64037fe8e55a89796957cab406f7a3ef1769c85fd215c8a608357c1a11c7cc3a

See more details on using hashes here.

Provenance

The following attestation bundles were made for ianalyzer_readers-0.3.2.tar.gz:

Publisher: release.yml on CentreForDigitalHumanities/ianalyzer-readers

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file ianalyzer_readers-0.3.2-py3-none-any.whl.

File metadata

File hashes

Hashes for ianalyzer_readers-0.3.2-py3-none-any.whl
Algorithm Hash digest
SHA256 f2f7f43e584d9317a3f9fc9fe29e9e4ea8d0238f3b2a3d760ac394b5385e004f
MD5 e3381ee7015c5695635e78c58af557f2
BLAKE2b-256 1823f3d01d790616d4b4fd9d43e64946791ca0c4dda06b814b92e675e7e2dd6d

See more details on using hashes here.

Provenance

The following attestation bundles were made for ianalyzer_readers-0.3.2-py3-none-any.whl:

Publisher: release.yml on CentreForDigitalHumanities/ianalyzer-readers

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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