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.10.0.tar.gz (36.4 kB view details)

Uploaded Source

Built Distribution

wpp_bavapi-0.10.0-py3-none-any.whl (33.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: wpp-bavapi-0.10.0.tar.gz
  • Upload date:
  • Size: 36.4 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.10.0.tar.gz
Algorithm Hash digest
SHA256 4132a42c716cef687aa4d401558f90bc97012c913d73ef33ebcf09de35498259
MD5 8cf292da7fc06b38c4c5e26ff12cc0a8
BLAKE2b-256 56b7907eefa8ab5982363d060e1099c12fc6359aa554444544f726a17325a01d

See more details on using hashes here.

File details

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

File metadata

  • Download URL: wpp_bavapi-0.10.0-py3-none-any.whl
  • Upload date:
  • Size: 33.9 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.10.0-py3-none-any.whl
Algorithm Hash digest
SHA256 7363de82d291c6d2c577c9bd75e8fcc4113f763571692ac72b650326944a225b
MD5 b949b949b092db3ddec44e6e0932b559
BLAKE2b-256 7bfbb8374d7c800f25a9cfa23940484b55f0e0b23c94f773025b60e8651c4c36

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