Skip to content

A script for downloading performance and account structure from Criteo API

License

Notifications You must be signed in to change notification settings

project-a/criteo-performance-downloader

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

29 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Criteo Performance Downloader

A Python script for downloading performance data using the Criteo API to local files.

The mara Criteo performance pipeline can be, then, used for loading and transforming the downloaded data into a dimensional schema.

Resulting data

By default, it creates two data sets:

  1. Campaign Performance consists of measures such as impressions, clicks and cost. The script creates one file per day in a specified time rage:

     data/2016/10/30/criteo/campaign-performance-accountname-v2.json.gz
     data/2016/10/31/criteo/campaign-performance-accountname-v2.json.gz
    

    The resulting JSON files contain arrays of dictionaries per campaign:

     [
         {
             "campaignID": "1234567",
             "dateTimePosix": "1488240000",
             "dateTime": "2016-10-31",
             "click": "1630",
             "impressions": "61009",
             "CTR": "0.27",
             "revcpc": "0.44",
             "ecpm": "1.18",
             "cost": "717.20",
             "sales": "0",
             "convRate": "0.00",
             "orderValue": "0.00",
             "salesPostView": "0",
             "convRatePostView": "0.00",
             "orderValuePostView": "0.00",
             "costOfSale": "0.00",
             "overallCompetitionWin": "0.60",
             "costPerOrder": "0.00"
         },
     ..
     ]
    
  2. Account Structure information. This file is always overwritten by the script:

     data/criteo/criteo-account-structure-accountname-v2.json.gz
    

    The resulting JSON files contain arrays of dictionaries per campaign:

     [
         {
             "advertiserName": "Account Name",
             "partner": "criteo",
             "channel": "retargeting",
             "campaignID": 123456,
             "campaignName": "Lower Funnel 2016",
             "campaignBid": {
                 "cpaBid": null,
                 "cpcBid": {
                    "cpc": 0.76
                 },
                 "biddingStrategy": "Cpc"
             },
             "budgetID": 56789,
             "remainingDays": 6,
             "status": "RUNNING",
             "categoryBids": [],
             "platform": "",
             "currency": "EUR"
         },
     ..
     ]
    

Getting Started

Prerequisites

To use the Criteo Performance Downloader you have to create an API token to access the Criteo API. See Create a Criteo API Token for the necessary steps.

Installation

The Criteo Performance Downloader requires:

Python (>= 3.5)
pycriteo (>0.0.1)
click (>=6.0)

The easiest way to install criteo-downloader is using pip

pip install git+https://github.com/mara/criteo-performance-downloader.git --process-dependency-links

In case you want to install it in a virtual environment:

$ git clone git@github.com:mara/criteo-performance-downloader.git criteo_downloader
$ cd criteo_downloader
$ python3 -m venv .venv
$ .venv/bin/pip install . --process-dependency-links

Create a Criteo API Token

Note: Should you not be able to see the images, please deactivate your adblocker

Create an username, passoword and token. As described in Criteo API integration documentation.

Log into your Criteo Account and go to Manage -> Users. Create a new API token:

Generating Criteo API token

Usage

To run the Criteo Performance Downloader call download-criteo-performance-data with its config parameters:

$ download-criteo-performance-data \
--accounts accountname username passwort token \
--accounts accountname2 username2 passwort2 token2 \
--data_dir /tmp/criteo
--retry_timeout 10
--retry_attempts 3

About

A script for downloading performance and account structure from Criteo API

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages