Skip to content

Latest commit

 

History

History
118 lines (89 loc) · 4.37 KB

README.md

File metadata and controls

118 lines (89 loc) · 4.37 KB

#The googleads Python client library

This client library simplifies accessing Google's SOAP Ads APIs - AdWords, DoubleClick Ad Exchange SOAP, DoubleClick for Advertisers, and DoubleClick for Publishers. The library provides easy ways to store your authentication and create SOAP web service clients. It also contains example code to help you get started integrating with our APIs.

##How do I get started? ####Installing the library Install or update the library from PyPI. If you're using pip, this is as easy as:

$ pip install [--upgrade] googleads

If you don't want to install directly from PyPI, you can download the library as a tarball and then install it manually. The download can be found here: https://pypi.python.org/pypi/googleads Navigate to the directory that contains your downloaded unzipped client library and run the "setup.py" script to install the "googleads" module.

$ python setup.py build install

You can find code examples in the git repo and in the library's releases within the examples folder.

####Where can I find the pydocs? Our pydocs are hosted at: http://googleads.github.io/googleads-python-lib

####Caching authentication information It is possible to cache your API authentication information. The library includes a sample file showing how to do this named googleads.yaml. Fill in the fields for the API you plan to use. The library's LoadFromStorage methods default to looking for a file with this name in your home directory, but you can pass in a path to any file with the correct yaml contents.

# Use the default location - your home directory:
adwords_client = adwords.AdWordsClient.LoadFromStorage()

# Alternatively, pass in the location of the file:
dfp_client = dfp.DfpClient.LoadFromStorage('C:\My\Directory\googleads.yaml')

##Where do I submit bug reports and/or feature requests?

Use the issue tracker at: https://github.com/googleads/googleads-python-lib/issues

Make sure to subscribe to our Google Plus page for API change announcements and other news:

https://plus.google.com/+GoogleAdsDevelopers

##How do I log SOAP interactions? The library uses Python's built in logging framework. If you wish to log your SOAP interactions to stdout, you can do the following:

logging.basicConfig(level=logging.INFO)
logging.getLogger('suds.transport').setLevel(logging.DEBUG)

If you wish to log to a file, you'll need to attach a log handler to this source which is configured to write the output to a file.

##I'm familiar with suds. Can I use suds features with this library? Yes, you can. The services returned by the client.GetService() functions all have a reference to the underlying suds client stored in the suds_client attribute. You can retrieve the client and use it in familiar ways:

client = AdWordsClient.LoadFromStorage()
campaign_service = client.GetService('CampaignService')
suds_client = campaign_service.suds_client

campaign = suds_client.factory.create('Campaign')
# Set any attributes on the campaign object which you need.
campaign.name = 'My Campaign'
campaign.status = 'PAUSED'

operation = suds_client.factory.create('CampaignOperation')
operation.operator = 'ADD'
operation.operand = campaign

# The service object returned from the client.GetService() call accepts suds
# objects and will set the SOAP and HTTP headers for you.
campaign_service.mutate([operation])

# Alternatively, if you wish to set the headers yourself, you can use the
# suds_client.service directly.
soap_header = suds_client.factory.create('SoapHeader')
soap_header.clientCustomerId = client.client_customer_id
soap_header.developerToken = client.developer_token
soap_header.userAgent = client.user_agent

suds_client.set_options(
    soapheaders=soap_header,
    headers=client.oauth2_client.CreateHttpHeader())

suds_client.service.mutate([operation])

##External Dependencies:

- oauthlib             -- http://pypi.python.org/pypi/oauthlib/
- suds-jurko           -- http://pypi.python.org/pypi/suds-jurko/
- pytz                 -- https://pypi.python.org/pypi/pytz
- pyYAML               -- http://pypi.python.org/pypi/pyYAML/
- mock                 -- http://pypi.python.org/pypi/mock
                          (only needed to run unit tests)
- pyfakefs             -- https://pypi.python.org/pypi/pyfakefs
                          (only needed to run unit tests)

##Authors: [email protected] (Joseph DiLallo)