SEO
Using Python + Streamlit To Find Striking Distance Keyword Opportunities
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:
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:
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!)
Next, it’s on to the Extraction tab.
Configuration > Spider > Extraction
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.
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
After clicking Export, It’s important to make sure the type is set to CSV format.
The export screen should look like the below:
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).
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
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.
Site Explorer > Organic Keywords
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.
Here’s how to do it in Ahrefs.
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.
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.
The script will prompt you to upload the keyword CSV from Ahrefs or Semrush first and the crawl file afterward.
That’s it! The script will automatically download an actionable CSV file you can use to optimize your site.
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.
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.
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()
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.
# 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: ‘python-seo-striking-distance’,
content_category: ‘seo-strategy technical-seo’
});
SEO
How To Create High-Quality Content
SEO success depends on providing high-quality content to your audiences. The big question is: What exactly does “high quality” mean?
Content has many meanings. In digital marketing, it simply means the information a website displays to users.
But don’t forget: In a different context with a different emphasis on the word (content as opposed to content), content is a synonym for happy and satisfied. The meaning is different, but the letters are the same.
If you want to understand content quality online, keep these two different definitions in mind.
Every webpage has content. “High-quality” content depends on contexts like:
- What the needs of your audience are.
- What users expect to find.
- How the content is presented and how easy it is to pull critical information out of it quickly.
- How appropriate the medium of the content is for users’ needs.
What Makes Content High Quality?
This is a complex question that we hope to answer in full during this article. But let’s start with a simple statement:
High-quality content is whatever the user needs at the time they’re looking for it.
This might not be helpful in a specific sense but note this somewhere because it’s a guiding light that has far-reaching implications for your website and audience strategy.
We use this definition because the quality of your content isn’t static. Google and other search engines know this and frequently update search engine results pages (SERPs) and algorithms to adjust for changing user priorities.
You need to bake this idea into your understanding of content and audiences. You can have the most beautifully written, best-formatted content, but if your target audience doesn’t need that information in that format, it’s not “high-quality” for SEO.
If you provide a story when the user is looking for a two-sentence answer, then you’re not serving their interests.
This is especially pertinent with the introduction of generative AI features into search platforms. This is a continuation of a “zero click” phenomenon for certain types of searches and why Google doesn’t send a user to a website for these searches.
Defining & Meeting Audience Needs
SEO professionals have many different ways of conceptualizing these ideas. One of the most common is “the funnel,” which categorizes content into broad categories based on its position in a marketing journey.
The funnel is usually categorized something like this:
- Top of the funnel: Informational intent and awareness-building content.
- Middle of the funnel: Consideration intent and product/service-focused content.
- Bottom of the funnel: Purchase intent and conversion content.
While it’s helpful to categorize types of content by their purpose in your marketing strategy, this can be an overly limiting view of user intent and encourages linear thinking when you conceptualize user journeys.
As Google gets more specific about intent, such broad categorization becomes less helpful in determining whether content meets users’ needs.
Build a list of verbs that describe the specific needs of your audience while they’re searching. Ideally, you should base this on audience research and data you have about them and their online activity.
Learn who they follow, what questions they ask, when a solution seems to satisfy them, what content they engage with, etc.
Then, create verb categories to apply to search terms during your keyword research. For example:
- Purchase.
- Compare.
- Discover.
- Learn.
- Achieve.
- Check.
User Intends To Purchase
If the user is looking for something to buy, then high quality probably looks like a clean landing or product page that’s easy to navigate. Be sure to include plenty of detail so search engines can match your page to specific parameters the user might enter or have in their search history.
Product photos and videos, reviews and testimonials, and Schema markup can all help these pages serve a better experience and convert. Pay particular attention to technical performance and speed.
Remember that you’re highly likely to go up against ads on the SERPs for these queries, and driving traffic to landing pages can be difficult.
User Intends To Compare
This could take a couple of different forms. Users might come to you for reviews and comparisons on other things or to compare your benefits to those of another company.
For this content to be successful, you need to be dialed into what problems a user is trying to solve, what pain points they have, and how specific differences impact their outcomes.
This is the old “features vs. benefits” marketing argument, but the answer is “both.” Users could want to see all the features listed, but don’t forget to contextualize how those features solve specific problems.
User Intends To Discover
This intent could describe a user looking for industry news, data to support their research, or new influencers to follow.
Prioritize the experience they’re seeking and ensure that the discovery happens quickly.
This could look like adding text summaries or videos to the top of posts, tables of contents to assist with navigation, or page design elements that highlight the most critical information.
User Intends To Learn
If a user intends to learn about a topic, a long, well-organized post, video, or series of either may serve them best. This content should be in-depth, well-organized, and written by genuine topic experts. You may need to demonstrate the author’s qualifications to build trust with readers.
You must consider the existing knowledge level of your target audience. Advanced content will not satisfy the needs of inexperienced users, while basic content will bore advanced users.
Don’t try to satisfy both audiences in a single experience. It’s tempting to include basic questions in this type of content to target more SEO keywords, but think about whether you’re trading keywords for user experience.
For example, if you write a post about “how to use a straight razor” and your subheadings look like the ones below, you’re probably not serving the correct intent.
- What is a straight razor?
- Are straight razors dangerous?
- Should I use a straight razor?
The chances are high that someone landing on your page “how to use a straight razor” doesn’t need answers to these basic questions. In other words, you’re wasting their time.
User Intends To Achieve
A slightly different intent from learning. In this instance, a user has a specific goal for an action they want to perform. Like learning content, it should be written by subject matter experts.
If the person creating this content doesn’t have sufficient first-hand experience, they won’t effectively guide users and predict their real-world needs. This results in unsatisfying content and a failure point of many SEO content strategies.
In SEJ’s SEO Trends 2024 ebook, Mordy Oberstein, Head of SEO Brand at Wix, said:
“One trend I would get ahead of that aligns with Google’s focus on expertise and experience is what I’m coining “situational content.” Situational content attempts to predict the various outcomes of any advice or the like offered within the content to present the next logical steps. If, for example, a piece of content provides advice about how to get a baby to sleep through the night, it would then offer the next steps if that advice didn’t work.
This is “situational” – if X doesn’t work, you might want to try Y. Situational content creates a compelling form of content I see more frequently. It does a few things for the reader:
- It addresses them and their needs directly.
- It’s more conversational than standard content (an emerging content
trend itself).- To predict various outcomes and situations, you have to actually know what
you’re talking about.That latter point directly addresses E-E-A-T. You can only predict and address secondary situations with expertise and experience. Most of all, situational content indicates to the user that a real person, not a large language model (LLM), wrote it.”
The difference between “learn” and “achieve” intents can be difficult to see. Sometimes, you might need to satisfy both. Pay careful attention to these types of content.
User Intends To Check
Misunderstanding when a user just wants to “check” something can cause you to waste resources on content doomed not to perform, and another failure point of SEO strategies. If what a user needs can be solved in a few sentences, you’re in zero-click territory.
For example, ‘How to tie a bowtie’.
That is, Google will serve users an answer on the SERP, and they may not click a link at all. You may want to target these types of queries as part of longform content for other search intents using good content organization and Schema markup.
That way, you can give your authoritative and in-depth content opportunities to show up in rich results on SERPs, and users might click through if they see more information available or have follow-up questions.
You should consider these intents part of your SEO strategy, but think of them as awareness and branding tactics. AI features such as AI Overviews in Google seek to surface quick answers to queries. It will be much harder to acquire clicks on SERPs where features like this are activated.
If you struggle to understand why well-written content is losing traffic, you should assess whether you wrote hundreds of words to answer a query that only needed 30.
More intents exist, and to complicate matters further, they are not exclusive to each other in a single piece of content. Comparison and discovery intents, for example, often combine in listicles, product comparisons, and titles like “X alternatives to X.”
More reading about user intent:
Continue reading this article 👇
Content Quality Signifiers
While there’s no quantifiable answer to what good content means, there are many ways to evaluate it to ensure it contains key signs of quality.
Google’s content guidelines provide some questions you can ask yourself to objectively assess your content’s quality.
The SEO content mantra is E-E-A-T: Experience, Expertise, Authoritativeness, and Trustworthiness.
Google uses many signals to approximate these concepts and apply these signals to ranking algorithms. To be clear, E-E-A-T are not ranking factors themselves. But they are the concepts that ranking systems attempt to emulate via other signals.
These concepts apply to individual pages and to websites as a whole.
Experience: Are the people creating content directly knowledgeable about the subject matter, and do you demonstrate credible experience?
Expertise: Does your content demonstrate genuine expertise through depth, accuracy, and relevance?
Authoritativeness: Is your website an authoritative source about the topic?
Trust: Is your website trustworthy, considering the information or purposes at hand?
In its content guidelines, Google says this about E-E-A-T:
“Of these aspects, trust is most important. The others contribute to trust, but content doesn’t necessarily have to demonstrate all of them. For example, some content might be helpful based on the experience it demonstrates, while other content might be helpful because of the expertise it shares.”
Understanding these concepts is critical for building a content strategy because publishing content with poor E-E-A-T signals could impact your website as a whole. Google’s language downplays this potential impact, but it’s critical to know that it’s possible. It’s tempting to assume that because a website has high “authority” in a general sense or in one particular area, anything it publishes is considered authoritative. This may not be true.
If you chase traffic by creating content outside your core areas of authority and expertise, that content may perform poorly and drag the rest of your site down.
More reading about E-E-A-T:
Continue reading this article 👇
Creating Effective SEO Content
This article focuses on written content, but don’t neglect multimedia in your content strategy.
The thought process behind content should go a little bit like this:
Audience > Query (Keywords) > Intent > Brief / Outline > Create
You can also express it as a series of questions:
- Audience: Who is our audience?
- Query: What are they searching for?
- Intent: Why?
- Brief: How can we best assist them?
- Create: What does exceptional user experience look like?
Keyword Research For Content
Keyword research is a massive topic on its own, so here are some key pieces of advice and a few additional resources:
- Look at the SERPs for the keywords you target to understand what Google prioritizes, what your competitors are doing, what success looks like, and whether there are gaps you can fill.
- Cluster related keywords together and develop a content strategy that covers multiple branching areas of a topic deeply.
- High search volume often means high competition. Allocate your resources carefully between acquiring lower competition positions and fighting for a slice of competitive traffic.
- Building a robust catalog of content focused on long-tail keywords can help you acquire the authority to compete in more competitive SERPs for related topics.
More reading about keyword research:
Continue reading this article 👇
Briefing SEO Content
Once you have performed your research and identified the intents you must target, it’s time to plan the content.
SEO professionals may not have the required knowledge to create content that demonstrates experience and expertise – unless they’re writing about SEO.
They’re SEO specialists, so if your website is about finance or razor blades, someone else will need to provide the knowledge.
Briefing is critical because it allows the SEO team to communicate all that hard work and research to the person or team creating the content. A successful brief should inform the content creators:
- The target keyword strategy, with suggestions or a template for the title and subheadings.
- The purpose of the content for the user: What the user should learn or be able to accomplish.
- The purpose of the content for the business: Where it falls into the marketing strategy and relevant KPIs.
- Details such as length, style guide or voice notes, and key pieces of information to be included.
Creating SEO Content
Your research should guide the format of your writing.
Remember, intent impacts the usability of different types of content. Prioritize the information most likely to solve the user’s intent.
You can do this by providing summaries, tables of contents, videos, pictures, skip links, and, most importantly, headings.
Use The Title & Headings To Target Keywords & Organize Information
The title of a page is your primary keyword opportunity. It’s also the first thing users will see on a SERP, which impacts CTR. Match the title to your target query and think about effectively describing the content to entice a click. But don’t misrepresent your page for clicks.
Your primary responsibility in SEO content is to set expectations and then deliver on them. Don’t set if you can’t deliver.
HTML heading formats help users navigate the page by breaking up blocks of text and indicating where certain topics are covered. They’re critical to your on-page SEO, so use your keywords.
Expectations are as true for headings as for titles. Headings should be descriptive and useful. Prioritize setting an expectation for what the user will find on that part of the page and then delivering on that expectation.
More reading about headings:
Continue reading this article 👇
Get To The Point
Whether content should be long or short is subjective to its purpose. All SEO content should be as short as possible while achieving its goals. “As short as possible” could mean 4,000 words.
If you need 4,000 words to achieve your goal, then use them. But don’t add any more than you need.
This is a call to avoid rambling, especially in introductions. Do you really need to cite the projected growth of an industry just to prove it’s worth talking about?
Not unless you’re writing a news story about that growth. Cut that sentence and the link to Statista from your introduction. (No shade, Statista, you rock.)
Features like skip links can also help with this. Give users the option to skim and skip directly to what they need.
Use Internal Links To Connect Your Pages Together & Provide Further Reading
Internal links are the bedrock of SEO content strategies. They are how you organize related pages and guide users around your website. They also spread the SEO value of your pages to the pages they’re connected to.
In the keyword research section, we suggested that you create clusters of keywords and topics to write about – this is why. You build authority by covering a topic in-depth and creating multiple pages exploring it and all its subtopics.
You should link between pages related to one another at contextually important points in the content. You can use this tactic to direct the SEO power of multiple pages to one important page for your strategy or your business.
Contextually relevant links that properly set expectations for what the user will find also contribute to a good site experience.
More reading about internal linking:
Continue reading this article 👇
Use Personal Experiences And Unique Expertise To Stand Out
AI presents numerous challenges for SEOs. Anyone can quickly create content at scale using generative AI tools.
The tools can replicate competitors, synthesize content together from myriad sources, and enable breakneck publishing paces. This poses two core problems:
- How do you stand out with so much AI content out there?
- How do you build trust in audiences looking for legitimate experts?
For now, the best answer is to lean into the E-E-A-T principles that Google prioritizes.
- Tell human stories with your content that demonstrate your experience and expertise.
- Use Oberstein’s “situational content” principle, mentioned earlier in this article, to connect with your audience’s experiences and needs.
- Ensure that content is created by verifiable experts, especially if that content involves topics that can impact the audience’s well-being (YMYL.)
SEO Content Is Both A Strategy & An Individual Interaction
It’s easy to focus on what you need from users: what keyword you want to rank for, what you want users to click, and what actions you want them to take.
But all of that falls apart if you don’t honor the individual interaction between your website and a user who needs something.
Audience-first content is SEO content. Content is a core function of SEO because it’s the basis of how humans and algorithms understand your website.
More resources:
Featured Image: Art_Photo/Shutterstock
SEO
The Expert SEO Guide To URL Parameter Handling
In the world of SEO, URL parameters pose a significant problem.
While developers and data analysts may appreciate their utility, these query strings are an SEO headache.
Countless parameter combinations can split a single user intent across thousands of URL variations. This can cause complications for crawling, indexing, visibility and, ultimately, lead to lower traffic.
The issue is we can’t simply wish them away, which means it’s crucial to master how to manage URL parameters in an SEO-friendly way.
To do so, we will explore:
What Are URL Parameters?
URL parameters, also known as query strings or URI variables, are the portion of a URL that follows the ‘?’ symbol. They are comprised of a key and a value pair, separated by an ‘=’ sign. Multiple parameters can be added to a single page when separated by an ‘&’.
The most common use cases for parameters are:
- Tracking – For example ?utm_medium=social, ?sessionid=123 or ?affiliateid=abc
- Reordering – For example ?sort=lowest-price, ?order=highest-rated or ?so=latest
- Filtering – For example ?type=widget, colour=purple or ?price-range=20-50
- Identifying – For example ?product=small-purple-widget, categoryid=124 or itemid=24AU
- Paginating – For example, ?page=2, ?p=2 or viewItems=10-30
- Searching – For example, ?query=users-query, ?q=users-query or ?search=drop-down-option
- Translating – For example, ?lang=fr or ?language=de
SEO Issues With URL Parameters
1. Parameters Create Duplicate Content
Often, URL parameters make no significant change to the content of a page.
A re-ordered version of the page is often not so different from the original. A page URL with tracking tags or a session ID is identical to the original.
For example, the following URLs would all return a collection of widgets.
- Static URL: https://www.example.com/widgets
- Tracking parameter: https://www.example.com/widgets?sessionID=32764
- Reordering parameter: https://www.example.com/widgets?sort=latest
- Identifying parameter: https://www.example.com?category=widgets
- Searching parameter: https://www.example.com/products?search=widget
That’s quite a few URLs for what is effectively the same content – now imagine this over every category on your site. It can really add up.
The challenge is that search engines treat every parameter-based URL as a new page. So, they see multiple variations of the same page, all serving duplicate content and all targeting the same search intent or semantic topic.
While such duplication is unlikely to cause a website to be completely filtered out of the search results, it does lead to keyword cannibalization and could downgrade Google’s view of your overall site quality, as these additional URLs add no real value.
2. Parameters Reduce Crawl Efficacy
Crawling redundant parameter pages distracts Googlebot, reducing your site’s ability to index SEO-relevant pages and increasing server load.
Google sums up this point perfectly.
“Overly complex URLs, especially those containing multiple parameters, can cause a problems for crawlers by creating unnecessarily high numbers of URLs that point to identical or similar content on your site.
As a result, Googlebot may consume much more bandwidth than necessary, or may be unable to completely index all the content on your site.”
3. Parameters Split Page Ranking Signals
If you have multiple permutations of the same page content, links and social shares may be coming in on various versions.
This dilutes your ranking signals. When you confuse a crawler, it becomes unsure which of the competing pages to index for the search query.
4. Parameters Make URLs Less Clickable
Let’s face it: parameter URLs are unsightly. They’re hard to read. They don’t seem as trustworthy. As such, they are slightly less likely to be clicked.
This may impact page performance. Not only because CTR influences rankings, but also because it’s less clickable in AI chatbots, social media, in emails, when copy-pasted into forums, or anywhere else the full URL may be displayed.
While this may only have a fractional impact on a single page’s amplification, every tweet, like, share, email, link, and mention matters for the domain.
Poor URL readability could contribute to a decrease in brand engagement.
Assess The Extent Of Your Parameter Problem
It’s important to know every parameter used on your website. But chances are your developers don’t keep an up-to-date list.
So how do you find all the parameters that need handling? Or understand how search engines crawl and index such pages? Know the value they bring to users?
Follow these five steps:
- Run a crawler: With a tool like Screaming Frog, you can search for “?” in the URL.
- Review your log files: See if Googlebot is crawling parameter-based URLs.
- Look in the Google Search Console page indexing report: In the samples of index and relevant non-indexed exclusions, search for ‘?’ in the URL.
- Search with site: inurl: advanced operators: Know how Google is indexing the parameters you found by putting the key in a site:example.com inurl:key combination query.
- Look in Google Analytics all pages report: Search for “?” to see how each of the parameters you found are used by users. Be sure to check that URL query parameters have not been excluded in the view setting.
Armed with this data, you can now decide how to best handle each of your website’s parameters.
SEO Solutions To Tame URL Parameters
You have six tools in your SEO arsenal to deal with URL parameters on a strategic level.
Limit Parameter-based URLs
A simple review of how and why parameters are generated can provide an SEO quick win.
You will often find ways to reduce the number of parameter URLs and thus minimize the negative SEO impact. There are four common issues to begin your review.
1. Eliminate Unnecessary Parameters
Ask your developer for a list of every website’s parameters and their functions. Chances are, you will discover parameters that no longer perform a valuable function.
For example, users can be better identified by cookies than sessionIDs. Yet the sessionID parameter may still exist on your website as it was used historically.
Or you may discover that a filter in your faceted navigation is rarely applied by your users.
Any parameters caused by technical debt should be eliminated immediately.
2. Prevent Empty Values
URL parameters should be added to a URL only when they have a function. Don’t permit parameter keys to be added if the value is blank.
In the above example, key2 and key3 add no value, both literally and figuratively.
3. Use Keys Only Once
Avoid applying multiple parameters with the same parameter name and a different value.
For multi-select options, it is better to combine the values after a single key.
4. Order URL Parameters
If the same URL parameter is rearranged, the pages are interpreted by search engines as equal.
As such, parameter order doesn’t matter from a duplicate content perspective. But each of those combinations burns crawl budget and split ranking signals.
Avoid these issues by asking your developer to write a script to always place parameters in a consistent order, regardless of how the user selected them.
In my opinion, you should start with any translating parameters, followed by identifying, then pagination, then layering on filtering and reordering or search parameters, and finally tracking.
Pros:
- Ensures more efficient crawling.
- Reduces duplicate content issues.
- Consolidates ranking signals to fewer pages.
- Suitable for all parameter types.
Cons:
- Moderate technical implementation time.
Rel=”Canonical” Link Attribute
The rel=”canonical” link attribute calls out that a page has identical or similar content to another. This encourages search engines to consolidate the ranking signals to the URL specified as canonical.
You can rel=canonical your parameter-based URLs to your SEO-friendly URL for tracking, identifying, or reordering parameters.
But this tactic is not suitable when the parameter page content is not close enough to the canonical, such as pagination, searching, translating, or some filtering parameters.
Pros:
- Relatively easy technical implementation.
- Very likely to safeguard against duplicate content issues.
- Consolidates ranking signals to the canonical URL.
Cons:
- Wastes crawling on parameter pages.
- Not suitable for all parameter types.
- Interpreted by search engines as a strong hint, not a directive.
Meta Robots Noindex Tag
Set a noindex directive for any parameter-based page that doesn’t add SEO value. This tag will prevent search engines from indexing the page.
URLs with a “noindex” tag are also likely to be crawled less frequently and if it’s present for a long time will eventually lead Google to nofollow the page’s links.
Pros:
- Relatively easy technical implementation.
- Very likely to safeguard against duplicate content issues.
- Suitable for all parameter types you do not wish to be indexed.
- Removes existing parameter-based URLs from the index.
Cons:
- Won’t prevent search engines from crawling URLs, but will encourage them to do so less frequently.
- Doesn’t consolidate ranking signals.
- Interpreted by search engines as a strong hint, not a directive.
Robots.txt Disallow
The robots.txt file is what search engines look at first before crawling your site. If they see something is disallowed, they won’t even go there.
You can use this file to block crawler access to every parameter based URL (with Disallow: /*?*) or only to specific query strings you don’t want to be indexed.
Pros:
- Simple technical implementation.
- Allows more efficient crawling.
- Avoids duplicate content issues.
- Suitable for all parameter types you do not wish to be crawled.
Cons:
- Doesn’t consolidate ranking signals.
- Doesn’t remove existing URLs from the index.
Move From Dynamic To Static URLs
Many people think the optimal way to handle URL parameters is to simply avoid them in the first place.
After all, subfolders surpass parameters to help Google understand site structure and static, keyword-based URLs have always been a cornerstone of on-page SEO.
To achieve this, you can use server-side URL rewrites to convert parameters into subfolder URLs.
For example, the URL:
www.example.com/view-product?id=482794
Would become:
www.example.com/widgets/purple
This approach works well for descriptive keyword-based parameters, such as those that identify categories, products, or filters for search engine-relevant attributes. It is also effective for translated content.
But it becomes problematic for non-keyword-relevant elements of faceted navigation, such as an exact price. Having such a filter as a static, indexable URL offers no SEO value.
It’s also an issue for searching parameters, as every user-generated query would create a static page that vies for ranking against the canonical – or worse presents to crawlers low-quality content pages whenever a user has searched for an item you don’t offer.
It’s somewhat odd when applied to pagination (although not uncommon due to WordPress), which would give a URL such as
www.example.com/widgets/purple/page2
Very odd for reordering, which would give a URL such as
www.example.com/widgets/purple/lowest-price
And is often not a viable option for tracking. Google Analytics will not acknowledge a static version of the UTM parameter.
More to the point: Replacing dynamic parameters with static URLs for things like pagination, on-site search box results, or sorting does not address duplicate content, crawl budget, or internal link equity dilution.
Having all the combinations of filters from your faceted navigation as indexable URLs often results in thin content issues. Especially if you offer multi-select filters.
Many SEO pros argue it’s possible to provide the same user experience without impacting the URL. For example, by using POST rather than GET requests to modify the page content. Thus, preserving the user experience and avoiding SEO problems.
But stripping out parameters in this manner would remove the possibility for your audience to bookmark or share a link to that specific page – and is obviously not feasible for tracking parameters and not optimal for pagination.
The crux of the matter is that for many websites, completely avoiding parameters is simply not possible if you want to provide the ideal user experience. Nor would it be best practice SEO.
So we are left with this. For parameters that you don’t want to be indexed in search results (paginating, reordering, tracking, etc) implement them as query strings. For parameters that you do want to be indexed, use static URL paths.
Pros:
- Shifts crawler focus from parameter-based to static URLs which have a higher likelihood to rank.
Cons:
- Significant investment of development time for URL rewrites and 301 redirects.
- Doesn’t prevent duplicate content issues.
- Doesn’t consolidate ranking signals.
- Not suitable for all parameter types.
- May lead to thin content issues.
- Doesn’t always provide a linkable or bookmarkable URL.
Best Practices For URL Parameter Handling For SEO
So which of these six SEO tactics should you implement?
The answer can’t be all of them.
Not only would that create unnecessary complexity, but often, the SEO solutions actively conflict with one another.
For example, if you implement robots.txt disallow, Google would not be able to see any meta noindex tags. You also shouldn’t combine a meta noindex tag with a rel=canonical link attribute.
Google’s John Mueller, Gary Ilyes, and Lizzi Sassman couldn’t even decide on an approach. In a Search Off The Record episode, they discussed the challenges that parameters present for crawling.
They even suggest bringing back a parameter handling tool in Google Search Console. Google, if you are reading this, please do bring it back!
What becomes clear is there isn’t one perfect solution. There are occasions when crawling efficiency is more important than consolidating authority signals.
Ultimately, what’s right for your website will depend on your priorities.
Personally, I take the following plan of attack for SEO-friendly parameter handling:
- Research user intents to understand what parameters should be search engine friendly, static URLs.
- Implement effective pagination handling using a ?page= parameter.
- For all remaining parameter-based URLs, block crawling with a robots.txt disallow and add a noindex tag as backup.
- Double-check that no parameter-based URLs are being submitted in the XML sitemap.
No matter what parameter handling strategy you choose to implement, be sure to document the impact of your efforts on KPIs.
More resources:
Featured Image: BestForBest/Shutterstock
SEO
SEO Experts Gather for a Candid Chat About Search [Podcast]
Wix just celebrated their 100th podcast episode! Congrats, Wix. To quote Mordy Oberstein, Head of SEO Brand at Wix; “we talk a lot.”
You sure do! It’s a good thing you have a lot of interesting stuff to say.
The 100th episode of “SERPs Up” was full of awesome guests. Here’s a summary of the action.
Apart from the usual faces, Oberstein and Crystal Carter, Head Of SEO Communications, it was a powerhouse guestlist:
- Chima Mmeje.
- Darren Shaw.
- Joy Hawkins.
- Eli Schwartz.
- Kevin Indig.
- Barry Schwartz.
Just How Broken Are The SERPs?
The first guest was Chima Mmeje from Moz. She dove into the frustrations that many SEOs have been feeling and spoke plainly about the flaws in Google’s updates.
Mordy Oberstein: “Is the SERP broken?”
Chima Mmeje: “The helpful content update, and I’m saying this here, live, is a farce. There was nothing helpful about that update. … Yes, the SERP is 1,000% broken. … How does anybody even use Google in the U.S.? … I don’t think they are going to release any update that will fix these issues.”
Mordy Oberstein: “There’s no update. … Plopping Reddit all over the SERP was because they saw the content trends … and they said ‘we don’t have any so we’re just going to throw Reddit there’.”
Chima Mmeje: “It was lazy to have Reddit there … Nobody uses their real names. Anybody can go on Reddit and answer questions and then you see these answers populating in People Also Ask, populating in featured snippets, populating all over the SERPs as correct information. It is dangerous, at worst.”
Crystal Carter: “Do you think that one of the reasons why we’ve seen so much upheaval and so much so volatility in the SERPs, which I certainly agree with in the last year … is lots and lots of variables, like lots of new features coming in, so the alignment with Reddit, the AI overviews, the SGE … Do you think it is just too many things being thrown in at the same time and it messing up lots of SERPs as a result? Or do you think it’s something else?”
Chima Mmeje: ” … releasing too many features that they did not test properly. Features that were rushed SGE [testing] did not even last a year and now they brought in Google AI Overviews. I still don’t understand why we have AI Overviews and featured snippets on the same SERP. I feel like it’s like pick one, make a choice.”
Mordy Oberstein’s next question was about what we can do. “As an SEO, how are you supposed to do this? I’ve heard things from people … Yeah, I don’t know what to do. I can’t produce the kind of results that I’ve always wanted to. Can you still be effective as an SEO in an environment like this?”
Chima Mmeje: “I’m going to be honest, we are suffering … It feels like we are trying our best with what we are seeing … because there is no clear guidance. And to be honest, a lot of us are playing a guessing game right now and that is the best that we can do. It’s all a guessing game based on what we’ve seen one or two variables work. And this is not a long-term strategy. If we’re going to be realistic, it’s not going to work in the long-term. I honestly, I don’t know what the answer is … you’re fighting against Reddit. How do you compete against Reddit? Nobody has figured that out yet.”
Crystal Carter: “Thanks for saying it out loud, Chima.” Crystal was reflecting the sentiment of the commenters, who appreciated her candor and willingness to say: we don’t know, but we’re trying our best.
Mordy Oberstein: “The most honest take I’ve heard on that in quite a long time.”
Mmeje also recounted examples of small website owners and small businesses that have had to shut down. She also talked about the pervasive feeling in the SEO community that there is no rhyme or reason to how the algorithms handle websites and content.
What’s Going On In Local SEO?
The next guests were Darren Shaw from Whitespark and Joy Hawkins, owner of Sterling Sky for a segment called “It’s New.” They talked about new developments in local SEO.
Hawkins talked about a new feature in Google Business Profile.
Joy Hawkins: “… There’s a little services section inside the Google business profile dashboard that’s easy to miss, but you can add anything you want in there. … We’ve done a lot of testing on it and they do impact ranking, but I should clarify, it’s like a small impact. So usually we see it for longer-tailed queries that maybe don’t match a category or things that are not super competitive. … So it is a small ranking factor, but still one that is worth filling out.”
Darren Shaw: “ .. this is the question that a lot of people ask. We know that if you go into the services section of your Google business profile, Google will suggest predefined services … And so Joy’s original research was focused on those predefined ones and it definitely identified that when you do put those on your profile, you now rank better for those terms depending on how competitive they’re, as Joy had mentioned. … There is a place where you can add your own custom services. Have you done any testing around that? Will you rank better with the custom services?”
Joy Hawkins: “Yes. They both work. In custom services … I’m trying to remember the keyword that Colin tested it on. It was something super niche like vampire facials. I was Googling, what the hell is that? … Really, really niche … But he just wanted to know if there was any impact whatsoever and there was. [Custom services fields are a] good way to go after longer tail keywords that don’t have crazy high search volume or aren’t super competitive.”
Darren Shaw: “You want to make sure that you’re telling Google what you do … that’s basically what the services section provides. And it’s not a huge ranking factor, but it’s just another step in the local optimization process. … a tip for custom services because custom services often get pulled into the local results as justifications. It’ll say this business provides vampire facials, right? Well, did you know there’s a vampire emoji? So if you put the vampire emoji in the title … Then in the local results you’ll see a whole panel of businesses that all provide that service, but yours has that little vampire emoji which will draw people in.”
There was tons more in this section, including questions from the audiences and some great jokes.
The Obligatory AI Section.
Eli Schwartz And Kevin indig were next up to talk about AI. Oberstein, professional rabble rouser, tried to get them to argue, but despite their very different posting habits, they found a lot to agree on about AI.
Mordy Oberstein: “It wouldn’t be an SEO podcast if we didn’t talk about AI. Where do we currently stand with AI? What can it do? What can’t it do?”
Kevin Indig: “… We’re at a stage where AI basically has the capability to create content, analyze some basic data. It still hallucinates here and there and it still makes mistakes. … If you compare that to when this AI hype started in November, 2022, so it’s almost two years now and we’ve come a really long way, these models are getting exponentially better. … It means different things based on whether you look at it as a tool for yourself to make your work more efficient. And of course, what does it mean from an SEO perspective? How does it change search, not just Google, but also how people search. And I think these are all different questions that are exciting to dive into. … So there is a lot of objective data that indicates efficiencies and benefits from AI. There’s also a lot of hype that promises a little too much about what AI can do. And so I’m generally AI bullish, but I’m not in the camp of AI is going to replace us all the next two years.”
Mordy Oberstein: “I’m setting the stage here a little bit because while your LinkedIn pros are generally like pro ai, a lot of Eli’s posts are a little more skeptical about AI. So Eli, what do you think about what Kevin just said? By the way, I’m like, for those who are listening or watching this, I’m pitting them against each other. They’re friends and they do a podcast together. So it’s cool.”
Eli Schwartz: I think AI is great. I think that there’s a lot of great things you can get out of AI. You can, again, like Kevin said, it can be your thought partner. … I’m anti AI in the way people are using it. And I don’t think people have necessarily changed their behaviors because before … they outsource [content] on Fiverr and Upwork and they bought very cheap content and now they’re getting very free content. So then that’s coming from AI. That behavior hasn’t really changed. The challenge is that now there are more people that think they can copy them.
So I talk to CMOs all the time who are like, well, I just go of my SEO team. A big company reached out to me recently. They wanted to gut check themselves after they already fired their SEO team. So I can’t really help there, but they’re like, AI can do everything. … Well, I’ll see them in a year from now when they have whatever sort of penalty. AI is a very powerful tool. Any tool we have a drill is a very powerful tool. But if you just hold it in the air and just let it go, it’s going to make holes. But if you use it appropriately, it does the thing it’s supposed to do. … We’re humans and we buy stuff and it has to come to a point where humans are talking to humans.
Crystal Carter: “… Most of the gains are coming from productivity. The stuff like Kevin was talking about with being able to write product descriptions more quickly, being able to write lots of posts more quickly and being able to finish your things more quickly, brainstorm, et cetera, in terms of the quality, the quality is still not there. It’s getting there rapidly, but it’s still not there.”
There was lots more AI talk, so you should listen to the whole episode if you want to hear the full range of opinions.
Snappy News About The Google August Update
“The Snappy News” segment featured Barry Schwartz, Contributing Editor to Search Engine Land. It also featured the dreaded SEO phrase “it depends.”
Mordy Oberstein: So the article of the day is from Search Engine Land, basically written by Barry that the core update, the August 2024 core update is done. It is complete. … The issue with Google folks who are trying to figure out, will they see a reversal of their fortunes from the 2023 helpful content update, the September, 2023 helpful content update. It’s a mouthful, to be honest with you. And my question for you, since you’re here, did that happen? Was the August updated reversal?
Barry Schwartz: “It depends on the site. I think the number, I don’t have the exact data, obviously I don’t think anybody does, but I’ve seen examples of some very few sites see complete reversals. … There are a number of sites that saw maybe a 20% bump, a 30% bump, maybe a 5% bump. But very few sites saw a complete reversal, if you want to even call it that. … I’ve been through a lot of Google updates over the years, and it’s sometimes sad to see the stories, but at the same time, if you keep at it and you are true to the content, your audience, generally, you’ll do well in the long run. Not every site, there’s plenty of sites that have been hit, went out of business, and they couldn’t come back. That’s business in general. And things change, like seasonalities and times change. You’re writing about the railroad business a hundred years ago and you keep writing about it today. There’s not many people investing a lot of money in railroads these days. So I dunno, it’s, it’s hard to read those stories, but not everybody deserves to go back to where they were. And then at the same time, Google’s not perfect either, which is why they keep on releasing new updates.”
That’s a wrap!
If you haven’t experienced a SERPs Up episode before, you should absolutely take a listen to experience the full effect of Mordy and Crystal’s banter.
The SERP’s Up podcast is brought to you by Wix Studio.
-
SEARCHENGINES6 days ago
Daily Search Forum Recap: September 9, 2024
-
SEARCHENGINES5 days ago
Daily Search Forum Recap: September 10, 2024
-
SEO7 days ago
Mediavine Bans Publisher For Overuse Of AI-Generated Content
-
SEO5 days ago
Expert Embedding Techniques for SEO Success
-
WORDPRESS6 days ago
The Ultimate eCommerce Launch Checklist for WordPress
-
WORDPRESS5 days ago
Roadmap Update – WordPress.com News
-
AFFILIATE MARKETING7 days ago
One $40 Payment Can Get You Lifetime Access to Microsoft Office Professional 2021
-
SEARCHENGINES4 days ago
Daily Search Forum Recap: September 11, 2024
You must be logged in to post a comment Login