Skip to main content

Python consumer for the WPPBAV Fount API.

Project description

BAV API Python SDK

CI status coverage release status docs status PyPI PyPI - Python Version

bavapi is a Python SDK for the WPP BAV API.

It is published on PyPI as wpp-bavapi.

With bavapi you can access the full BAV data catalog, the largest and most comprehensive database of brand data in the world.

Queries are validated automatically thanks to pydantic and retrieved asynchronously via the httpx package.

For more information about the API, go to the WPPBAV Developer Hub.

Prerequisites

bavapi requires Python 3.8 or higher to run.

If you don't have Python installed, you can find it from the official website or via Anaconda.

You will also need a BAV API token. For more information, go to the Authentication section of the API documentation.

Dependencies

  • httpx >= 0.20
  • nest-asyncio >= 1.5.6
  • pandas >= 0.16.2
  • pydantic >= 2.0
  • tqdm >= 4.62
  • typing-extensions >= 3.10 for Python < 3.10

Installation

bavapi can be installed using pip:

pip install wpp-bavapi

Installing from source

To install from source, clone the GitHub repository into your local machine:

git clone https://github.com/wppbav/bavapi-sdk-python.git

Go into the cloned directory and install bavapi:

cd bavapi-sdk-python
pip install .

Usage

Once you have acquired a token, you can start using this library directly in python or in a Jupyter Notebook:

>>> import bavapi
>>> result = bavapi.brands("TOKEN", name="Swatch")  # Replace `"TOKEN"` with your BAV API token
>>> result
sector_id sector_name id name ...
0 233 Apparel & Accessories 8635 Swatch ...
... ... ... ... ... ...

Features

  • Support for all endpoints in the Fount API. Extended support for the audiences, brands, brandscape-data and studies endpoints.
    • Other endpoints are available via the raw_query functions and methods.
  • Validates query parameters are of the correct types.
    • Provides type hints for better IDE support.
  • Retrieve multiple pages of data simultaneously.
    • Monitors and prevents exceeding API rate limit.
  • Both synchronous and asynchronous APIs for accessing BAV data.

Documentation

Read more about bavapi in the documentation.

Issues

Please file an issue on GitHub here.

Contributing

Please see the Contributing section of the documentation 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

wpp-bavapi-0.9.0.tar.gz (33.6 kB view details)

Uploaded Source

Built Distribution

wpp_bavapi-0.9.0-py3-none-any.whl (31.6 kB view details)

Uploaded Python 3

File details

Details for the file wpp-bavapi-0.9.0.tar.gz.

File metadata

  • Download URL: wpp-bavapi-0.9.0.tar.gz
  • Upload date:
  • Size: 33.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for wpp-bavapi-0.9.0.tar.gz
Algorithm Hash digest
SHA256 ff5c7961d04068a860f90f110487b2864663d75614ce4e89df11358dfa772a17
MD5 523425a1ba73025ca81fb5af70b79a9b
BLAKE2b-256 cb84ed16009c1779bdaf77f96300f8dea10d0a3a4e600c161a44e2d9d63d56c7

See more details on using hashes here.

File details

Details for the file wpp_bavapi-0.9.0-py3-none-any.whl.

File metadata

  • Download URL: wpp_bavapi-0.9.0-py3-none-any.whl
  • Upload date:
  • Size: 31.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for wpp_bavapi-0.9.0-py3-none-any.whl
Algorithm Hash digest
SHA256 50158ff52f7b24e4e2075afa3e3c1fc05e906a18054490d3a5745b9bdb503944
MD5 b9653c2135e36f7b3993b6e3a00caad8
BLAKE2b-256 1499783c942626655becd5c16a13838a2918ecf459c418d9dd2827f0c8ea2eac

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