Skip to main content

Python consumer for the WPPBAV Fount API.

Project description

BAV API Python SDK

CI status coverage 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.8.0.tar.gz (32.5 kB view details)

Uploaded Source

Built Distribution

wpp_bavapi-0.8.0-py3-none-any.whl (30.6 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for wpp-bavapi-0.8.0.tar.gz
Algorithm Hash digest
SHA256 7e55c6933977104569914f676e945d7faef4507d6df902d38167ce8cf4bc3724
MD5 0b78326c116fc2750ede7ffe702756ff
BLAKE2b-256 bd5031793b06978c9cf7fdcb2c804549ddd9201135f13681d213c7c98644f5e5

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for wpp_bavapi-0.8.0-py3-none-any.whl
Algorithm Hash digest
SHA256 dc4d5045fa2c4c391d68fde417ffabb4583cf383cdc527fb0ce98eaf76a52165
MD5 f68f23fc99e82be1aec6a73a0044f156
BLAKE2b-256 98a6ce6a2bee73914e71d045df9e047bc49e4eeb65916bc4323daa91a0da42c9

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