Connect with us

SEO

Using Python + Streamlit To Find Striking Distance Keyword Opportunities

Published

on

Python is an excellent tool to automate repetitive tasks as well as gain additional insights into data.

In this article, you’ll learn how to build a tool to check which keywords are close to ranking in positions one to three and advises whether there is an opportunity to naturally work those keywords into the page.

It’s perfect for Python beginners and pros alike and is a great introduction to using Python for SEO.

If you’d just like to get stuck in there’s a handy Streamlit app available for the code. This is simple to use and requires no coding experience.

There’s also a Google Colaboratory Sheet if you’d like to poke around with the code. If you can crawl a website, you can use this script!

Here’s an example of what we’ll be making today:

Screenshot from Microsoft Excel, October 2021An Excel sheet documenting onpage keywords opportunites generated with Python

These keywords are found in the page title and H1, but not in the copy. Adding these keywords naturally to the existing copy would be an easy way to increase relevancy for these keywords.

By taking the hint from search engines and naturally including any missing keywords a site already ranks for, we increase the confidence of search engines to rank those keywords higher in the SERPs.

This report can be created manually, but it’s pretty time-consuming.

So, we’re going to automate the process using a Python SEO script.

Preview Of The Output

This is a sample of what the final output will look like after running the report:

Excel sheet showing and example of keywords that can be optimised by using the striking distance reportScreenshot from Microsoft Excel, October 2021Excel sheet showing and example of keywords that can be optimised by using the striking distance report

The final output takes the top five opportunities by search volume for each page and neatly lays each one horizontally along with the estimated search volume.

It also shows the total search volume of all keywords a page has within striking distance, as well as the total number of keywords within reach.

The top five keywords by search volume are then checked to see if they are found in the title, H1, or copy, then flagged TRUE or FALSE.

This is great for finding quick wins! Just add the missing keyword naturally into the page copy, title, or H1.

Getting Started

The setup is fairly straightforward. We just need a crawl of the site (ideally with a custom extraction for the copy you’d like to check), and an exported file of all keywords a site ranks for.

This post will walk you through the setup, the code, and will link to a Google Colaboratory sheet if you just want to get stuck in without coding it yourself.

To get started you will need:

We’ve named this the Striking Distance Report as it flags keywords that are easily within striking distance.

(We have defined striking distance as keywords that rank in positions four to 20, but have made this a configurable option in case you would like to define your own parameters.)

Striking Distance SEO Report: Getting Started

1. Crawl The Target Website

  • Set a custom extractor for the page copy (optional, but recommended).
  • Filter out pagination pages from the crawl.

2. Export All Keywords The Site Ranks For Using Your Favorite Provider

  • Filter keywords that trigger as a site link.
  • Remove keywords that trigger as an image.
  • Filter branded keywords.
  • Use both exports to create an actionable Striking Distance report from the keyword and crawl data with Python.

Crawling The Site

I’ve opted to use Screaming Frog to get the initial crawl. Any crawler will work, so long as the CSV export uses the same column names or they’re renamed to match.

The script expects to find the following columns in the crawl CSV export:

"Address", "Title 1", "H1-1", "Copy 1", "Indexability"

Crawl Settings

The first thing to do is to head over to the main configuration settings within Screaming Frog:

Configuration > Spider > Crawl

The main settings to use are:

Crawl Internal Links, Canonicals, and the Pagination (Rel Next/Prev) setting.

(The script will work with everything else selected, but the crawl will take longer to complete!)

Recommended Screaming Frog Crawl SettingsScreenshot from Screaming Frog, October 2021Recommended Screaming Frog Crawl Settings

Next, it’s on to the Extraction tab.

Configuration > Spider > Extraction

Recommended Screaming Frog Extraction Crawl SettingsScreenshot from Screaming Frog, October 2021Recommended Screaming Frog Extraction Crawl Settings

At a bare minimum, we need to extract the page title, H1, and calculate whether the page is indexable as shown below.

Indexability is useful because it’s an easy way for the script to identify which URLs to drop in one go, leaving only keywords that are eligible to rank in the SERPs.

If the script cannot find the indexability column, it’ll still work as normal but won’t differentiate between pages that can and cannot rank.

Setting A Custom Extractor For Page Copy

In order to check whether a keyword is found within the page copy, we need to set a custom extractor in Screaming Frog.

Configuration > Custom > Extraction

Name the extractor “Copy” as seen below.

Screaming Frog Custom Extraction Showing Default Options for Extracting the Page CopyScreenshot from Screaming Frog, October 2021Screaming Frog Custom Extraction Showing Default Options for Extracting the Page Copy

Important: The script expects the extractor to be named “Copy” as above, so please double check!

Lastly, make sure Extract Text is selected to export the copy as text, rather than HTML.

There are many guides on using custom extractors online if you need help setting one up, so I won’t go over it again here.

Once the extraction has been set it’s time to crawl the site and export the HTML file in CSV format.

Exporting The CSV File

Exporting the CSV file is as easy as changing the drop-down menu displayed underneath Internal to HTML and pressing the Export button.

Internal > HTML > Export

Screaming Frog - Export Internal HTML SettingsScreenshot from Screaming Frog, October 2021Screaming Frog - Export Internal HTML Settings

After clicking Export, It’s important to make sure the type is set to CSV format.

The export screen should look like the below:

Screaming Frog Internal HTML CSV Export SettingsScreenshot from Screaming Frog, October 2021Screaming Frog Internal HTML CSV Export Settings

Tip 1: Filtering Out Pagination Pages

I recommend filtering out pagination pages from your crawl either by selecting Respect Next/Prev under the Advanced settings (or just deleting them from the CSV file, if you prefer).

Screaming Frog Settings to Respect Rel / PrevScreenshot from Screaming Frog, October 2021Screaming Frog Settings to Respect Rel / Prev

Tip 2: Saving The Crawl Settings

Once you have set the crawl up, it’s worth just saving the crawl settings (which will also remember the custom extraction).

This will save a lot of time if you want to use the script again in the future.

File > Configuration > Save As

How to save a configuration file in screaming frogScreenshot from Screaming Frog, October 2021How to save a configuration file in screaming frog

Exporting Keywords

Once we have the crawl file, the next step is to load your favorite keyword research tool and export all of the keywords a site ranks for.

The goal here is to export all the keywords a site ranks for, filtering out branded keywords and any which triggered as a sitelink or image.

For this example, I’m using the Organic Keyword Report in Ahrefs, but it will work just as well with Semrush if that’s your preferred tool.

In Ahrefs, enter the domain you’d like to check in Site Explorer and choose Organic Keywords.

Ahrefs Site Explorer SettingsScreenshot from Ahrefs.com, October 2021Ahrefs Site Explorer Settings

Site Explorer > Organic Keywords

Ahrefs - How Setting to Export Organic Keywords a Site Ranks ForScreenshot from Ahrefs.com, October 2021Ahrefs - How Setting to Export Organic Keywords a Site Ranks For

This will bring up all keywords the site is ranking for.

Filtering Out Sitelinks And Image links

The next step is to filter out any keywords triggered as a sitelink or an image pack.

The reason we need to filter out sitelinks is that they have no influence on the parent URL ranking. This is because only the parent page technically ranks for the keyword, not the sitelink URLs displayed under it.

Filtering out sitelinks will ensure that we are optimizing the correct page.

Ahrefs Screenshot Demonstrating Pages Ranking for Sitelink KeywordsScreenshot from Ahrefs.com, October 2021Ahrefs Screenshot Demonstrating Pages Ranking for Sitelink Keywords

Here’s how to do it in Ahrefs.

Image showing how to exclude images and sitelinks from a keyword exportScreenshot from Ahrefs.com, October 2021Image showing how to exclude images and sitelinks from a keyword export

Lastly, I recommend filtering out any branded keywords. You can do this by filtering the CSV output directly, or by pre-filtering in the keyword tool of your choice before the export.

Finally, when exporting make sure to choose Full Export and the UTF-8 format as shown below.

Image showing how to export keywords in UTF-8 format as a csv fileScreenshot from Ahrefs.com, October 2021Image showing how to export keywords in UTF-8 format as a csv file

By default, the script works with Ahrefs (v1/v2) and Semrush keyword exports. It can work with any keyword CSV file as long as the column names the script expects are present.

Processing

The following instructions pertain to running a Google Colaboratory sheet to execute the code.

There is now a simpler option for those that prefer it in the form of a Streamlit app. Simply follow the instructions provided to upload your crawl and keyword file.

Now that we have our exported files, all that’s left to be done is to upload them to the Google Colaboratory sheet for processing.

Select Runtime > Run all from the top navigation to run all cells in the sheet.

Image showing how to run the stirking distance Python script from Google CollaboratoryScreenshot from Colab.research.google.com, October 2021Image showing how to run the stirking distance Python script from Google Collaboratory

The script will prompt you to upload the keyword CSV from Ahrefs or Semrush first and the crawl file afterward.

Image showing how to upload the csv files to Google CollaboratoryScreenshot from Colab.research.google.com, October 2021Image showing how to upload the csv files to Google Collaboratory

That’s it! The script will automatically download an actionable CSV file you can use to optimize your site.

Image showing the Striking Distance final outputScreenshot from Microsoft Excel, October 2021Image showing the Striking Distance final output

Once you’re familiar with the whole process, using the script is really straightforward.

Code Breakdown And Explanation

If you’re learning Python for SEO and interested in what the code is doing to produce the report, stick around for the code walkthrough!

Install The Libraries

Let’s install pandas to get the ball rolling.

!pip install pandas

Import The Modules

Next, we need to import the required modules.

import pandas as pd
from pandas import DataFrame, Series
from typing import Union
from google.colab import files

Set The Variables

Now it’s time to set the variables.

The script considers any keywords between positions four and 20 as within striking distance.

Changing the variables here will let you define your own range if desired. It’s worth experimenting with the settings to get the best possible output for your needs.

# set all variables here
min_volume = 10  # set the minimum search volume
min_position = 4  # set the minimum position  / default = 4
max_position = 20 # set the maximum position  / default = 20
drop_all_true = True  # If all checks (h1/title/copy) are true, remove the recommendation (Nothing to do)
pagination_filters = "filterby|page|p="  # filter patterns used to detect and drop paginated pages

Upload The Keyword Export CSV File

The next step is to read in the list of keywords from the CSV file.

It is set up to accept an Ahrefs report (V1 and V2) as well as a Semrush export.

This code reads in the CSV file into a Pandas DataFrame.

upload = files.upload()
upload = list(upload.keys())[0]
df_keywords = pd.read_csv(
    (upload),
    error_bad_lines=False,
    low_memory=False,
    encoding="utf8",
    dtype={
        "URL": "str",
        "Keyword": "str",
        "Volume": "str",
        "Position": int,
        "Current URL": "str",
        "Search Volume": int,
    },
)
print("Uploaded Keyword CSV File Successfully!")

If everything went to plan, you’ll see a preview of the DataFrame created from the keyword CSV export. 

Dataframe showing sucessful upload of the keyword export fileScreenshot from Colab.research.google.com, October 2021Dataframe showing sucessful upload of the keyword export file

Upload The Crawl Export CSV File

Once the keywords have been imported, it’s time to upload the crawl file.

This fairly simple piece of code reads in the crawl with some error handling option and creates a Pandas DataFrame named df_crawl.

upload = files.upload()
upload = list(upload.keys())[0]
df_crawl = pd.read_csv(
    (upload),
        error_bad_lines=False,
        low_memory=False,
        encoding="utf8",
        dtype="str",
    )
print("Uploaded Crawl Dataframe Successfully!")

Once the CSV file has finished uploading, you’ll see a preview of the DataFrame.

Image showing a dataframe of the crawl file being uploaded successfullyScreenshot from Colab.research.google.com, October 2021Image showing a dataframe of the crawl file being uploaded successfully

Clean And Standardize The Keyword Data

The next step is to rename the column names to ensure standardization between the most common types of file exports.

Essentially, we’re getting the keyword DataFrame into a good state and filtering using cutoffs defined by the variables.

df_keywords.rename(
    columns={
        "Current position": "Position",
        "Current URL": "URL",
        "Search Volume": "Volume",
    },
    inplace=True,
)

# keep only the following columns from the keyword dataframe
cols = "URL", "Keyword", "Volume", "Position"
df_keywords = df_keywords.reindex(columns=cols)

try:
    # clean the data. (v1 of the ahrefs keyword export combines strings and ints in the volume column)
    df_keywords["Volume"] = df_keywords["Volume"].str.replace("0-10", "0")
except AttributeError:
    pass

# clean the keyword data
df_keywords = df_keywords[df_keywords["URL"].notna()]  # remove any missing values
df_keywords = df_keywords[df_keywords["Volume"].notna()]  # remove any missing values
df_keywords = df_keywords.astype({"Volume": int})  # change data type to int
df_keywords = df_keywords.sort_values(by="Volume", ascending=False)  # sort by highest vol to keep the top opportunity

# make new dataframe to merge search volume back in later
df_keyword_vol = df_keywords[["Keyword", "Volume"]]

# drop rows if minimum search volume doesn't match specified criteria
df_keywords.loc[df_keywords["Volume"] < min_volume, "Volume_Too_Low"] = "drop"
df_keywords = df_keywords[~df_keywords["Volume_Too_Low"].isin(["drop"])]

# drop rows if minimum search position doesn't match specified criteria
df_keywords.loc[df_keywords["Position"] <= min_position, "Position_Too_High"] = "drop"
df_keywords = df_keywords[~df_keywords["Position_Too_High"].isin(["drop"])]
# drop rows if maximum search position doesn't match specified criteria
df_keywords.loc[df_keywords["Position"] >= max_position, "Position_Too_Low"] = "drop"
df_keywords = df_keywords[~df_keywords["Position_Too_Low"].isin(["drop"])]

Clean And Standardize The Crawl Data

Next, we need to clean and standardize the crawl data.

Essentially, we use reindex to only keep the “Address,” “Indexability,” “Page Title,” “H1-1,” and “Copy 1” columns, discarding the rest.

We use the handy “Indexability” column to only keep rows that are indexable. This will drop canonicalized URLs, redirects, and so on. I recommend enabling this option in the crawl.

Lastly, we standardize the column names so they’re a little nicer to work with.

# keep only the following columns from the crawl dataframe
cols = "Address", "Indexability", "Title 1", "H1-1", "Copy 1"
df_crawl = df_crawl.reindex(columns=cols)
# drop non-indexable rows
df_crawl = df_crawl[~df_crawl["Indexability"].isin(["Non-Indexable"])]
# standardise the column names
df_crawl.rename(columns={"Address": "URL", "Title 1": "Title", "H1-1": "H1", "Copy 1": "Copy"}, inplace=True)
df_crawl.head()

Group The Keywords

As we approach the final output, it’s necessary to group our keywords together to calculate the total opportunity for each page.

Here, we’re calculating how many keywords are within striking distance for each page, along with the combined search volume.

# groups the URLs (remove the dupes and combines stats)
# make a copy of the keywords dataframe for grouping - this ensures stats can be merged back in later from the OG df
df_keywords_group = df_keywords.copy()
df_keywords_group["KWs in Striking Dist."] = 1  # used to count the number of keywords in striking distance
df_keywords_group = (
    df_keywords_group.groupby("URL")
    .agg({"Volume": "sum", "KWs in Striking Dist.": "count"})
    .reset_index()
)
df_keywords_group.head()
DataFrame showing how many keywords were found within striking distanceScreenshot from Colab.research.google.com, October 2021DataFrame showing how many keywords were found within striking distance

Once complete, you’ll see a preview of the DataFrame.

Display Keywords In Adjacent Rows

We use the grouped data as the basis for the final output. We use Pandas.unstack to reshape the DataFrame to display the keywords in the style of a GrepWords export.

DataFrame showing a grepwords type-view of keywords laid out horizontallyScreenshot from Colab.research.google.com, October 2021DataFrame showing a grepwords type-view of keywords laid out horizontally
# create a new df, combine the merged data with the original data. display in adjacent rows ala grepwords
df_merged_all_kws = df_keywords_group.merge(
    df_keywords.groupby("URL")["Keyword"]
    .apply(lambda x: x.reset_index(drop=True))
    .unstack()
    .reset_index()
)

# sort by biggest opportunity
df_merged_all_kws = df_merged_all_kws.sort_values(
    by="KWs in Striking Dist.", ascending=False
)

# reindex the columns to keep just the top five keywords
cols = "URL", "Volume", "KWs in Striking Dist.", 0, 1, 2, 3, 4
df_merged_all_kws = df_merged_all_kws.reindex(columns=cols)

# create union and rename the columns
df_striking: Union[Series, DataFrame, None] = df_merged_all_kws.rename(
    columns={
        "Volume": "Striking Dist. Vol",
        0: "KW1",
        1: "KW2",
        2: "KW3",
        3: "KW4",
        4: "KW5",
    }
)

# merges striking distance df with crawl df to merge in the title, h1 and category description
df_striking = pd.merge(df_striking, df_crawl, on="URL", how="inner")

Set The Final Column Order And Insert Placeholder Columns

Lastly, we set the final column order and merge in the original keyword data.

There are a lot of columns to sort and create!

# set the final column order and merge the keyword data in

cols = [
    "URL",
    "Title",
    "H1",
    "Copy",
    "Striking Dist. Vol",
    "KWs in Striking Dist.",
    "KW1",
    "KW1 Vol",
    "KW1 in Title",
    "KW1 in H1",
    "KW1 in Copy",
    "KW2",
    "KW2 Vol",
    "KW2 in Title",
    "KW2 in H1",
    "KW2 in Copy",
    "KW3",
    "KW3 Vol",
    "KW3 in Title",
    "KW3 in H1",
    "KW3 in Copy",
    "KW4",
    "KW4 Vol",
    "KW4 in Title",
    "KW4 in H1",
    "KW4 in Copy",
    "KW5",
    "KW5 Vol",
    "KW5 in Title",
    "KW5 in H1",
    "KW5 in Copy",
]

# re-index the columns to place them in a logical order + inserts new blank columns for kw checks.
df_striking = df_striking.reindex(columns=cols)

Merge In The Keyword Data For Each Column

This code merges the keyword volume data back into the DataFrame. It’s more or less the equivalent of an Excel VLOOKUP function.

# merge in keyword data for each keyword column (KW1 - KW5)
df_striking = pd.merge(df_striking, df_keyword_vol, left_on="KW1", right_on="Keyword", how="left")
df_striking['KW1 Vol'] = df_striking['Volume']
df_striking.drop(['Keyword', 'Volume'], axis=1, inplace=True)
df_striking = pd.merge(df_striking, df_keyword_vol, left_on="KW2", right_on="Keyword", how="left")
df_striking['KW2 Vol'] = df_striking['Volume']
df_striking.drop(['Keyword', 'Volume'], axis=1, inplace=True)
df_striking = pd.merge(df_striking, df_keyword_vol, left_on="KW3", right_on="Keyword", how="left")
df_striking['KW3 Vol'] = df_striking['Volume']
df_striking.drop(['Keyword', 'Volume'], axis=1, inplace=True)
df_striking = pd.merge(df_striking, df_keyword_vol, left_on="KW4", right_on="Keyword", how="left")
df_striking['KW4 Vol'] = df_striking['Volume']
df_striking.drop(['Keyword', 'Volume'], axis=1, inplace=True)
df_striking = pd.merge(df_striking, df_keyword_vol, left_on="KW5", right_on="Keyword", how="left")
df_striking['KW5 Vol'] = df_striking['Volume']
df_striking.drop(['Keyword', 'Volume'], axis=1, inplace=True)

Clean The Data Some More

The data requires additional cleaning to populate empty values, (NaNs), as empty strings. This improves the readability of the final output by creating blank cells, instead of cells populated with NaN string values.

Next, we convert the columns to lowercase so that they match when checking whether a target keyword is featured in a specific column.

# replace nan values with empty strings
df_striking = df_striking.fillna("")
# drop the title, h1 and category description to lower case so kws can be matched to them
df_striking["Title"] = df_striking["Title"].str.lower()
df_striking["H1"] = df_striking["H1"].str.lower()
df_striking["Copy"] = df_striking["Copy"].str.lower()

Check Whether The Keyword Appears In The Title/H1/Copy and Return True Or False

This code checks if the target keyword is found in the page title/H1 or copy.

It’ll flag true or false depending on whether a keyword was found within the on-page elements.

df_striking["KW1 in Title"] = df_striking.apply(lambda row: row["KW1"] in row["Title"], axis=1)
df_striking["KW1 in H1"] = df_striking.apply(lambda row: row["KW1"] in row["H1"], axis=1)
df_striking["KW1 in Copy"] = df_striking.apply(lambda row: row["KW1"] in row["Copy"], axis=1)
df_striking["KW2 in Title"] = df_striking.apply(lambda row: row["KW2"] in row["Title"], axis=1)
df_striking["KW2 in H1"] = df_striking.apply(lambda row: row["KW2"] in row["H1"], axis=1)
df_striking["KW2 in Copy"] = df_striking.apply(lambda row: row["KW2"] in row["Copy"], axis=1)
df_striking["KW3 in Title"] = df_striking.apply(lambda row: row["KW3"] in row["Title"], axis=1)
df_striking["KW3 in H1"] = df_striking.apply(lambda row: row["KW3"] in row["H1"], axis=1)
df_striking["KW3 in Copy"] = df_striking.apply(lambda row: row["KW3"] in row["Copy"], axis=1)
df_striking["KW4 in Title"] = df_striking.apply(lambda row: row["KW4"] in row["Title"], axis=1)
df_striking["KW4 in H1"] = df_striking.apply(lambda row: row["KW4"] in row["H1"], axis=1)
df_striking["KW4 in Copy"] = df_striking.apply(lambda row: row["KW4"] in row["Copy"], axis=1)
df_striking["KW5 in Title"] = df_striking.apply(lambda row: row["KW5"] in row["Title"], axis=1)
df_striking["KW5 in H1"] = df_striking.apply(lambda row: row["KW5"] in row["H1"], axis=1)
df_striking["KW5 in Copy"] = df_striking.apply(lambda row: row["KW5"] in row["Copy"], axis=1)

Delete True/False Values If There Is No Keyword

This will delete true/false values when there is no keyword adjacent.

# delete true / false values if there is no keyword
df_striking.loc[df_striking["KW1"] == "", ["KW1 in Title", "KW1 in H1", "KW1 in Copy"]] = ""
df_striking.loc[df_striking["KW2"] == "", ["KW2 in Title", "KW2 in H1", "KW2 in Copy"]] = ""
df_striking.loc[df_striking["KW3"] == "", ["KW3 in Title", "KW3 in H1", "KW3 in Copy"]] = ""
df_striking.loc[df_striking["KW4"] == "", ["KW4 in Title", "KW4 in H1", "KW4 in Copy"]] = ""
df_striking.loc[df_striking["KW5"] == "", ["KW5 in Title", "KW5 in H1", "KW5 in Copy"]] = ""
df_striking.head()

Drop Rows If All Values == True

This configurable option is really useful for reducing the amount of QA time required for the final output by dropping the keyword opportunity from the final output if it is found in all three columns.

def true_dropper(col1, col2, col3):
    drop = df_striking.drop(
        df_striking[
            (df_striking[col1] == True)
            & (df_striking[col2] == True)
            & (df_striking[col3] == True)
        ].index
    )
    return drop

if drop_all_true == True:
    df_striking = true_dropper("KW1 in Title", "KW1 in H1", "KW1 in Copy")
    df_striking = true_dropper("KW2 in Title", "KW2 in H1", "KW2 in Copy")
    df_striking = true_dropper("KW3 in Title", "KW3 in H1", "KW3 in Copy")
    df_striking = true_dropper("KW4 in Title", "KW4 in H1", "KW4 in Copy")
    df_striking = true_dropper("KW5 in Title", "KW5 in H1", "KW5 in Copy")

Download The CSV File

The last step is to download the CSV file and start the optimization process.

df_striking.to_csv('Keywords in Striking Distance.csv', index=False)
files.download("Keywords in Striking Distance.csv")

Conclusion

If you are looking for quick wins for any website, the striking distance report is a really easy way to find them.

Don’t let the number of steps fool you. It’s not as complex as it seems. It’s as simple as uploading a crawl and keyword export to the supplied Google Colab sheet or using the Streamlit app.

The results are definitely worth it!

More Resources:


Featured Image: aurielaki/Shutterstock

!function(f,b,e,v,n,t,s)
{if(f.fbq)return;n=f.fbq=function(){n.callMethod?
n.callMethod.apply(n,arguments):n.queue.push(arguments)};
if(!f._fbq)f._fbq=n;n.push=n;n.loaded=!0;n.version=’2.0′;
n.queue=[];t=b.createElement(e);t.async=!0;
t.src=v;s=b.getElementsByTagName(e)[0];
s.parentNode.insertBefore(t,s)}(window,document,’script’,
‘https://connect.facebook.net/en_US/fbevents.js’);

if( typeof sopp !== “undefined” && sopp === ‘yes’ ){
fbq(‘dataProcessingOptions’, [‘LDU’], 1, 1000);
}else{
fbq(‘dataProcessingOptions’, []);
}

fbq(‘init’, ‘1321385257908563’);

fbq(‘track’, ‘PageView’);

fbq(‘trackSingle’, ‘1321385257908563’, ‘ViewContent’, {
content_name: ‘striking-distance-keywords-python’,
content_category: ‘seo-strategy technical-seo ‘
});

Source link

Keep an eye on what we are doing
Be the first to get latest updates and exclusive content straight to your email inbox.
We promise not to spam you. You can unsubscribe at any time.
Invalid email address

SEO

Google’s Guidance About The Recent Ranking Update

Published

on

By

Google issues a statement about their recent algorithm update

Google’s Danny Sullivan explained the recent update, addressing site recoveries and cautioning against making radical changes to improve rankings. He also offered advice for publishes whose rankings didn’t improve after the last update.

Google’s Still Improving The Algorithm

Danny said that Google is still working on their ranking algorithm, indicating that more changes (for the positive) are likely on the way. The main idea he was getting across is that they’re still trying to fill the gaps in surfacing high quality content from independent sites. Which is good because big brand sites don’t necessarily have the best answers.

He wrote:

“…the work to connect people with “a range of high quality sites, including small or independent sites that are creating useful, original content” is not done with this latest update. We’re continuing to look at this area and how to improve further with future updates.”

A Message To Those Who Were Left Behind

There was a message to those publishers whose work failed to recover with the latest update, to let them know that Google is still working to surface more of the independent content and that there may be relief on the next go.

Danny advised:

“…if you’re feeling confused about what to do in terms of rankings…if you know you’re producing great content for your readers…If you know you’re producing it, keep doing that…it’s to us to keep working on our systems to better reward it.”

Google Cautions Against “Improving” Sites

Something really interesting that he mentioned was a caution against trying to improve rankings of something that’s already on page one in order to rank even higher. Tweaking a site to get from position six or whatever to something higher has always been a risky thing to do for many reasons I won’t elaborate on here. But Danny’s warning increases the pressure to not just think twice before trying to optimize a page for search engines but to think three times and then some more.

Danny cautioned that sites that make it to the top of the SERPs should consider that a win and to let it ride instead of making changes right now in order to improve their rankings. The reason for that caution is that the search results continue to change and the implication is that changing a site now may negatively impact the rankings in a newly updated search index.

He wrote:

“If you’re showing in the top results for queries, that’s generally a sign that we really view your content well. Sometimes people then wonder how to move up a place or two. Rankings can and do change naturally over time. We recommend against making radical changes to try and move up a spot or two”

How Google Handled Feedback

There was also some light shed on what Google did with all the feedback they received from publishers who lost rankings. Danny wrote that the feedback and site examples he received was summarized, with examples, and sent to the search engineers for review. They continue to use that feedback for the next round of improvements.

He explained:

“I went through it all, by hand, to ensure all the sites who submitted were indeed heard. You were, and you continue to be. …I summarized all that feedback, pulling out some of the compelling examples of where our systems could do a better job, especially in terms of rewarding open web creators. Our search engineers have reviewed it and continue to review it, along with other feedback we receive, to see how we can make search better for everyone, including creators.”

Feedback Itself Didn’t Lead To Recovery

Danny also pointed out that sites that recovered their rankings did not do so because of they submitted feedback to Google. Danny wasn’t specific about this point but it conforms with previous statements about Google’s algorithms that they implement fixes at scale. So instead of saying, “Hey let’s fix the rankings of this one site” it’s more about figuring out if the problem is symptomatic of something widescale and how to change things for everybody with the same problem.

Danny wrote:

“No one who submitted, by the way, got some type of recovery in Search because they submitted. Our systems don’t work that way.”

That feedback didn’t lead to recovery but was used as data shouldn’t be surprising. Even as far back as the 2004 Florida Update Matt Cutts collected feedback from people, including myself, and I didn’t see a recovery for a false positive until everyone else also got back their rankings.

Takeaways

Google’s work on their algorithm is ongoing:
Google is continuing to tune its algorithms to improve its ability to rank high quality content, especially from smaller publishers. Danny Sullivan emphasized that this is an ongoing process.

What content creators should focus on:
Danny’s statement encouraged publishers to focus on consistently creating high quality content and not to focus on optimizing for algorithms. Focusing on quality should be the priority.

What should publishers do if their high-quality content isn’t yet rewarded with better rankings?
Publishers who are certain of the quality of their content are encouraged to hold steady and keep it coming because Google’s algorithms are still being refined.

Read the post on LinkedIn.

Featured Image by Shutterstock/Cast Of Thousands

Source link

Keep an eye on what we are doing
Be the first to get latest updates and exclusive content straight to your email inbox.
We promise not to spam you. You can unsubscribe at any time.
Invalid email address
Continue Reading

SEO

Plot Up To Five Metrics At Once

Published

on

By

Plot Up To Five Metrics At Once

Google has rolled out changes to Analytics, adding features to help you make more sense of your data.

The update brings several key improvements:

  • You can now compare up to five different metrics side by side.
  • A new tool automatically spots unusual trends in your data.
  • A more detailed report on transactions gives a closer look at revenue.
  • The acquisition reports now separate user and session data more clearly.
  • It’s easier to understand what each report does with new descriptions.

Here’s an overview of these new features, why they matter, and how they might help improve your data analysis and decision-making.

Plot Rows: Enhanced Data Visualization

The most prominent addition is the “Plot Rows” feature.

You can now visualize up to five rows of data simultaneously within your reports, allowing for quick comparisons and trend analysis.

This feature is accessible by selecting the desired rows and clicking the “Plot Rows” option.

Anomaly Detection: Spotting Unusual Patterns

Google Analytics has implemented an anomaly detection system to help you identify potential issues or opportunities.

This new tool automatically flags unusual data fluctuations, making it easier to spot unexpected traffic spikes, sudden drops, or other noteworthy trends.

Improved Report Navigation & Understanding

Google Analytics has added hover-over descriptions for report titles.

These brief explanations provide context and include links to more detailed information about each report’s purpose and metrics.

Key Event Marking In Events Report

The Events report allows you to mark significant events for easy reference.

This feature, accessed through a three-dot menu at the end of each event row, helps you prioritize and track important data points.

New Transactions Report For Revenue Insights

For ecommerce businesses, the new Transactions report offers granular insights into revenue streams.

This feature provides information about each transaction, utilizing the transaction_id parameter to give you a comprehensive view of sales data.

Scope Changes In Acquisition Reports

Google has refined its acquisition reports to offer more targeted metrics.

The User Acquisition report now includes user-related metrics such as Total Users, New Users, and Returning Users.

Meanwhile, the Traffic Acquisition report focuses on session-related metrics like Sessions, Engaged Sessions, and Sessions per Event.

What To Do Next

As you explore these new features, keep in mind:

  • Familiarize yourself with the new Plot Rows function to make the most of comparative data analysis.
  • Pay attention to the anomaly detection alerts, but always investigate the context behind flagged data points.
  • Take advantage of the more detailed Transactions report to understand your revenue patterns better.
  • Experiment with the refined acquisition reports to see which metrics are most valuable for your needs.

As with any new tool, there will likely be a learning curve as you incorporate these features into your workflow.


FAQ

What is the “Plot Rows” feature in Google Analytics?

The “Plot Rows” feature allows you to visualize up to five rows of data at the same time. This makes it easier to compare different metrics side by side within your reports, facilitating quick comparisons and trend analysis. To use this feature, select the desired rows and click the “Plot Rows” option.

How does the new anomaly detection system work in Google Analytics?

Google Analytics’ new anomaly detection system automatically flags unusual data patterns. This tool helps identify potential issues or opportunities by spotting unexpected traffic spikes, sudden drops, or other notable trends, making it easier for users to focus on significant data fluctuations.

What improvements have been made to the Transactions report in Google Analytics?

The enhanced Transactions report provides detailed insights into revenue for ecommerce businesses. It utilizes the transaction_id parameter to offer granular information about each transaction, helping businesses get a better understanding of their revenue streams.


Featured Image: Vladimka production/Shutterstock



Source link

Keep an eye on what we are doing
Be the first to get latest updates and exclusive content straight to your email inbox.
We promise not to spam you. You can unsubscribe at any time.
Invalid email address
Continue Reading

SEO

Top 10 Affiliate Marketing Platforms To Maximize Sales In 2024

Published

on

By

Top 10 Affiliate Marketing Platforms To Maximize Sales In 2024

Affiliate marketing has been experiencing explosive growth in recent years, so it’s essential now more than ever for brands to run affiliate programs of their own.

It involves brands hiring affiliates to promote their products and services and rewarding them with a commission from every sale.

As such, affiliate marketing is an excellent low-cost and low-risk way for brands to drive sales and brand awareness without hiring an in-house advertising and marketing team of their own.

Affiliate marketing spending worldwide is estimated at around $14 billion in 2024 – and the industry is predicted to reach a worth of over $38 billion by 2031.

Affiliate Marketing And SEO

Affiliate marketing and search engine optimization (SEO) both share a common goal of attracting relevant and high-quality traffic to a site with the goal of increasing sales.

As such, both of these marketing activities shouldn’t be perceived as two separate, competing entities.

Instead, you should look at them as one and the same that work together in perfect harmony to increase website traffic and generate more revenue.

The most successful publishers in the affiliate marketing space combine the two to get the best of both worlds.

SEO affiliate marketing involves choosing the right products and affiliate programs that attract the most search traffic and offer the best commissions.

Publishers often make the most of affiliate marketing by creating content that adds real value for their readers and prioritizes their experience.

Publishers often do this by creating “Best of” or “Top X” oriented posts that address their audience’s needs and pain points, while, at the same time, allowing them to monetize their content by using affiliate links throughout the posts.

By adding relevant and contextual affiliate links in such posts, publishers foster an authentic user experience that puts their readers first.

This is one of the most significant advantages of affiliate marketing compared to alternative marketing methods such as sponsored posts.

Today’s consumers are increasingly distancing themselves from heavily business-oriented content, as it’s often perceived as inauthentic and disingenuous.

By focusing on high-quality content that adds value to readers and combining it with relevant and contextual affiliate links, everyone wins!

Additionally, Google rewards publishers who create original content and add real value for their readers.

They reward such publishers by placing them higher in search results and driving more traffic to them.

But, in today’s highly competitive and increasingly dynamic market, how can brands find the time to manage and grow their affiliate marketing program?

The answer is with the help of the right affiliate marketing software that streamlines the entire process.

Once upon a time, running a successful affiliate marketing program meant manually managing every aspect – a time-consuming and inefficient process.

Thankfully, these days, affiliate marketing software and solutions have evolved to offer all the necessary tools in a single place, which simplifies the whole process and enables brands to optimize their programs and focus on growth.

Therefore, brands need to utilize the right affiliate marketing software to stay competitive and maximize ROI in today’s highly competitive affiliate marketing space.

This article will go over what affiliate marketing software is and what makes a great affiliate software platform.

We’ll also review the top 10 affiliate marketing software platforms that brands can use to take their affiliate program to the next level.

What Is An Affiliate Marketing Software?

In a nutshell, affiliate marketing software is a comprehensive tool that facilitates all aspects of affiliate marketing program management.

It allows brands to track, manage, and grow their affiliate marketing campaigns.

Most affiliate marketing software platforms share standard features such as affiliate onboarding, collaboration with affiliate partners, affiliate tracking and reporting, and referral, cost, and commission payment management.

What Makes A Good Affiliate Marketing Software Platform?

Though most affiliate marketing software platforms share many of the same features, what sets apart the good platforms from the bad is what’s important.

For starters, the actual platform must have an intuitive and user-friendly interface.

An affiliate marketing platform can boast all of the best affiliate tools and features available.

Still, it’s a moot effort if the dashboard is complicated for most people.

Additionally, since brands usually utilize a variety of Software as a Service (SaaS) platforms for ecommerce and affiliate marketing, affiliate marketing software platforms need to offer tons of third-party SaaS integrations.

The best affiliate marketing software platforms offer robust tracking and reporting capabilities.

Brands need to be able to precisely track their affiliate sales and access real-time granular data to measure the ROI of their affiliate campaigns effectively.

Additionally, a good affiliate marketing platform will provide brands with all the affiliate tools they need to launch, manage, promote, and scale their affiliate programs, such as flexible commission management and customizable real-time affiliate tracking and reporting capabilities.

At the same time, they should offer their clients peace of mind by providing the highest level of fraud detection and other security features.

Lastly, the best affiliate marketing software platforms mean nothing if there isn’t quality customer service available 24/7 to back it up. Readily available customer assistance is equally important for brands as it is for affiliates.

Top 10 Affiliate Marketing Software

1. Refersion

Screenshot from refersion.com, August 2024

With over 60,000+ registered merchants, 6.6 million affiliates managed, and $2 billion in affiliate revenue tracked, Refersion is one of the leading affiliate marketing software platforms on the market.

Its robust and highly personalized dashboard allows brands to manage all aspects of their affiliate program, such as monitoring all aspects of their affiliate activity with extensive real-time reporting capability.

Refersion offers brands all the tools they need to scale and promote their affiliate programs, such as managing commissions, payouts, and providing simplified tax automation. It also offers easy integration with popular tools like Shopify, WooCommerce, and BigCommerce.

While Refersion does come with a higher price point than some competitors – starting at $99 per month – it’s hard to find a solution that offers the same level of top-notch affiliate tools, marketplace, and customer service.

Pricing:

  • The professional tier starts at $99/month (if paid annually) for up to 50 monthly order conversions.
  • The business tier starts at $249/month (if paid annually) for up to 200 monthly order conversions.
  • The enterprise tier is available with unlimited monthly order conversions – you’ll need to contact Refersion for pricing details.

2. Impact

ImpactScreenshot from Impact.com, August 2024

Impact is one of the biggest affiliate marketing software platforms for cloud automation.

Its signature product, the Impact Partnership Cloud, allows brands to automate their affiliate and influencer marketing campaigns. It offers a marketplace where brands can connect with a network of affiliates, influencers, ambassadors, and other possible partners.

The platform’s tools also include dynamic commissioning, reporting, advanced analytics, and third-party integrations for companies to track and manage their affiliate programs.

However, pricing is not readily available, and you must contact the Impact sales team for a custom quote.

Pricing:

  • Custom quotes are available upon request.

3. Tapfiliate

TapfiliateScreenshot from Tapfiliate.com, August 2024

For businesses primarily operating and generating their revenue on ecommerce SaaS platforms, Tapfiliate may be a great choice.

It features a range of automation capabilities, including an autopilot mode that can automate things such as onboarding new affiliates, sharing via social media, or even drip campaigns.

Tapfiliate easily integrates with major ecommerce players like Shopify and WooCommerce, and offers advanced tracking and reporting capabilities. However, most of the features are accessible only through the Pro plan, which starts at $149 a month – nothing to sneeze at.

Pricing:

  • The essential plan starts at $74/month for 1 team member and basic features.
  • The pro plan starts at $124/month for 5 team members and more advanced features.
  • The enterprise plan offers custom pricing for unlimited team members, unlimited tracking requests, a dedicated personal manager, and more.

4. Awin

AwinScreenshot from Awin.com, August 2024

Awin, previously known as Zanox, merged with Affilinet in 2017 to become one of the largest affiliate marketing platforms, providing “unlimited access to over 1M vetted partners.”

It features a handful of marketing and reporting features you’d expect from such an extensive network, like tools for cross-device tracking, real-time reporting, and automated compliance management.

The platform’s Awin Access program is an interesting option for smaller businesses or teams newer to affiliate marketing, as it offers a straightforward setup process and flexible pricing to make joining the network easier.

Registration is free on Awin, but it uses a performance-based pricing model. This means brands pay a predetermined cost-per-acquisition (CPA), and specific pricing details are only available upon request.

Pricing:

  • Custom quotes are available upon request.

5. CAKE

CAKEScreenshot from getcake.com, August 2024

CAKE is another SaaS-based affiliate marketing platform, meaning you can access it from anywhere (with an Internet connection).

CAKE partners with a bunch of partners to offer a variety of streamlined and automated features. It’s known for its great tracking and reporting capabilities, which enable you to follow and optimize your campaigns in real time.

The platform boasts more than 500 advertisers, networks, and publishers across 50+ countries, and it offers 24/7 customer support to its users. It has customizable features, granular data analysis, and impressive fraud protection to give customers peace of mind.

Unfortunately, CAKE’s pricing is not readily available on its website. It also doesn’t feature any pre-made promotional tools for marketers, which doesn’t make it quite suitable for novice users just starting out with their affiliate program

Pricing:

  • Custom quotes are available upon request.

6. ClickBank

ClickBankScreenshot from ClickBank.com, August 2024

ClickBank was one of the first affiliate platforms, launching all the way back in 1998. Since then, it’s grown to one of the largest affiliate marketplaces with over 200 million customers.

According to the company’s website, there are 300,000+ daily purchases made on ClickBank – and it boasts $4.2B in paid commissions.

ClickBank stands out for its native support for subscription services, which makes it easy for brands to create one-click, repeatable purchases. This allows them to provide monthly products without requiring manual monthly payments.

It also offers some of the standard features commonly found on most affiliate platforms, such as affiliate reporting, payments, commissions management, and third-party integrations. It’s quick and easy to list your products and set up affiliate programs on the platform.

However, compared to some of the other affiliate platforms on this list, it doesn’t offer a demo, free trial, or monthly pricing. Instead, ClickBank charges a one-time activation to list products on the platform and then a fee per sale.

Pricing:

  • One-Time Activation Fee: $49.95.
  • Transaction Fee: 7.5% + $1 per sale.

7. CJ Affiliate

CJ AffiliateScreenshot from cj.com, August 2024

CJ Affiliate is a well-known and reputable affiliate marketing platform. It offers access to hundreds of advertisers, publishers, and potential partners in one platform.

CJ Affiliate provides a customizable dashboard and a variety of reports and specialized tools, including advanced tracking and reporting capabilities. Most notably, it offers specialized tools, such as Deep Link Automation and Product Widgets, that enable brands to improve their affiliate program ROI.

While CJ Affiliate is a great choice for businesses of all sizes, it’s worth noting that the company doesn’t provide a free trial or demo, operates on a performance-based pricing model, and you’ll need to reach out for specific details.

Pricing:

  • Custom quotes are available upon request.

8. TUNE

TUNEScreenshot from Tune.com, August 2024

Designed for companies that require detailed tracking and analytics, TUNE allows brands to build, manage, and grow their affiliate partner networks through its proprietary marketing technology.

TUNE offers a flexible platform, which users can tweak and tailor to fit their needs. Within the platform, you have customizable tools, commissions, payments, and real-time affiliate tracking and reporting.

However, it doesn’t provide affiliate promotional tools like most other platforms, and there is no straightforward pricing listed on the website.

It does, however, list details on its different plans, including a Pro Plan with basic features up to an Enterprise Plan with features like custom integrations, premium support, enhanced fraud prevention, and more.

Pricing:

  • Custom quote available upon request.

9. LeadDyno

LeadDynoScreenshot from LeadDyno.com, August 2024

LeadDyno specializes in affiliate program promotion and perhaps offers the most promotional tools available in an affiliate marketing software platform.

LeadDyno offers tools that enable brands to create various promotional campaigns, such as email, newsletters, and social media campaigns, making it a wonderful choice for companies that want to expand the reach of their programs.

It provides a straightforward user experience that makes it easy to onboard affiliates, track your performance, and manage payouts. Extensive real-time tracking and reporting features give businesses the ability to monitor and optimize their campaigns.

Pricing is on the affordable side and LeadDyno offers a free trial – which not all tools on this list do!

Pricing:

  • The lite plan starts at $49/month for up to 50 active affiliates, one commission plan, one reward structure, and other basics.
  • The essential plan is $129.month and offers up to 150 active affiliates, three commission plans, and one reward structure, as well as other advanced features like a landing page, 1:1 call and video support, and more.
  • The advanced plan is $349/month and offers up to 500 active affiliates, unlimited reward structures and commission plans, and many other advanced features.
  • The unlimited plan is $749/month and offers unlimited active affiliates, unlimited reward structures and commission plans, and more.

10. ShareASale

ShareASaleScreenshot from ShareASale.com, August 2024

With over 20 years of experience, ShareASale has been around for quite some time. It’s a reliable solution for merchants and affiliates alike, and carries a variety of tools to help boost your affiliate marketing programs.

If you’re looking for an extensive network of affiliates and partners across a ton of industries, ShareASale is a good option for you. You’ll also get access to customizable affiliable management, real-time tracking, detailed reporting, custom banner, and link generation, and plenty more.

One thing to note: like a few of the other tools listed here, ShareASale uses a performance-based pricing model that includes a one-time network access fee and then transaction fees.

Pricing:

  • There is a one-time setup fee of $650.
  • Transaction fees: 20% of each affiliate commission, with a minimum of $35/month.

Wrapping Up

Great affiliate marketing solutions enable brands to easily launch and manage affiliate programs, as well as track referrals and sales made by their affiliate partners.

The best affiliate marketing software provides brands with all the tools needed to launch, promote, and grow their affiliate program.

At the same time, they provide customizable and easy-to-use reporting capabilities for real-time performance tracking.

Without reliable tracking and reporting tools, brands cannot effectively assess the success and profitability of their affiliate campaigns and partnerships.

More resources:


Featured Image: Panchenko Vladimir/Shutterstock

Source link

Keep an eye on what we are doing
Be the first to get latest updates and exclusive content straight to your email inbox.
We promise not to spam you. You can unsubscribe at any time.
Invalid email address
Continue Reading

Trending