Skip to main content

DataForSEO API documentation

Project description

OVERVIEW

This is a Python client providing you, as a developer, with a tool for obtaining the necessary data from DataForSEO APIs. You don't have to figure out how to make a request and process a response - all that is readily available in this client.

GitHub issues GitHub license

DataForSEO API uses REST technology for interchanging data between your application and our service. The data exchange is made through the widely used HTTP protocol, which allows using our API with almost any programming language.

Client contains 12 sections (aka APIs):

API Contains 2 types of requests:

  1. Live (Simple HTTP request/response message)
  2. Task-based (Requires sending a 'Task' entity to execute, waiting until the 'Task' status is ready, and getting the 'Task' result in a special endpoint. Usually, it is represented by 3 types of endpoints: 'TaskPost', 'TaskReady', and 'TaskGet') For more details - please follow here

YAML Spec

Our API description is based on the OpenAPI syntax in YAML format. The YAML file attached to the project here

Documentation

The documentation for code objects, formatted in Markdown (.md) is available here. Official documentation for DataForSEO API is available here.

Code generation

Code generated using the openapi generator cli

Install package from nuget.org

pip install dataforseo-client 

Examples of usage

Example of live request

from dataforseo_client import configuration as dfs_config, api_client as dfs_api_provider
from dataforseo_client.api.serp_api import SerpApi
from dataforseo_client.rest import ApiException
from dataforseo_client.models.serp_google_organic_live_advanced_request_info import SerpGoogleOrganicLiveAdvancedRequestInfo
from pprint import pprint

# Configure HTTP basic authorization: basicAuth
configuration = dfs_config.Configuration(username='USERNAME',password='PASSWORD')
with dfs_api_provider.ApiClient(configuration) as api_client:
    # Create an instance of the API class
    serp_api = SerpApi(api_client)

    try:

        api_response = serp_api.google_organic_live_advanced([SerpGoogleOrganicLiveAdvancedRequestInfo(
            language_name="English",
            location_name="United States",
            keyword="albert einstein"
        )])
        
        pprint(api_response)
    
    except ApiException as e:
        print("Exception: %s\n" % e)

Example of Task-Based request

from dataforseo_client import configuration as dfs_config, api_client as dfs_api_provider
from dataforseo_client.api.serp_api import SerpApi
from dataforseo_client.rest import ApiException
from dataforseo_client.models.serp_task_request_info import SerpTaskRequestInfo
from pprint import pprint
import asyncio
import time

# Configure HTTP basic authorization: basicAuth
configuration = dfs_config.Configuration(username='USERNAME',password='PASSWORD')

def GoogleOrganicTaskReady(id):
    result = serp_api.google_organic_tasks_ready()
    return any(any(xx.id == id for xx in x.result) for x in result.tasks)

with dfs_api_provider.ApiClient(configuration) as api_client:
    # Create an instance of the API class
    serp_api = SerpApi(api_client)

    try:

        task_post = serp_api.google_organic_task_post([SerpTaskRequestInfo(
            language_name="English",
            location_name="United States",
            keyword="albert einstein"
        )])

        task_id = task_post.tasks[0].id

        start_time = time.time()

        while GoogleOrganicTaskReady(task_id) is not True and (time.time() - start_time) < 60:
           asyncio.sleep(1) 

        api_response = serp_api.google_organic_task_get_advanced(id=task_id)
        
        pprint(api_response)
    
    except ApiException as e:
        print("Exception: %s\n" % e)

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

dataforseo_client-2.0.24.tar.gz (1.1 MB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

dataforseo_client-2.0.24-py3-none-any.whl (4.5 MB view details)

Uploaded Python 3

File details

Details for the file dataforseo_client-2.0.24.tar.gz.

File metadata

  • Download URL: dataforseo_client-2.0.24.tar.gz
  • Upload date:
  • Size: 1.1 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.12

File hashes

Hashes for dataforseo_client-2.0.24.tar.gz
Algorithm Hash digest
SHA256 5226217e67ff2c9022cceaff33d5c6c9fd72a12ffeae48f351d242a9cb011eb5
MD5 a22acaf9c1963606b7e961fb8236d1a1
BLAKE2b-256 48e1b68d0b277a543ccfdef6ac144ad80aebafc21765499768545b755ecca4f0

See more details on using hashes here.

Provenance

The following attestation bundles were made for dataforseo_client-2.0.24.tar.gz:

Publisher: publish.yaml on dataforseo/PythonClient

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file dataforseo_client-2.0.24-py3-none-any.whl.

File metadata

File hashes

Hashes for dataforseo_client-2.0.24-py3-none-any.whl
Algorithm Hash digest
SHA256 f183b41090ceb2f031d556522dbd15a7370fb166c49ba932b0791298334ba34d
MD5 458289c22b72443675e07f2ab5e3815a
BLAKE2b-256 216b4b27e87b8f8a49a6b22ebe10a9a1f6cb0bd67075930b022ddf9e32edcfbc

See more details on using hashes here.

Provenance

The following attestation bundles were made for dataforseo_client-2.0.24-py3-none-any.whl:

Publisher: publish.yaml on dataforseo/PythonClient

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page