How to get CSV report with related search queries and links to their target pages from Google Search Console and Google Analytics
Table of Contents
If you use Google Analytics 4 and Google Search Console, you probably know that you can access "Performance" in Google Search Console to look at search queries that led to your website. While you can click on them one by one to see each query separately, getting a complete report of all queries and their linked pages for the big picture isn't straightforward through the interface.
While you can export to CSV directly from Google Search Console, you're limited to exporting either a list of search queries or a list of pages (URLs) separately.
Fortunately, there's a solution using the script we've made! You can generate a complete CSV report that shows both the list of queries and their corresponding pages/URLs that appeared in Google search results.
 
      
  This can be accomplished using a Python script that interfaces with the Google Search Console API. Although you can copy the script from our repository, you'll need to set up API access to your Google Search Console and complete several setup steps to get everything working. Let's walk through the process step by step!
Step 1: Setup Python on your computer
Windows Installation:
- Visit python.org and download the latest Python version (3.8 or higher)
- Run the installer, making sure to check "Add Python to PATH"
- Download Rye from rye-up.com
- Run the Rye installer
- Open Command Prompt and verify with: python --versionandrye --version
Mac Installation:
- Open Terminal
- Install Homebrew if not already installed: /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com/Homebrew/install/HEAD/install.sh)"
- Install Python: brew install python
- Install Rye: curl -sSf https://rye-up.com/get | bash
- Verify installation: python3 --versionandrye --version
Step 2: Create a folder and save Python script
- Create a new folder for your project (e.g., "search-console-report")
- Open your preferred text editor
- Create a new file named get-queries-and-urls.py
- Copy the following Python script into the file:
Step 3: Run Rye to install required Python packages
Open your terminal or command prompt in your project directory and run these commands:
          rye init
          rye add google-api-python-client google-auth pandas
          rye sync
          
      These commands will:
- Initialize a new Rye project
- Add required dependencies
- Install all packages and create a virtual environment
Step 4: Signup for Google Developer Cloud
- Visit console.cloud.google.com
- Click "Sign Up" if you don't have an account
- Follow the registration process
- Enable 2-Step Verification:
              - Go to your Google Account settings
- Select "Security"
- Enable "2-Step Verification"
- Choose your preferred second factor (phone, authenticator app, or security key)
 
  <h2 class="text-3xl font-bold  mb-8">Step 5: Create a new API project</h2>
  <div class=" rounded-xl p-8">
      <ol class="list-decimal pl-6 ">
          <li>Go to Google Cloud Console (console.cloud.google.com)</li>
          <li>Click on the project dropdown at the top of the page</li>
          <li>Click "New Project" in the modal window</li>
          <li>Enter a meaningful project name (e.g., "search-console-reports")</li>
          <li>Leave the organization as "No Organization" if you don't have one</li>
          <li>Click "Create" to initialize your new project</li>
      </ol>
      <div class=" p-4 mt-4 rounded-lg">
          <p class="font-bold ">Pro Tip:</p>
          <p class="">Choose a descriptive project name that helps you identify its purpose later, especially if you manage multiple Google Cloud projects.</p>
      </div>
  </div>
Step 6: Enable Google Search Console API
- Move through to: Google Search Console API
- Make sure your new project is selected in the top dropdown
- Click the "Enable" button
- Wait for the API to be enabled (usually takes a few seconds)
- Verify that the status changes to "API Enabled"
Note:
If you don't see the "Enable" button, make sure you're logged in with the correct Google account and have selected your project.
Step 7: Generate access credentials
- In the Google Cloud Console, go to "APIs & Services" > "Credentials"
- Click "Create Credentials" and select "Service Account"
- Fill in the service account details:
          - Name: "Search Console Reporter"
- ID: Will be auto-generated
- Description: "Service account for Search Console reporting"
 
- Click "Create and Continue"
- For role, select "Owner" (Required for Search Console access)
- Click "Continue" an then "Done"
- Also copy the service account email address  because you will need it in Step 10 when setting up Search Console permissions (format: yourname@project-id.iam.gserviceaccount.com)
Important:
Save the service account email address - you'll need it in Step 10 when setting up Search Console permissions.
Step 8: Save credentials.json file
- In the Google Cloud Console, go to your service account
- Click on the "Keys" tab
- Click "Add Key" > "Create new key"
- Select "JSON" as the key type
- Click "Create" - the file will automatically download
- Rename the downloaded file to credentials.json
- Move credentials.jsonto your project folder (same location asget-queries-and-urls.py)
Security Warning:
Keep your credentials.json file secure and never share it publicly. This file grants access to your Google Search Console data.
Step 9: Create output folder
Create a folder to store the generated reports:
Windows:
      md output
      
  Mac/Linux:
      mkdir output
      
  Your project structure should now look like this:
project-folder/ βββ get-queries-and-urls.py βββ credentials.json βββ output/
Step 10: Configure Search Console access
- Go to Google Search Console
- Select your property
- Click "Settings" (gear icon) in the left sidebar
- Click "Users and permissions"
- Click "Add User"
- Enter the service account email address you saved earlier
- Set permission level to "Restricted"
- Click "Add"
Verification:
You should see the service account email listed under "Users" with "Restricted" access level.
Step 11: Run the script
Running the script:
    rye run python get-queries-and-urls.py
    
     
  After that output subfolder will contain output with reports based on your data
project-folder/ βββ output/ βββ search_console_data-[timestamp].csv βββ page_summary-[timestamp].csv βββ query_summary-[timestamp].csv
If you encounter any errors:
- Verify that credentials.json is in the correct location
- Check that all required packages are installed
- Make sure your service account has proper Search Console access
- Verify your Python environment is activated
Step 12: Access your reports
After successful execution, you'll find three CSV files in your output folder:
Main Report:
        /output/search_console_data-[timestamp].csv
        
        Contains complete data linking search queries with their corresponding URLs
Additional Reports:
- 
            /output/page_summary-[timestamp].csvAggregated metrics by page, including total impressions, clicks, and average position 
- 
            /output/search_query_summary-[timestamp].csvSearch query performance data, showing how different queries perform across all pages 
Using the Reports:
- Use the main report for detailed query-URL analysis
- Reference page summary for content performance ideas
- Analyze query summary for keyword improvement opportunities
- Import into Excel or Google Sheets for further analysis
Frequently Asked Questions
1. Do I need a paid Google Cloud account to run this script?
No. You can use a free tier Google Cloud account as long as you enable the Search Console API. Most users wonβt exceed the free usage limits for this purpose.
2. Can I run this Python script on both Windows and macOS?
Yes. The script works on any system that supports Python (Windows, macOS, or Linux). Just make sure you install Python 3.8+ and set up the Rye environment as described.
3. Do I need prior coding knowledge to implement this solution?
Basic familiarity with command-line operations and Python is helpful, but you can follow the provided step-by-step instructions without being an expert coder.
4. How do I add the service account email to Google Search Console?
Go to "Users and permissions" in Search Console settings, click "Add User," and enter the service account email. Assign at least Restricted access to allow data retrieval.
5. Why do I need to enable 2-Step Verification on my Google account?
Itβs a best practice for securely managing API credentials. It helps protect your Google Cloud and Search Console data from unauthorized access.
6. How can I automate this CSV reporting process?
You can schedule the Python script via cron jobs on Linux/macOS or Task Scheduler on Windows. Adjust the command to run regularly and make sure valid credentials remain accessible.
7. What if I encounter an error saying my service account lacks permission?
Double-check the service account email is correctly added under "Users and permissions" in Search Console. Also verify you have the correct JSON credentials file in your project folder.
8. Can I specify custom date ranges for the report?
Yes. You can modify the date range parameters within the Python script to define the start and end dates you want. Adjust these lines to fetch older or more recent data as needed.
9. Do I need to pay for Google Analytics to use this script?
No. Google Analytics (GA4 or Universal Analytics) has free tiers. This script primarily uses the Search Console API, which also offers a free tier within its usage quotas.
10. Can I integrate Google Analytics metrics with the Search Console output?
The provided script focuses on Google Search Console data. If you want GA metrics (sessions, bounce rates, etc.), youβd need to use the Google Analytics API and merge datasets.
11. Are there any API usage limits I should worry about?
Google Search Console API and Google Cloud have daily usage limits. But most small-to-medium sites rarely hit these limits. Monitor your quotas in Google Cloud Console if concerned.
12. Does this script collect personal information about my site visitors?
No. The Search Console API only provides aggregated data about clicks, impressions, and queries. Thereβs no personally identifiable information (PII) in the API responses.
Keywords
Continue Reading:
ChatGPT for SEO Copywriting: Faster Briefs, Stronger Keywords
Practical guide for SEOs. Learn workflows that use ChatGPT for keyword research, content briefs, and...
Why Entrepreneurs Use ChatGPT as a Personal Assistant in 2025
A clear guide on using ChatGPT for customer support, content creation, and market research.
Using ChatGPT for Market Research and Product Ideation
How small entrepreneurs harness ChatGPT for market research and exploring new product lines
