How to Add Google Analytics to WordPress Without Plugin

Cody Schneider7 min read

Adding Google Analytics to your WordPress site is a non-negotiable step for understanding your audience and measuring performance. While plugins are a popular shortcut, inserting the tracking code manually gives you more control and helps keep your site lean and fast. This article will walk you through exactly how to add Google Analytics to WordPress without a plugin, using two different methods.

GraphedGraphed

Still Building Reports Manually?

Watch how growth teams are getting answers in seconds — not days.

Watch Graphed demo video

Why Bother Adding Google Analytics Manually?

You might be wondering why you'd choose to edit code when there are dozens of plugins that can do it for you. While plugins are great for convenience, a manual approach has some distinct advantages:

  • Better Site Performance: Every plugin you add to your site introduces more code, which can slightly slow down your website. Adding a small snippet of code directly is more lightweight than installing and activating an entire plugin.
  • Fewer Security Risks: Outdated or poorly coded plugins can be a security vulnerability. By managing the code yourself, you eliminate one potential point of failure.
  • Reduced "Plugin Bloat": Relying on too many plugins can lead to conflicts, update headaches, and general clutter. Staying lean keeps your WordPress backend clean and easier to manage.

The main trade-off is that you need to be comfortable editing theme files. It sounds intimidating, but if you follow the steps carefully and use a child theme, it's a straightforward process.

Before You Begin: Two Critical Steps

Before you touch any code, there are two preliminary steps you must take to ensure you don't break your site or lose your changes down the line.

1. Create a Google Analytics Account & Get Your Code

If you haven’t already, you’ll first need a Google Analytics account. When signing up, Google will prompt you to create a "property" for your website. The current standard is Google Analytics 4.

Once your property is created, you need to find your unique tracking code snippet. Here’s how you find it in GA4:

  1. Log into your Google Analytics account.
  2. Click the Admin gear icon in the bottom-left corner.
  3. In the Property column, make sure your correct website property is selected.
  4. Click on Data Streams, then select the data stream for your website.
  5. Under the "Google tag" section at the bottom, click View tag instructions.
  6. A new tab will open with installation instructions. Click the Install manually tab.
  7. You'll see a snippet of JavaScript code. This is your GA4 tracking code. Copy the entire thing to your clipboard.

Your code will look something like this, but with your unique 'G-' ID:

<!-- Google tag (gtag.js) -->
<script async src="https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX"></script>
<script>
  window.dataLayer = window.dataLayer || [],
  function gtag(){dataLayer.push(arguments),}
  gtag('js', new Date()),

  gtag('config', 'G-XXXXXXXXXX'),
</script>
GraphedGraphed

Still Building Reports Manually?

Watch how growth teams are getting answers in seconds — not days.

Watch Graphed demo video

2. Use a WordPress Child Theme (This is Important!)

This is the most crucial part of making manual code edits to a WordPress site. If you add the tracking code directly to your main theme’s files, it will be deleted the next time you update your theme.

A child theme is a sub-theme that inherits all the functionality and styling of its parent theme. When you modify a child theme, your changes are kept separate from the parent theme's files. This way, when the parent theme receives an update, your custom modifications - like the Google Analytics code - are safe and sound.

If you're not already using a child theme, you should create one before proceeding. Many premium themes come with a child theme pre-packaged. If yours doesn't, you can easily create one using a free plugin like Child Theme Configurator, then deactivate the plugin once you're done.

Method 1: Add the Tracking Code to Your header.php File

This is the most common and direct method for manually adding code to your website’s header. The header.php file contains the opening HTML content for your site, including the crucial <head> section, which is exactly where Google wants you to place its tracking script.

Follow these steps:

  1. Navigate to your WordPress dashboard.
  2. In the left sidebar, go to Appearance > Theme File Editor. (If you don't see this option, your hosting may have disabled it for security. In that case, you'd need to edit the file using an FTP client or your host's file manager.)
  3. You might see a warning about editing theme files directly. Click "I understand" to continue.
  4. On the right side, under "Theme Files," make sure you've selected your child theme from the dropdown menu.
  5. Find and click on the file named Theme Header (header.php).
  6. Inside the editor, look for the closing </head> tag.
  7. Paste your full Google Analytics tracking code directly above the closing </head> tag.
  8. Click the Update File button to save your changes.

That’s it! The script will now be present on every page of your website, as the header.php file is loaded universally.

GraphedGraphed

Still Building Reports Manually?

Watch how growth teams are getting answers in seconds — not days.

Watch Graphed demo video

Method 2: Use Your Theme's functions.php File

Adding code via the functions.php file is considered a slightly cleaner and more programmatic approach by many developers. Instead of directly pasting the HTML into a template file, you use a PHP function to "hook" your script into the WordPress header. This keeps your custom logic neatly contained within one file.

This method accomplishes the same goal as editing header.php, but it does so more elegantly.

Here’s how to do it:

  1. In your WordPress dashboard, go to Appearance > Theme File Editor.
  2. Again, make sure your child theme is selected in the dropdown menu on the right.
  3. Click on the file named Theme Functions (functions.php).
  4. Scroll to the very bottom of the file.
  5. Copy and paste the following PHP code block at the very end.
function graphed_add_google_analytics() { ?>

    <!-- Paste Your Google Analytics Tracking Code Here -->

<?php }
add_action( 'wp_head', 'graphed_add_google_analytics' ),
  1. Now, paste your complete Google Analytics tracking snippet into the space that says <!-- Paste Your Google Analytics Tracking Code Here -->.

Your final code in functions.php should look like this (but with your own GA4 snippet):

function graphed_add_google_analytics() { ?>

    <!-- Google tag (gtag.js) -->
    <script async src="https://www.googletagmanager.com/gtag/js?id=G-XXXXXXXXXX"></script>
    <script>
      window.dataLayer = window.dataLayer || [],
      function gtag(){dataLayer.push(arguments),}
      gtag('js', new Date()),

      gtag('config', 'G-XXXXXXXXXX'),
    </script>

<?php }
add_action( 'wp_head', 'graphed_add_google_analytics' ),
  1. Click Update File to save.

This function, graphed_add_google_analytics(), tells WordPress to execute the code inside it by using the wp_head action hook. This hook runs right before the </head> tag is closed, injecting your script in the correct location across your entire site.

GraphedGraphed

Still Building Reports Manually?

Watch how growth teams are getting answers in seconds — not days.

Watch Graphed demo video

How to Check If Google Analytics is Working Correctly

After you’ve added the code using either method, you need to confirm it’s actually working. There are two simple ways to verify your setup:

1. Use the Real-Time Report

This is the fastest and most reliable way to check.

  • Open your Google Analytics dashboard.
  • In the left sidebar, navigate to Reports > Realtime.
  • In a different browser tab or on your phone, open your website. Clicking around a few pages can help.
  • If the installation was successful, your visit will appear on the Realtime overview map and in the "Users in Last 30 Minutes" card within a minute. If you see a "1" or more, you're good to go!

2. View Your Website's Page Source

You can also check your website's code to see if the script is present.

  • Go to any page of your website.
  • Right-click anywhere on the page and select "View Page Source" (or use the shortcut Ctrl+U on Windows, Cmd+Option+U on Mac).
  • A new tab will open with your site's raw HTML.
  • Press Ctrl+F (or Cmd+F) to open the find tool and search for gtag.js.
  • If your search finds the Google Analytics tracking code, you’ve installed it correctly.

Final Thoughts

Adding Google Analytics to WordPress without a plugin is a smart way to streamline your website while maintaining full control over your code. By using a child theme and adding the tracking script to either your header.php or functions.php file, you can ensure your site is tracking visitors efficiently and safely.

Getting your website analytics properly set up is the crucial first step. The next, and more important, challenge is translating that data into actionable insights without getting lost in complex reports. Since manually building dashboards in Google Analytics is complicated and time-consuming, we've automated it. With Graphed, you just connect your Google Analytics account and use plain English to instantly create real-time dashboards and reports, freeing you up to focus on growing your business instead of wrestling with data.

Related Articles

How to Enable Data Analysis in Excel

Enable Excel's hidden data analysis tools with our step-by-step guide. Uncover trends, make forecasts, and turn raw numbers into actionable insights today!