Skip to main content

A Python client for the GROQA API

Project description

Groqa Python Library Documentation

The Groqa Python library provides an interface to interact with the Groqa API, allowing you to perform various search and web-related operations.

Installation

To install the Groqa library, use pip:

pip install --upgrade groqa

Initialization

To use the Groqa library, you need to initialize it with your API key:

from groqa import GroqaSync, GroqaAsync

api_key = "your_groqa_api_key_here"
client_sync = GroqaSync(api_key)
client_async = GroqaAsync(api_key)

Available Methods

The library provides both synchronous and asynchronous versions of its methods. Here are the available methods:

1. search / search_stream

Perform a search query, either as a single response or as a stream.

  • Query Precision: Provide clear and concise queries to get accurate results.

Synchronous:

# Non-streaming search
result = client_sync.search(
    query="What are the latest developments in AI?",
    date_context="Today is Tuesday 19 of November 2024 and the time is 9:40 PM",
    location="us", # can be 'us', 'ca', 'uk',.... (see supported locations below)
    pro_mode=False, # set to True to enable pro mode
    response_language="en", # can be 'auto', 'en', 'fr', 'es', 'de', 'it', 'pt', 'nl', 'ja', 'ko', 'zh', 'ar', 'ru', 'tr', 'hi'
    answer_type="text", # can be 'text', 'markdown', or 'html'
    verbose_mode=False, # set to True to enable verbose mode
    search_type="general", # can be 'news' or 'general'
    return_citations=False, # set to True to return citations
    return_sources=False, # set to True to return sources
    return_images=False, #set to True to return images (depends on the query, some queries may not return images)
    recency_filter="anytime" # can be 'hour', 'day', 'week', 'month', 'year', 'anytime'
)

print(result)

# Streaming search
for chunk in client_sync.search_stream(
    query="Explain quantum computing",
    date_context="Today is Tuesday 19 of November 2024 and the time is 9:40 PM",
    location="us", # can be 'us', 'ca', 'uk',.... (see supported locations below)
    pro_mode=False,  # set to True to enable pro mode
    response_language="en", # can be 'auto', 'en', 'fr', 'es', 'de', 'it', 'pt', 'nl', 'ja', 'ko', 'zh', 'ar', 'ru', 'tr', 'hi'
    answer_type="text", # can be 'text', 'markdown', or 'html'
    verbose_mode=False, # set to True to enable verbose mode
    search_type="general", # can be 'news' or 'general'
    return_citations=False, # set to True to return citations
    return_sources=False, # set to True to return sources
    return_images=False, #set to True to return images (depends on the query, some queries may not return images)
    recency_filter="anytime" # can be 'hour', 'day', 'week', 'month', 'year', 'anytime'
):
    print(chunk)

Asynchronous:

import asyncio

# Non-streaming search
async def search_async():    
    result = await client_async.search(
        query="What are the latest developments in AI?",
        date_context="Today is Tuesday 19 of November 2024 and the time is 9:40 PM",
        location="us", # can be 'us', 'ca', 'uk',.... (see supported locations below)
        pro_mode=False, # set to True to enable pro mode
        response_language="en", # can be 'auto', 'en', 'fr', 'es', 'de', 'it', 'pt', 'nl', 'ja', 'ko', 'zh', 'ar', 'ru', 'tr', 'hi'
        answer_type="text", # can be 'text', 'markdown', or 'html'
        verbose_mode=False, # set to True to enable verbose mode
        search_type="general", # can be 'news' or 'general'
        return_citations=False, # set to True to return citations
        return_sources=False, # set to True to return sources
        return_images=False, #set to True to return images (depends on the query, some queries may not return images)
        recency_filter="anytime" # can be 'hour', 'day', 'week', 'month', 'year', 'anytime'
    )
    print(result)

# Streaming search
async for chunk in client_async.search_stream(
        query="Explain quantum computing",
        date_context="Today is Tuesday 19 of November 2024 and the time is 9:40 PM",
        location="us", # can be 'us', 'ca', 'uk',.... (see supported locations below)
        pro_mode=False, # set to True to enable pro mode
        response_language="en", # can be 'auto', 'en', 'fr', 'es', 'de', 'it', 'pt', 'nl', 'ja', 'ko', 'zh', 'ar', 'ru', 'tr', 'hi'
        answer_type="text", # can be 'text', 'markdown', or 'html'
        verbose_mode=False, # set to True to enable verbose mode
        search_type="general", # can be 'news' or 'general'
        return_citations=False, # set to True to return citations
        return_sources=False, # set to True to return sources
        return_images=False, #set to True to return images
        recency_filter="anytime" # can be 'hour', 'day', 'week', 'month', 'year', 'anytime'
    ):
        print(chunk)

asyncio.run(search_async())

2. get_website_text

Retrieve the text content of a website.

Synchronous:

result = client_sync.get_website_text("https://www.example.com")
print(result)

Asynchronous:

result = await client_async.get_website_text("https://www.example.com")
print(result)

3. get_website_screenshot

Get a screenshot of a website.

Synchronous:

result = client_sync.get_website_screenshot("https://www.example.com")
print(result)

Asynchronous:

result = await client_async.get_website_screenshot("https://www.example.com")
print(result)

4. get_website_markdown

Get the markdown representation of a website.

Synchronous:

result = client_sync.get_website_markdown("https://www.example.com")
print(result)

Asynchronous:

result = await client_async.get_website_markdown("https://www.example.com")
print(result)

5. query_from_url

Perform a query based on the content of a specific URL.

Synchronous:

response = client_sync.query_from_url(
    url="https://www.example.com/article",
    query="What is the main topic of this article?",
    response_language="en", # can be 'auto', 'en', 'fr', 'es', 'de', 'it', 'pt', 'nl', 'ja', 'ko', 'zh', 'ar', 'ru', 'tr', 'hi'
    answer_type="text" # can be 'text', 'markdown', or 'html'
)
print(response)

Asynchronous:

response = await client_async.query_from_url(
    url="https://www.example.com/article",
    query="What is the main topic of this article?",
    response_language="en", 
    answer_type="text"
)
print(response)

6. custom_search / custom_search_stream

Perform a custom search query with a system prompt and user prompt.

Synchronous:

# Non-streaming custom search
result = client_sync.custom_search(
    system_prompt="You are a helpful assistant.",
    user_prompt="Explain the theory of relativity",
    location="us", # can be 'us', 'ca', 'uk',.... (see supported locations below)
    pro_mode=False, # set to True to enable pro mode
    search_type="general", # can be 'news' or 'general'
    return_images=False, # set to True to return images
    return_sources=False, # set to True to return sources
    temperature=0.2, # float value to control the randomness of the output
    top_p=0.9, # float value to control the diversity of the output
    recency_filter="anytime" # can be 'hour', 'day', 'week', 'month', 'year', 'anytime'
)
print(result)

# Streaming custom search
for chunk in client_sync.custom_search_stream(
    system_prompt="You are a helpful assistant.",
    user_prompt="Explain the theory of relativity",
    location="us",
    pro_mode=False,
    search_type="general",
    return_images=False,
    return_sources=False,
    temperature=0.2,
    top_p=0.9,
    recency_filter="anytime" # can be 'hour', 'day', 'week', 'month', 'year', 'anytime'
):
    print(chunk)

Asynchronous:

# Non-streaming custom search
result = await client_async.custom_search(
    system_prompt="You are a helpful assistant.",
    user_prompt="Explain the theory of relativity",
    location="us",
    pro_mode=False,
    search_type="general",
    return_images=False,
    return_sources=False,
    temperature=0.2,
    top_p=0.9,
    recency_filter="anytime" # can be 'hour', 'day', 'week', 'month', 'year', 'anytime'
)
print(result)

# Streaming custom search
async for chunk in client_async.custom_search_stream(
    system_prompt="You are a helpful assistant.",
    user_prompt="Explain the theory of relativity",
    location="us", # can be 'us', 'ca', 'uk',.... (see supported locations below)
    pro_mode=False, # set to True to enable pro mode
    search_type="general", # can be 'news' or 'general'
    return_images=False, # set to True to return images
    return_sources=False, # set to True to return sources
    temperature=0.2, # float value to control the randomness of the output
    top_p=0.9, # float value to control the diversity of the output
    recency_filter="anytime" # can be 'hour', 'day', 'week', 'month', 'year', 'anytime'
):
    print(chunk)

Parameters

Common Parameters for Search Methods

  • query: The search query or question.
  • date_context: String Optional date for context (format: "today is 8 of october and time is 4 PM" or "YYYY-MM-DD HH:MM AM/PM"). If empty, the current date of the API server is used.
  • location: Country code for search context. Default is "us".
  • pro_mode: Boolean to enable or disable pro mode. Default is False.
  • response_language: Language code for the response. Default is "auto" (auto-detect).
  • answer_type: Type of answer format. Options are "text" (default), "markdown", or "html".
  • verbose_mode: Boolean to enable or disable verbose mode. Default is False.
  • search_type: Type of search to perform (general or news). Default is "general".
  • return_citations: Boolean to indicate whether to return citations. Default is False.
  • return_sources: Boolean to indicate whether to return sources. Default is False.
  • return_images: Boolean to indicate whether to return images. Default is False.
  • recency_filter: Filter results by recency. Options are "hour", "day", "week", "month", "year", or "anytime". Default is "anytime".

Custom Search Parameters

  • system_prompt: The system prompt for custom search.
  • user_prompt: The user prompt for custom search.
  • temperature: Float value to control the randomness of the output. Default is 0.2.
  • top_p: Float value to control the diversity of the output. Default is 0.9.
  • search_type: Type of search to perform (general or news). Default is "general".
  • return_images: Boolean to indicate whether to return images. Default is False.
  • return_sources: Boolean to indicate whether to return sources. Default is False.
  • recency_filter: Filter results by recency. Options are "hour", "day", "week", "month", "year", or "anytime". Default is "anytime".

Supported Locations

The location parameter accepts the following country codes:

๐Ÿ‡บ๐Ÿ‡ธ us (United States), ๐Ÿ‡จ๐Ÿ‡ฆ ca (Canada), ๐Ÿ‡ฌ๐Ÿ‡ง uk (United Kingdom), ๐Ÿ‡ฒ๐Ÿ‡ฝ mx (Mexico), ๐Ÿ‡ช๐Ÿ‡ธ es (Spain), ๐Ÿ‡ฉ๐Ÿ‡ช de (Germany), ๐Ÿ‡ซ๐Ÿ‡ท fr (France), ๐Ÿ‡ต๐Ÿ‡น pt (Portugal), ๐Ÿ‡ณ๐Ÿ‡ฑ nl (Netherlands), ๐Ÿ‡น๐Ÿ‡ท tr (Turkey), ๐Ÿ‡ฎ๐Ÿ‡น it (Italy), ๐Ÿ‡ต๐Ÿ‡ฑ pl (Poland), ๐Ÿ‡ท๐Ÿ‡บ ru (Russia), ๐Ÿ‡ฟ๐Ÿ‡ฆ za (South Africa), ๐Ÿ‡ฆ๐Ÿ‡ช ae (United Arab Emirates), ๐Ÿ‡ธ๐Ÿ‡ฆ sa (Saudi Arabia), ๐Ÿ‡ฆ๐Ÿ‡ท ar (Argentina), ๐Ÿ‡ง๐Ÿ‡ท br (Brazil), ๐Ÿ‡ฆ๐Ÿ‡บ au (Australia), ๐Ÿ‡จ๐Ÿ‡ณ cn (China), ๐Ÿ‡ฐ๐Ÿ‡ท kr (Korea), ๐Ÿ‡ฏ๐Ÿ‡ต jp (Japan), ๐Ÿ‡ฎ๐Ÿ‡ณ in (India), ๐Ÿ‡ต๐Ÿ‡ธ ps (Palestine), ๐Ÿ‡ฐ๐Ÿ‡ผ kw (Kuwait), ๐Ÿ‡ด๐Ÿ‡ฒ om (Oman), ๐Ÿ‡ถ๐Ÿ‡ฆ qa (Qatar), ๐Ÿ‡ฎ๐Ÿ‡ฑ il (Israel), ๐Ÿ‡ฒ๐Ÿ‡ฆ ma (Morocco), ๐Ÿ‡ช๐Ÿ‡ฌ eg (Egypt), ๐Ÿ‡ฎ๐Ÿ‡ท ir (Iran), ๐Ÿ‡ฑ๐Ÿ‡พ ly (Libya), ๐Ÿ‡พ๐Ÿ‡ช ye (Yemen), ๐Ÿ‡ฎ๐Ÿ‡ฉ id (Indonesia), ๐Ÿ‡ต๐Ÿ‡ฐ pk (Pakistan), ๐Ÿ‡ง๐Ÿ‡ฉ bd (Bangladesh), ๐Ÿ‡ฒ๐Ÿ‡พ my (Malaysia), ๐Ÿ‡ต๐Ÿ‡ญ ph (Philippines), ๐Ÿ‡น๐Ÿ‡ญ th (Thailand), ๐Ÿ‡ป๐Ÿ‡ณ vn (Vietnam)

Supported Languages

The response_language parameter accepts the following language codes:

  • auto: Auto-detect the user question language (default)
  • en: English
  • fr: French
  • es: Spanish
  • de: German
  • it: Italian
  • pt: Portuguese
  • nl: Dutch
  • ja: Japanese
  • ko: Korean
  • zh: Chinese
  • ar: Arabic
  • ru: Russian
  • tr: Turkish
  • hi: Hindi

Best Practices

  • Query Precision: Provide clear and concise queries to get accurate results.
  • Custom Search: Use the custom_search or custom_search_stream to write your own system and user prompts for more specific queries. always be specific with the user prompt since it will be used for the web search. Remember to include date context if needed in your system prompt. if you need citations, you must add the citation prompt in the System prompt.
  • API Key Security: Never hard-code your API key in your source code. Use environment variables or secure configuration management.
  • Error Handling: Always implement proper error handling to manage API errors and network issues gracefully.
  • Asynchronous Usage: For applications that need to handle multiple requests concurrently, consider using the asynchronous version of the client.
  • Streaming Responses: When using search_stream or custom_search_stream, remember to handle the streaming nature of the response appropriately in your application.
  • Pro Mode: Use pro_mode=True when you need advanced search features, but be aware that it might be slower.
  • Date Context: When historical context is important for your query, always specify the date_context parameter. Use the format "Today is Tuesday 19 of November 2024 and the time is 9:40 PM".
  • Localization: Use the location to get localized results.
  • Response Language: Use the response_language parameter to get responses in different languages.
  • Recency Filter: Use the recency_filter parameter to filter results by recency.
  • Verbose Mode: Use the verbose_mode parameter to get more detailed information in the response.
  • Search Type: Use the search_type parameter to specify the type of search (general or news).

Error Handling

The library raises GroqaError exceptions for API errors. Always wrap your API calls in try-except blocks:

from groqa import GroqaSync, GroqaError

try:
    result = client_sync.search("AI advancements")
    print(result)
except GroqaError as e:
    print(f"An error occurred: {e}")

Remember to handle potential network errors and other exceptions as needed in your application.

Discord Community

  • Join our Discord community to get help, share your projects, and discuss the latest updates: Groqa Discord

Conclusion

The Groqa Python library provides a powerful interface to access advanced search and web analysis capabilities. By leveraging its various methods and parameters, you can create sophisticated applications that can understand and process web content in multiple languages and contexts.

For any issues, feature requests, or further questions, please open an issue.

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

groqa-0.0.5.tar.gz (11.5 kB view details)

Uploaded Source

Built Distribution

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

groqa-0.0.5-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

File details

Details for the file groqa-0.0.5.tar.gz.

File metadata

  • Download URL: groqa-0.0.5.tar.gz
  • Upload date:
  • Size: 11.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.2

File hashes

Hashes for groqa-0.0.5.tar.gz
Algorithm Hash digest
SHA256 fe52dcb6b4f6642e37702028763353e53ed7b43c72818dd954d48bc7991570ea
MD5 de85a3b0a2de76fbb49d65ed815f4dce
BLAKE2b-256 e4969b18b8907391e10d0f031e0645e3c6bcb39a739566ad3c60ff13aab0ec2b

See more details on using hashes here.

File details

Details for the file groqa-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: groqa-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 7.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.2

File hashes

Hashes for groqa-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 966f238ca2aeafd21a4777b6e2dd298314b91f137a0cec2639548f04f4b33009
MD5 02b94f9fdc5583c1cb97327598d7b50c
BLAKE2b-256 357efccc1ab36c03010a6c3db8cda1c4755e4986fbc83a65f61f48575b3b864a

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