Python wrapper for the Amazon Advertising API
Project description
PYTHON-AMAZON-AD-API
Amazon's Advertising API
A python 3 wrapper to access Amazon's Advertising API with an easy-to-use interface.
Install
pip install python-amazon-ad-api
Donate
If you find this project is useful consider donating or sponsor it to keep on going on it, thank you.
Overview
You need obtain your own credentials with Amazon that may include an amazon developer account and access as seller or vendor. Please view the checklist of Amazon Ads API onboarding overview
Code Credentials
You can use your credentials as follows passing it to the client as a dict. Please review the full documentation to see all posibilities to include your credentials.
from ad_api.api import sponsored_products
my_credentials = dict(
refresh_token='your-refresh_token',
client_id='your-client_id',
client_secret='your-client_secret',
profile_id='your-profile_id',
)
result=sponsored_products.Campaigns(credentials=my_credentials).list_campaigns()
YAML Credentials
Use a credentials.yml file with your credentials for more convenience and manage diferent accounts or profiles. Amazon requires one profile per marketplace so it is helpful to keep all in one file and switch directly from the code, using the account.
Create a file credentials.yml
version: '1.0'
default:
refresh_token: 'your-refresh-token'
client_id: 'your-client-id'
client_secret: 'your-client-secret'
profile_id: 'your-profile-id'
germany:
refresh_token: 'other-refresh-token'
client_id: 'other-client-id'
client_secret: 'other-client-secret'
profile_id: 'other-profile-id'
Python code
from ad_api.api import sponsored_products
# Leave empty will use the 'default' account
result=sponsored_products.Campaigns().list_campaigns()
# will use germany account data
result=sponsored_products.Campaigns(account="germany").list_campaigns()
Search path for credentials.yml
- macOS and Other Unix:
~/.config/python-ad-api
- Windows:
%APPDATA%\python-ad-api
where the APPDATA environment variable falls back to%HOME%\AppData\Roaming
if undefined
Marketplaces
Marketplaces are used to define basically the API endpoints Amazon need to use depending on the regions, by default it will use EU so if you are using one of the marketplaces that are under the Europe (EU). Covers UK, FR, IT, ES, DE, NL, AE, SE, PL, and TR marketplaces you can skip. If you are using either North America (NA) or Far East (FE), you will need import from base and pass the marketplace as follows:
from ad_api.api import sponsored_products
from ad_api.base import Marketplaces
# You can pass NA or US, CA, MX or BR for North America and JP, AU or SG for Far East
result=sponsored_products.Campaigns(marketplace=Marketplaces.NA).list_campaigns()
Exceptions
You can use a try except statement when you call the API and catch exceptions if some problem ocurred:
from ad_api.api import sponsored_products
from ad_api.base import AdvertisingApiException
try:
result = sponsored_products.Campaigns().get_campaign_extended(
campaignId=campaign_id
)
logging.info(result)
except AdvertisingApiException as error:
logging.info(error)
Debug
Use debug=True if you want see some logs like the header you submit to the api endpoint, the method and path used among the params and the data submitted if any, to trace some possible errors.
from ad_api.api import sponsored_products
from ad_api.base import AdvertisingApiException
try:
result = sponsored_products.Campaigns(debug=True).get_campaign_extended(
campaignId=campaign_id
)
logging.info(result)
except AdvertisingApiException as error:
logging.info(error)
import logging
from ad_api.api import Profiles
from ad_api.base import AdvertisingApiException
logging.basicConfig(
level=logging.DEBUG,
format="%(asctime)s:%(levelname)s:%(message)s"
)
def register_assistant(value: str):
logging.info("-------------------------------------")
logging.info("Profiles > register_assistant(%s)" % value)
logging.info("-------------------------------------")
try:
result = Profiles(debug=True).register_assistant(
country_code=value
)
logging.info(result)
except AdvertisingApiException as error:
logging.info(error)
if __name__ == '__main__':
amz_country_code = "ES"
register_assistant(amz_country_code)
Or you could do with a curl command, note the {"countryCode":"ES"} that refers to the marketplace you will operate.
curl \
-X PUT \
-H "Content-Type:application/json" \
-H "Authorization: Bearer Your-Token \
-H "Amazon-Advertising-API-ClientId: your-client-id" \
--data '{"countryCode":"ES"}' \
https://advertising-api-test.amazon.com/v2/profiles/register
Modules Available Common Resources
- Profiles
- Manager Accounts
- Portfolios
- Invoices
- Billing
- Audiences
- Change History open Beta
- Creative Assets open Beta
- Elegibility
- Insights
- Localization
- Product Selector
- Validation Configurations
- Tactical recommendations beta
- Exports
Amazon Attribution open beta
Brand Metrics open beta
Advertising Test Account
Modules Available Sponsored Products 2.0
Warning: [PLANNED DEPRECATION 6/30/2023] There is a new version 3 of Sponsored Product API, please check the migration guide.
Modules Available Sponsored Products 3.0
- ThemeBased Bid Recommendation
- Keyword Recommendations
- Keywords
- Negative Keywords
- Product Targeting
- Campaign Optimization
- Budget Rules
- Product Ads
- Negative Targeting Clauses
- Campaign Negative Targeting Clauses
- Budget recommendations and missed opportunities
- Budget Rules Recommendation
- Campaigns
- Ad Groups
- Consolidated Recommendations
- Campaign Negative Keywords
- Product Recommendations
- Budget Usage
- Reports
Modules Available Sponsored Brands 3.0
- Campaigns
- Ad Groups
- Keywords
- Negative Keywords
- Product Targeting
- Negative Product Targeting
- Targeting Recommendations
- Bid Recommendations
- Stores
- Landing Page Asins
- Media
- Brands
- Moderation
- Reports
- Snapshots
Modules Available Sponsored Brands 4.0
Modules Available Sponsored Display
- Campaigns
- Ad Groups
- Reports
- Product Ads
- Targets
- Negative Targets
- Targets Recommendations
- Bid Recommendations
- Creatives
- Brand Safety List
- Budget Rules
- Campaigns Budget Usage
- Forecasts
- Recommendations
Modules Available DSP
Simple Example Usage Campaigns with Credentials
import logging
from ad_api.base import AdvertisingApiException
from ad_api.api.sp import Campaigns
logging.basicConfig(
level=logging.DEBUG,
format="%(asctime)s:%(levelname)s:%(message)s"
)
credentials = dict(
refresh_token='your-refresh_token',
client_id='your-client_id',
client_secret='your-client_secret',
profile_id='your-profile_id',
)
try:
states = 'enabled'
res = Campaigns(credentials=credentials, debug=True).list_campaigns_extended(
stateFilter=states
)
campaigns = res.payload
for campaign in campaigns:
logging.info(campaign)
logging.info(len(campaigns))
except AdvertisingApiException as error:
logging.info(error)
API NOTICE
This API is based on the API Client created by @saleweaver but adapted to amazon advertising authentication requeriments
DISCLAIMER
We are not affiliated with Amazon but they used our api :)
LICENSE
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file python_amazon_ad_api-0.6.2.tar.gz
.
File metadata
- Download URL: python_amazon_ad_api-0.6.2.tar.gz
- Upload date:
- Size: 96.4 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 5711b6c2023b9fffc5765ae7c8fe7086c67b87394e0c2f3102fc97425e2aa86b |
|
MD5 | e9fbaa014657f99fe1304971a7444fd6 |
|
BLAKE2b-256 | f48aa5babcae02d4b1bca4fa9b3df3777f6cd253d69a45ba83b408130e5cf87e |
File details
Details for the file python_amazon_ad_api-0.6.2-py3-none-any.whl
.
File metadata
- Download URL: python_amazon_ad_api-0.6.2-py3-none-any.whl
- Upload date:
- Size: 158.7 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/5.1.1 CPython/3.9.20
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 35e4becee1819b53b884778be5dd3af46b59c0f04e0ccb4362646cc61855b828 |
|
MD5 | 144c820663ff912a6cec39331974bb35 |
|
BLAKE2b-256 | 6770f2ca6048c42c5a9f4c539cad69ad4cc17387a40a00e7024587003cde2253 |