Skip to main content

A Library to interact with the Impresso API

Project description

Impresso Python Library

PyPI version PyPI - License

Impresso is a library designed to facilitate interaction with the Impresso dataset. It offers a comprehensive set of classes for API interaction and a variety of tools to streamline data manipulation and analysis.

You can find the full documentation at https://impresso.github.io/impresso-py/.

Installation

With pip:

pip install impresso

Usage

See sample notebooks in the examples/notebooks directory or examples available in the Impresso Datalab.

Extending the library

We use Poetry for dependency management. To install the package in development mode, run the following command in the root directory of the project:

poetry install

This will create and activate a virtual environment with all the dependencies installed.

Testing

poetry run pytest

Linting

poetry run pytest
poetry run flake8 impresso tests
poetry run mypy impresso tests

OpenAPI client generation

The OpenAPI client is generated using the OpenAPI Generator. Pydantic models from the OpenAPI spec are generated too. The following command generates both the client code and the pydantic models. Make sure the Public API is running on localhost.:

poetry run generate-client

Whenever the OpenAPI spec of the Impresso Public API changes, the client code and the pydantic models must be regenerated.

Protobuf

Filters used in some endpoints are serialized as a protobuf message. The protobuf message is defined in the impresso-jscommons project. The python code is generated using the protoc compiler (must be installed separately). The following command generates the python code for the protobuf message:

poetry run generate-protobuf

About Impresso

Impresso project

Impresso - Media Monitoring of the Past is an interdisciplinary research project that aims to develop and consolidate tools for processing and exploring large collections of media archives across modalities, time, languages and national borders. The first project (2017-2021) was funded by the Swiss National Science Foundation under grant No. CRSII5_173719 and the second project (2023-2027) by the SNSF under grant No. CRSII5_213585 and the Luxembourg National Research Fund under grant No. 17498891.

Copyright

Copyright (C) 2024 The Impresso team.

License

This program is provided as open source under the GNU Affero General Public License v3 or later.


Impresso Project Logo

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

impresso-0.9.17.tar.gz (116.5 kB view details)

Uploaded Source

Built Distribution

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

impresso-0.9.17-py3-none-any.whl (271.7 kB view details)

Uploaded Python 3

File details

Details for the file impresso-0.9.17.tar.gz.

File metadata

  • Download URL: impresso-0.9.17.tar.gz
  • Upload date:
  • Size: 116.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for impresso-0.9.17.tar.gz
Algorithm Hash digest
SHA256 4100ca0f42047ae6d8de2ab87a3e6d34076cf01c2292619a597819103337e3ea
MD5 5f432c3d66e3d0da14114ec4eaa62931
BLAKE2b-256 05854444a953f53aba68d1851b7dbe702e47b2f1cc8d6fcb93393335b9655789

See more details on using hashes here.

File details

Details for the file impresso-0.9.17-py3-none-any.whl.

File metadata

  • Download URL: impresso-0.9.17-py3-none-any.whl
  • Upload date:
  • Size: 271.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for impresso-0.9.17-py3-none-any.whl
Algorithm Hash digest
SHA256 53f24c35932fdd2185a76747b40b1e2ef61146ea77745ea0b48d1b6b8ea59aed
MD5 efe4dd544050ffedc0dbd0659c6ae106
BLAKE2b-256 2b57258e6c583abbac6c0aa21af0da75612912e5f667d6c407b988f006e40454

See more details on using hashes here.

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