How to easily Scrape Data from a Website’s Store Locator

Most retail store chains have a store locator map on their website.

This information is quite useful for their customers, but it can be much more valuable for you and your business.

What if you could extract all the data in these Store Locators into a handy spreadsheet full of potential business leads or competitor data?

Web scraping is the answer.

Web scraping a Store Locator can help you:

  • get your competitors’ locations to find out where to expand your business
  • get the locations of businesses that you can distribute or sell to
  • get contact info for all of the important businesses near yours

Step 1: Download a Web Scraper

If you have found yourself spending hours of your valuable time copying and pasting the addresses, phone numbers and store hours from these maps into your own database, then it is about time you discovered the power of web scraping.

ParseHub is powerful and FREE web scraping software - which we will use for this tutorial.

Download ParseHub for free here.

Today, you will learn how to create a ParseHub data extraction project to automate this time-consuming task - without writing a single line of code.

Step 2: Start your web scraping project

  1. Make sure you’ve downloaded and installed ParseHub from the link above.
  2. Open the ParseHub application and travel to the retail store website of your choice. In this example, we will use the Costco Store Locator
  3. Once you have traveled to the website, click on "New Project" and "Start project on this URL" to create your web scraping project.

Step 3: Searching for your location

  1. Now that you have created your web scraping project, you are ready to add the commands into your first template. Some templates are used to get data from a page, but this one will be used to search for that data. Click on the "Find a Warehouse" button to select it with the Select command.
  2. Rename your selection from selection1 to warehouse_button by clicking on the command.
  3. If you were using a regular browser to search, you would hover over this button without clicking to open a popup window. Luckily, you can command ParseHub to hover, the exact same way! You will see a "plus" button to the right of the command "Select and Extract warehouse_button". Click on it to open the command menu.
  4. Click on "Advanced" to open the rest of the commands.
  5. Choose the Hover command from the list to add it to your template. The pop-up window will open up.
  1. Add another Select command by clicking on the "plus" button next to the command "Select page".
  2. Click on the "City, State or Zip" search bar and an Input command will be added automatically.
  3. Type in your location into the input box. We will use San Francisco.
  4. Rename your selection search_bar.
  5. When you run your project, you will want to make sure that the pop-up window appears when ParseHub hovers over it. In order to do this, click on the "Select search_bar" command, and check the box that says "Wait up to 60 seconds for elements to appear", and change 60 to 2.
  1. Click on the "plus" button again to add another Select command.
  2. Click on the "Find a Warehouse" button to select it. Name it search_button.
  3. Click on the "plus" button beside "Select and Extract search_button" command to add a Click command from the menu.
  4. Clicking on this button will take you to a new page. Therefore, we want to Create a New Template. Call it search_results.

Step 4: Extract data for store locations

  1. You will be taken to a map with the 10 closest locations. Click on the first two in the list under the map. This will select and extract all 10 of them.
  2. Rename the selection to locations. Click on the checkbox next to "Wait up to 2 seconds for elements to appear" since the website may take a while to search.
  3. Click the plus button next to "Begin new entry in locations.
  4. Add a Relative Select command from the command menu.
  5. Click on one of the names and then click on the address below it. This will select and extract all of the addresses.Rename the selection address.
  1. Add another Relative Select command by clicking the "plus" button next to the "Begin new entry in locations" command. To select all of the city and zip codes, click on the name of one location and then on the city and zip code below it.
  2. Add another Relative Select and select the telephone numbers the same way.

Step 5: Scrape additional store details with page navigation

Clicking on the name of one of the locations will bring you to that store's additional details page, where you will find the store hours and a list of departments that it has.

  1. Click on the "plus" beside the "Begin new entry in locations" command, open the Advanced menu and add a Click command. By nesting this command in the Begin New Entry command, you are telling ParseHub to click on each one of the locations!
  2. You will travel to a new page with each click, so Create New Template and call it details.
  1. You will travel to the first details page in the list. I will first select the store hours, which are split up into three different lines. I don't want them to each get their own row in the CSV, so I will select all of them at once by zooming out by pressing "ctrl" (or "command") and "1" on my keyboard.
  2. To select all of the department names, I click on one from each of the columns. This highlights them all and selects and extracts them into separate rows in the CSV.

Step 6: Download Data into CSV or JSON file

So far I have instructed ParseHub to extract the address, phone number store hours and departments of each location near me. That's all the information that I need for my database, so it is time to run my project and extract my data!

There are a few ways to do this. You can run the project once and download your data from the app, you can schedule the project to run and download the data from an email, or you can control the project using ParseHub's API options with your own script. Here I will show you how to run the project once.

  1. Click on the big green "Get Data" button in the ParseHub sidebar.
  2. Click "Run" and "Save and Run" and wait for the extraction to complete.
  3. Download the CSV and the JSON. The results are also sent to my email address, and can be found on any computer with ParseHub's Desktop application when I log in to my account!

There are many ways that this project can be customized. A few examples are to:

  • Use the dropdown menu on the search results page to get the info from 20 locations instead of just 10
  • Select more data from the details page, which includes specific department phone numbers and hours
  • Use regular expressions to extract only the Monday to Friday hours, and ignore the Saturday and Sunday hours

And, of course, this isn't limited to the Costco website. Just about all major retailers have store locators designed just like this one.

You can use ParseHub with many other store locators (beyond just retail stores) such as:

Need help putting your project together? Visit our help articles or use the chat bubble on our main website to contact support.

[This post was originally written on July 13, 2016 and updated on August 1, 2019]