Async web search library supporting Google Custom Search, Wikipedia, arXiv, NewsAPI, GitHub, and PubMed data sources.
You can search across multiple sources and retrieve relevant, clean results in JSON format or as compiled text.
- β‘ Asynchronous Searching: Perform searches concurrently across multiple sources
- π Multi-Source Support: Query Google Custom Search, Wikipedia, arXiv, NewsAPI, GitHub, and PubMed
- π§Ή Content extraction and cleaning
- π§ Configurable Search Parameters: Adjust maximum results, preview length, and sources.
- π Python 3.8 or newer
- π API keys and configuration:
- Google Search: Requires a Google API key and a Custom Search Engine (CSE) ID.
- NewsAPI: Requires a free API key from newsapi.org.
- arXiv: No API key required.
- Wikipedia: No API key required.
- GitHub: No API key required.
- PubMed: No API key required.
Set environment variables:
export GOOGLE_API_KEY="your_google_api_key"
export CSE_ID="your_cse_id"
export NEWSAPI_KEY="your_newsapi_key"pip install async-web-searchfrom web_search import WebSearch, WebSearchConfig
config = WebSearchConfig(sources=["google", "arxiv", "github", "newsapi", "pubmed"])
results = await WebSearch(config).search("quantum computing")
# results is a list of dicts with keys: url, title, preview, source
for result in results:
print(f"Title: {result['title']}")
print(f"URL: {result['url']}")
print(f"Preview: {result['preview']}")
print(f"Source: {result['source']}")
print("---")from web_search import WebSearch, WebSearchConfig
config = WebSearchConfig(sources=["google", "arxiv", "github"])
compiled_results = await WebSearch(config).compile_search("quantum computing")
print(compiled_results) # Prints a formatted string with all resultsfrom web_search import GoogleSearchConfig
from web_search.google import GoogleSearch
config = GoogleSearchConfig(
api_key="your_google_api_key",
cse_id="your_cse_id",
max_results=5
)
results = await GoogleSearch(config)._search("quantum computing")
for result in results:
print(result)from web_search import BaseConfig
from web_search.wikipedia_ import WikipediaSearch
wiki_config = BaseConfig(max_results=5)
results = await WikipediaSearch(wiki_config)._search("deep learning")
for result in results:
print(result)from web_search import BaseConfig
from web_search.arxiv import ArxivSearch
arxiv_config = BaseConfig(max_results=3)
results = await ArxivSearch(arxiv_config)._search("neural networks")
for result in results:
print(result)Need to search a data source that isn't bundled with the library? Create a plugin from PluginSearch and pass an instance via WebSearchConfig.plugins.
from web_search import WebSearch, WebSearchConfig
from web_search.base import PluginSearch, SearchResult
class RedditSearch(PluginSearch):
slug = "reddit"
async def _search(self, query: str):
# ...implement Reddit search here...
return [
SearchResult(
url="https://reddit.com/r/MachineLearning/1",
title="AMA about quantum ML",
preview="I recently built a quantum ...",
source=self.slug,
)
]
# Option 1: Register the plugin in WebSearchConfig
config = WebSearchConfig(
sources=["google", "arxiv"],
plugins=[RedditSearch()]
)
results = await WebSearch(config).search("quantum computing")
# Option 2: add plugin after initializing Websearch
ws = WebSearch(config=WebSearchConfig(
sources=["google", "arxiv"],
))
ws.add_plugin(RedditSearch())
results = await ws.search("quantum computing")- Objects in the plugin list that do not inherit from
PluginSearchare ignored. - Exceptions raised inside a plugin are caught; other providers still return results.
A FastAPI-based production server is available for teams that want to use async web search as a web service. The server is hosted at https://awebs.veedo.ai and can be run locally as well.
See server/README.md for detailed API documentation, endpoints, and deployment instructions.
- BaseConfig: Shared configuration for all sources (e.g., max_results and timeout).
- GoogleSearchConfig: Google-specific settings (e.g., api_key, cse_id).
- WebSearchConfig: Configuration for the overall search process (e.g., sources to query).
- WebSearch: Entry point for performing searches across multiple sources.
- GoogleSearch: Handles searches via Google Custom Search Engine API.
- WikipediaSearch: Searches Wikipedia and retrieves article previews.
- ArxivSearch: Queries arXiv for academic papers.
- search(query: str): Main search method for WebSearch.
- _search(query: str): Source-specific search logic for GoogleSearch, WikipediaSearch, and ArxivSearch.
We welcome contributions! To contribute:
- Fork the repository.
- Create a new branch (git checkout -b feature-name).
- Commit your changes (git commit -am "Add new feature").
- Push to the branch (git push origin feature-name).
- Open a pull request.
pytest -vMIT