Skip to main content

LangChain integration for Talor SERP API — 33 search engines in one tool

Project description

langchain-talor-serp

LangChain integration for TalorData's SERP APIs

PyPI version Python versions License: MIT

InstallationQuick StartToolsResources

LangChain integration for the Talor SERP API.

This package provides:

  • TalorSerpAPIWrapper for direct sync and async API access
  • TalorSerpTool for creating LangChain tools
  • bundled engine schemas for 30+ search engines
  • support for search, history, and statistics endpoints

Overview

langchain-talor-serp provides LangChain tools for TalorData's SERP APIs, enabling your AI agents to:

  • Search - Query search engines with geo-targeting and language customization
  • Inspect engines - Discover supported engines and engine-specific parameters
  • Query history - Fetch SERP request history with filters
  • View statistics - Retrieve usage statistics by date range and engine

Installation

pip install langchain-talor-serp

Quick start

1. Get your API key

Sign up at TalorData and get your API key from the dashboard.

2. Set up authentication

import os
os.environ["TALOR_API_KEY"] = "your-token"

3. Modern agent usage

from langchain_talor_serp import TalorSerpTool
from langchain_openai import ChatOpenAI

llm = ChatOpenAI(model="gpt-4o-mini", temperature=0)
tool = TalorSerpTool.from_env()

# Tool calling without langchain_classic agents
model_with_tools = llm.bind_tools([tool])
response = model_with_tools.invoke("Search for the latest LangChain news")
print(response)

4. Search tool

from langchain_talor_serp import TalorSerpTool

search_tool = TalorSerpTool.from_env()

result = search_tool.invoke({
    "query": "LangChain tutorial",
    "engine": "google",
    "params": {
        "gl": "us",
        "hl": "en",
        "device": "desktop",
    },
})

print(result)

Search parameters:

  • query: required search query text
  • engine: optional engine key such as google, google_news, google_images, bing, duckduckgo
  • params: optional engine-specific parameter object
  • common params fields include gl, hl, device, location, and no_cache
  • use talor_serp_list_engines to inspect detailed parameters for a specific engine

params also accepts a JSON string when returned by a model tool call, for example:

result = search_tool.invoke({
    "query": "LangChain tutorial",
    "engine": "google",
    "params": "{\"hl\": \"zh-CN\", \"gl\": \"cn\"}",
})

5. History tool

from langchain_talor_serp import TalorSerpTool

history_tool = TalorSerpTool.history_from_env()

result = history_tool.invoke({
    "page": 1,
    "page_size": 20,
    "search_query": "langchain",
    "search_engine": "google",
    "status": "success",
    "timezone": "Asia/Shanghai",
})

print(result)

History parameters:

  • page: page number, default 1
  • page_size: page size, default 20
  • search_query: optional keyword filter
  • search_engine: optional engine filter such as google or bing
  • status: all, success, or error
  • start_time: optional unix timestamp in seconds
  • end_time: optional unix timestamp in seconds
  • timezone: optional timezone header such as Asia/Shanghai or +08:00

6. Statistics tool

from langchain_talor_serp import TalorSerpTool

statistics_tool = TalorSerpTool.statistics_from_env()

result = statistics_tool.invoke({
    "start_date": "2026-06-01",
    "end_date": "2026-06-05",
    "engines": "google,bing",
    "timezone": "+08:00",
})

print(result)

Statistics parameters:

  • start_date: required, format YYYY-MM-DD
  • end_date: required, format YYYY-MM-DD
  • engines: optional comma-separated engine keys such as google,bing
  • timezone: optional timezone offset such as +08:00

7. Bind multiple tools

from langchain_talor_serp import TalorSerpTool
from langchain_openai import ChatOpenAI

llm = ChatOpenAI(model="gpt-4o-mini", temperature=0)
tools = TalorSerpTool.tools_from_env()

model_with_tools = llm.bind_tools(tools)
response = model_with_tools.invoke("Show my SERP usage statistics for 2026-06-01 to 2026-06-05")
print(response)

bind_tools() only lets the model generate tool_calls. To actually execute the selected tool, either:

  • call tool.invoke(...) directly, or
  • use an agent workflow that executes tools automatically

Tools

  • talor_serp_search - search the web with engine-specific parameters
  • talor_serp_list_engines - inspect supported engines and detailed parameter schemas
  • talor_serp_history - query historical SERP requests
  • talor_serp_statistics - query usage statistics for a date range

Compatibility note

If you are using modern package versions such as:

  • langchain-core>=1.0
  • langchain-classic>=1.0
  • langchain-openai>=1.0

avoid langchain_classic.agents.create_openai_functions_agent() and other legacy initialize_agent / AgentType.OPENAI_FUNCTIONS flows with chat models. Those classic agent paths call llm.invoke(..., callbacks=...), while modern BaseChatModel.invoke() forwards callbacks through config, which can lead to:

TypeError: BaseLLM.generate_prompt() got multiple values for keyword argument 'callbacks'

Use one of these approaches instead:

  • llm.bind_tools([tool]) for direct tool calling
  • langchain.agents.create_agent(...) for new agent workflows
  • agent.invoke(...) instead of deprecated agent.run(...)

Features

  • compatible with LangChain tool workflows
  • supports multiple Talor SERP engines such as Google, Bing, Yandex, and DuckDuckGo
  • exposes engine schema metadata for parameter-aware integrations
  • includes helper APIs for usage history and statistics

Resources

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

langchain_talor_serp-0.1.1.tar.gz (140.6 kB view details)

Uploaded Source

Built Distribution

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

langchain_talor_serp-0.1.1-py3-none-any.whl (168.3 kB view details)

Uploaded Python 3

File details

Details for the file langchain_talor_serp-0.1.1.tar.gz.

File metadata

  • Download URL: langchain_talor_serp-0.1.1.tar.gz
  • Upload date:
  • Size: 140.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.14.0

File hashes

Hashes for langchain_talor_serp-0.1.1.tar.gz
Algorithm Hash digest
SHA256 a54ae16a414fd204a1e39575b9d4ed2abf27bf5ad8da4717158eb509929b6a67
MD5 f54d8a349d59c9c537de1a145e9a0d5d
BLAKE2b-256 e3f6f1eae2c071b1c173efbc562b9bad5e44451dc88d7790983748ab67adc676

See more details on using hashes here.

File details

Details for the file langchain_talor_serp-0.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for langchain_talor_serp-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d266715587069e1ed9da354841058ca75fee4ba9999cbb065bd77b28672e710a
MD5 1a664b769837ab66c9153fa63f298080
BLAKE2b-256 667026bedfc79f4733d519ff251ca83ed834c2946f082b6ac64f3fe526a7beec

See more details on using hashes here.

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