A free tool used to get Google Images search results based on a provided image URL.
To run this tool, you need to have Python 3.11 installed in your system.
Open up a terminal window, navigate to this repository and run this command:
make install
First of all, find an image you want to query Google Images with.
For this example, we'll be using an image of a cat from the Wikipedia page on cats.
Make sure to copy the direct image address, like this:
The retrieved URL must end in .jpg
, .png
, or any other image format. Here's the URL of the copied image:
Save the URL you copied, it will be used for scraping Google Images results based on that image.
To get results from Google Images based on an image URL, simply run this command in your terminal:
make scrape URL="<your_image_url>"
With the image URL we retrieved earlier, the command would look like this:
make scrape URL="https://upload.wikimedia.org/wikipedia/commons/thumb/b/bb/Kittyply_edit1.jpg/440px-Kittyply_edit1.jpg"
Make sure to surround the URL with quotation marks, otherwise the tool might have trouble parsing it.
After running the command, your terminal should look something like this:
After the tool has finished running, you should notice that an images.csv
file appeared in your current directory.
This data in this file has these columns for the Google Images results for your provided image:
title
- The title of the page the image was found on.image_url
- The static Google Images URL for that image.source_url
- The source URL of the page the image found on.
Here's an example of how the data can look like:
In case the code doesn't work or your project is of bigger scale, please refer to the second part of the tutorial. There, we showcase how to scrape public data with Oxylabs Scraper API.
You can also scrape public Google Images data with Google Images Search API. Keep in mind that this is a paid tool but you may get a free 7-day trial. Once you get the trial (or a subscription), you'll have to create a user account on the Oxylabs dashboard and get the API credentials. These credentials will be used in the later stages.
To get started, we must have Python 3.6+ installed and running on your system. Also, we need the following packages to put our code into action:
-
requests - for sending HTTP requests to Oxylabs API.
-
Pandas - for saving our output data in dataframes and saving in CSV files.
To install these packages, we can use the following command:
pip install requests pandas
Running this command will install all the required packages.
After the installation of packages, start by creating a new Python file and import the required libraries using the following code:
import requests
import pandas as pd
The Oxylabs Image Scraper API has some parameters that can be set to structure the payload and make the request accordingly. The details of these parameters can be found in the official documentation by Oxylabs.
The payload is structured as follows:
payload = {
"source": "google_images",
"domain": "com",
"query": "<search_image_URL>",
"context": [
{
"key": "search_operators",
"value": [
{"key": "site", "value": "example.com"},
{"key": "filetype", "value": "html"},
{"key": "inurl", "value": "image"},
],
}
],
"parse": "true",
"geo_location": "United States"
}
NOTE: Make sure to replace the query
parameter value with the required search image URL.
The context
parameter is used to apply some search filters. For example, our search operators force the API to scrape only the links from Google image search results that belong to example.com
. If you remove this site key from the search_operators
, the Image Scraper API may return related results from all the websites.
The search operators filetype:
html and inurl:image
define search criteria to only retrieve results with a file type of HTML and where "image" is included in the URL.
The parse
parameter is set to true to get the results parsed in the JSON format. Additionally, you can add pages and start_page
parameters to the payload to scrape multiple result pages starting from the start_page
. A value of 1 is the default value for both the parameters.
After creating the payload structure, you can initiate a POST request to Oxylabs’ API using the following code segment.
response = requests.request(
"POST",
"https://realtime.oxylabs.io/v1/queries",
auth=(USERNAME, PASSWORD),
json=payload,
)
NOTE: Make sure to replace username
and password
with your API credentials. The response received can be viewed in the JSON format.
Now, we can extract the required images from the response object. The response object has a key results
that contains all the related image data. We will extract and save all the image data in the data frame. Later, this dataframe can be saved in a CSV file using the following code.
image_results = result["results"]["organic"]
# Create a DataFrame
df = pd.DataFrame(columns=["Image Title", "Image Description", "Image URL"])
for i in image_results:
title = i["title"]
description = i["desc"]
url = i["url"]
df = pd.concat(
[pd.DataFrame([[title, description, url]], columns=df.columns), df],
ignore_index=True,
)
# Copy the data to CSV and JSON files
df.to_csv("google_image_results.csv", index=False)
df.to_json("google_image_results.json", orient="split", index=False)
Now, let's take an example URL of a cat as the query image and put all the code together to make more cognitive sense. Assume that we want to scrape the first page from Google Images and want to restrict search to wikipedia.org only. Here is what the code looks like:
# Import Required libraries
import requests
import pandas as pd
from pprint import pprint
# Set your Oxylabs API credentials
USERNAME = "<your_username>"
PASSWORD = "<your_password>"
# Structure payload.
payload = {
"source": "google_images",
"domain": "com",
"query": "https://upload.wikimedia.org/wikipedia/commons/a/a3/June_odd-eyed-cat.jpg",
"context": [
{
"key": "search_operators",
"value": [
{"key": "site", "value": "wikipedia.org"},
{"key": "filetype", "value": "html"},
{"key": "inurl", "value": "image"},
],
}
],
"parse": "true",
"geo_location": "United States"
}
# Get response.
response = requests.request(
"POST",
"https://realtime.oxylabs.io/v1/queries",
auth=(USERNAME, PASSWORD),
json=payload,
)
# Extract data from the response
result = response.json()["results"][0]["content"]
image_results = result["results"]["organic"]
# Create a DataFrame
df = pd.DataFrame(columns=["Image Title", "Image Description", "Image URL"])
for i in image_results:
title = i["title"]
description = i["desc"]
url = i["url"]
df = pd.concat(
[pd.DataFrame([[title, description, url]], columns=df.columns), df],
ignore_index=True,
)
# Print the data on the screen
print("Image Name: " + title)
print("Image Description: " + description)
print("Image URL: " + url)
# Copy the data to CSV and JSON files
df.to_csv("google_image_results.csv", index=False)
df.to_json("google_image_results.json", orient="split", index=False)
Here is what our output looks like:
The complete API response for this API request can be found here.
Looking to scrape data from other Google sources? Google Sheets for Basic Web Scraping, How to Scrape Google Shopping Results, Google Play Scraper, How To Scrape Google Jobs, Google News Scrpaer, How to Scrape Google Scholar, How to Scrape Google Flights with Python, Scrape Google Search Results, Scrape Google Trends