This module lets you use Google Searching capabilities right from your Python code
Project description
googlesearch
googlesearchlets you use Google Searching capabilities right from your Python code or from your CLI
Make any Google Search right from Python!
Getting Started
These instructions will get you a copy of the project up and running on your local machine for development and testing purposes. See deployment for notes on how to deploy the project on a live system.
Prerequisites
You will need Python 3 to use this module
# vermin output
Minimum required versions: 3.2
Incompatible versions: 2
According to Vermin, Python 3.2 is needed
Always check if your Python version works with googlesearch before using it in production
Installing
Option 1: From PyPI
pip install python-googlesearch
Make sure to download python-googlesearch as googlesearch cannot be given to any package on PyPI
Even if you download python-googlesearch, googlesearch is used for the imports and the CLI version for conveniency purposes
Option 2: From Git
pip install git+https://github.com/Animenosekai/googlesearch
You can check if you successfully installed it by printing out its version:
$ python -c "import googlesearch; print(googlesearch.__version__)"
# output:
googlesearch v1.1.1
or just:
$ googlesearch --version
# output:
googlesearch v1.1.1
Usage
You can use googlesearch in Python by importing it in your script:
>>> from googlesearch import Search
>>> python_results = Search("Python")
>>> python_results.results
[<SearchResult title="Python.org" (www.python.org)>, <SearchResult title="Python" ()>, <SearchResult title="Python (langage) — Wikipédia" (fr.wikipedia.org › wiki › Python_(langage))>, ...]
CLI usage
You can use googlesearch in other apps by accessing it through the CLI version:
$ googlesearch --query Python
{
"query": "Python",
"results": [
{
"url": "https://www.python.org/",
"title": "Welcome to Python.org",
"displayedURL": "www.python.org",
"description": "The official home of the Python Programming Language.\nDownloads \u00b7 Python For Beginners \u00b7 Quotes about Python \u00b7 Python Essays"
},
[...]
],
"relatedSearches": [
"Python serpent",
"Python openclassroom",
[...]
],
"success": true
}
Interactive Shell (REPL)
An interactive version of the CLI is also available
$ googlesearch
Enter '.quit' to exit googlesearch
[?] (googlesearch ~ Query) > : ... # enter your query
[?] What do you want to do?: # select the result with your keyboard's arrows and [enter]
—————————————————SEARCH RESULT—————————————————
[...] # site's name
Description: # the site's description
URL: ... # site's URL
Related Searches: # a max of 3 related searches
You can get help on this version by using:
$ googlesearch --help
usage: googlesearch [-h] [--version] [--query QUERY] [--langua...
As a Python module
Search
The search class represents a Google Search.
It lets you retrieve the different results/websites (Search.results) and the related searches (Search.related_searches)
How to use
This class is lazy loading the results.
When you initialize it with Search(), it takes a query as the required parameter and the following parameters as optional parameters:
language: The language to request the results in (All of the website won't be in the given language as it is biased by lots of factors, including your IP address location). This needs to be a two-letter ISO 639-1 language code (default: "en")number_of_results: The max number of results to be passed to Google Search while requesting the results (This won't give you the exact number of results) (default: 10)retry_count: A positive integer representing the number of retries done before raising an exception (useful asgooglesearchseems to fail sometimes) (default: 3)parser: The BeautifulSoup parser to use (default: "html.parser")
It will only load and parse the website when results or related_searches is called.
parser is the BeautifulSoup parser used to parse the website and .
results is a list of googlesearch.models.SearchResultElement.
related_searches is a list of Search elements.
SearchResultElement
This class represents a result and is initialized by googlesearch.
It holds the following information:
url: The URL of the websitetitle: The title of the websitedisplayed_url: The URL displayed on Google Searchdescription: The description of the website
Extra
Every class has the as_dict function which converts the object into a dictionary. For Search, the as_dict function will convert the other Search objects in related_search to a string with the query.
Exceptions
All of the exceptions inherit from the GoogleSearchException exception.
You can find a list of exceptions in the exceptions.py file
Deployment
This module is currently in development and might contain bugs.
Feel free to use it in production if you feel like it is suitable for your production even if you may encounter issues.
Built With
- beautifulsoup4 - To parse the HTML
- requests - To make HTTP requests
- pyuseragents - To create the
User-AgentHTTP header - inquirer - To make a beautiful CLI interface
Authors
- Anime no Sekai - Initial work - Animenosekai
License
This project is licensed under the MIT License - see the LICENSE file for more details
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file python-googlesearch-1.1.1.tar.gz.
File metadata
- Download URL: python-googlesearch-1.1.1.tar.gz
- Upload date:
- Size: 12.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
23bfe1d07399443d4abbedf13a22790dce0bf4bf06e7256f9ede9f6deaba9d4f
|
|
| MD5 |
fe95d3371b86e65e9e66cd157538abbd
|
|
| BLAKE2b-256 |
f9051032ea13e2e7fc820f946b05c2ebdf8f1b875194b3734a98e8b8535e133a
|
File details
Details for the file python_googlesearch-1.1.1-py3-none-any.whl.
File metadata
- Download URL: python_googlesearch-1.1.1-py3-none-any.whl
- Upload date:
- Size: 12.0 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.5
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
af7c1c829dc990c5b898d71aa8688afb151b3d8debaf674e0f71a8c6761f890f
|
|
| MD5 |
5b8011fb2babc41a120df690d7e35627
|
|
| BLAKE2b-256 |
0ca61578e5ac476e28b9c6929538ce47822431b0572138e9e96a6281a3429c75
|