Skip to content

Instantly share code, notes, and snippets.

@Shivani29sheth
Created June 20, 2020 23:43
Show Gist options
  • Save Shivani29sheth/5da2318be442e5d7ff7ff6ecddf31f52 to your computer and use it in GitHub Desktop.
Save Shivani29sheth/5da2318be442e5d7ff7ff6ecddf31f52 to your computer and use it in GitHub Desktop.
Created on Skills Network Labs
Display the source blob
Display the rendered blob
Raw
{
"cells": [
{
"cell_type": "markdown",
"metadata": {},
"source": [
"<h1>Final Capstone Project - Analyze and Cluster Neighborhoods in British Columbia </h1>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"## Table of contents\n",
"* [Introduction and Project Proposal](#introduction)\n",
"* [Obtaining and cleaning data](#data)\n",
"* [Methodology](#methodology)\n",
"* [Analyze each neighborhood](#analysis)\n",
"* [Cluster Neighborhoods](#cluster)\n",
"* [Results and Conclusion](#results)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"\n",
"## Introduction and Project Proposal <a name=\"introduction\"></a>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"In this project, we take leverage of the Foursquare API to find the most popular places in each of the neighborhoods consisting of British Columbia. A place is marked as “happening” by the Foursquare API according to the number of people present at a given place and hence the place is updated in real-time; it might change every few minutes. We then cluster the neighborhoods based upon their preferred places in the surrounding area. This will give a clear picture of the aura or the vibe of the place, which can help an individual know what to expect in the neighborhood, and hence decide upon a suitable location according to their preference."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"\n",
"## Obtaining and cleaning data <a name=\"data\"></a>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### In this module, we can obtain data from various sources and clean them to match our required data frame needed for further processing. Two such methods of obtaining our required data has been explained below."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"### First method to acquire the dataset needed:"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### In this method, we scrape the data frame needed from the wikipedia page from the given url and clean the table for better readability. Once we obtain the location data, we pass the address through the geocoder package of the geopy library to extract the latitude and longitude values for each address. Hence, this will give us the complete data set needed for the methodology."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### We start with importing and downloading the necessary libraries.\n"
]
},
{
"cell_type": "code",
"execution_count": 2,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Collecting package metadata (current_repodata.json): done\n",
"Solving environment: done\n",
"\n",
"## Package Plan ##\n",
"\n",
" environment location: /home/jupyterlab/conda/envs/python\n",
"\n",
" added / updated specs:\n",
" - lxml\n",
"\n",
"\n",
"The following packages will be downloaded:\n",
"\n",
" package | build\n",
" ---------------------------|-----------------\n",
" libxslt-1.1.33 | h7d1a2b0_0 426 KB\n",
" lxml-3.8.0 | py36_0 3.8 MB conda-forge\n",
" ------------------------------------------------------------\n",
" Total: 4.2 MB\n",
"\n",
"The following NEW packages will be INSTALLED:\n",
"\n",
" libxslt pkgs/main/linux-64::libxslt-1.1.33-h7d1a2b0_0\n",
" lxml conda-forge/linux-64::lxml-3.8.0-py36_0\n",
"\n",
"\n",
"\n",
"Downloading and Extracting Packages\n",
"lxml-3.8.0 | 3.8 MB | ##################################### | 100% \n",
"libxslt-1.1.33 | 426 KB | ##################################### | 100% \n",
"Preparing transaction: done\n",
"Verifying transaction: done\n",
"Executing transaction: done\n"
]
}
],
"source": [
"import pandas as pd\n",
"import numpy as np\n",
"import requests\n",
"!conda install -c conda-forge lxml --yes "
]
},
{
"cell_type": "code",
"execution_count": 3,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Collecting package metadata (current_repodata.json): done\n",
"Solving environment: done\n",
"\n",
"# All requested packages already installed.\n",
"\n",
"Collecting package metadata (current_repodata.json): done\n",
"Solving environment: done\n",
"\n",
"## Package Plan ##\n",
"\n",
" environment location: /home/jupyterlab/conda/envs/python\n",
"\n",
" added / updated specs:\n",
" - geocoder\n",
"\n",
"\n",
"The following packages will be downloaded:\n",
"\n",
" package | build\n",
" ---------------------------|-----------------\n",
" brotlipy-0.7.0 |py36h8c4c3a4_1000 346 KB conda-forge\n",
" chardet-3.0.4 |py36h9f0ad1d_1006 188 KB conda-forge\n",
" click-7.1.2 | pyh9f0ad1d_0 64 KB conda-forge\n",
" cryptography-2.9.2 | py36h45558ae_0 613 KB conda-forge\n",
" future-0.18.2 | py36h9f0ad1d_1 714 KB conda-forge\n",
" geocoder-1.38.1 | py_1 53 KB conda-forge\n",
" pysocks-1.7.1 | py36h9f0ad1d_1 27 KB conda-forge\n",
" ratelim-0.1.6 | py_2 6 KB conda-forge\n",
" requests-2.24.0 | pyh9f0ad1d_0 47 KB conda-forge\n",
" ------------------------------------------------------------\n",
" Total: 2.0 MB\n",
"\n",
"The following NEW packages will be INSTALLED:\n",
"\n",
" brotlipy conda-forge/linux-64::brotlipy-0.7.0-py36h8c4c3a4_1000\n",
" chardet conda-forge/linux-64::chardet-3.0.4-py36h9f0ad1d_1006\n",
" click conda-forge/noarch::click-7.1.2-pyh9f0ad1d_0\n",
" cryptography conda-forge/linux-64::cryptography-2.9.2-py36h45558ae_0\n",
" decorator conda-forge/noarch::decorator-4.4.2-py_0\n",
" future conda-forge/linux-64::future-0.18.2-py36h9f0ad1d_1\n",
" geocoder conda-forge/noarch::geocoder-1.38.1-py_1\n",
" idna conda-forge/noarch::idna-2.9-py_1\n",
" pyopenssl conda-forge/noarch::pyopenssl-19.1.0-py_1\n",
" pysocks conda-forge/linux-64::pysocks-1.7.1-py36h9f0ad1d_1\n",
" ratelim conda-forge/noarch::ratelim-0.1.6-py_2\n",
" requests conda-forge/noarch::requests-2.24.0-pyh9f0ad1d_0\n",
" urllib3 conda-forge/noarch::urllib3-1.25.9-py_0\n",
"\n",
"\n",
"\n",
"Downloading and Extracting Packages\n",
"future-0.18.2 | 714 KB | ##################################### | 100% \n",
"chardet-3.0.4 | 188 KB | ##################################### | 100% \n",
"cryptography-2.9.2 | 613 KB | ##################################### | 100% \n",
"brotlipy-0.7.0 | 346 KB | ##################################### | 100% \n",
"pysocks-1.7.1 | 27 KB | ##################################### | 100% \n",
"geocoder-1.38.1 | 53 KB | ##################################### | 100% \n",
"requests-2.24.0 | 47 KB | ##################################### | 100% \n",
"ratelim-0.1.6 | 6 KB | ##################################### | 100% \n",
"click-7.1.2 | 64 KB | ##################################### | 100% \n",
"Preparing transaction: done\n",
"Verifying transaction: done\n",
"Executing transaction: done\n"
]
}
],
"source": [
"!conda install -c conda-forge html5lib --yes \n",
"!conda install -c conda-forge geocoder --yes "
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Next, we scrape the table given on this wikipedia page using the read_html method of the pandas library. This table consists of the postal code along with the neighborhood for each location.\n"
]
},
{
"cell_type": "code",
"execution_count": 4,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>V1AKimberley</th>\n",
" <th>V2APenticton</th>\n",
" <th>V3ALangley Township(Langley City)</th>\n",
" <th>V4ASurreySouthwest</th>\n",
" <th>V5ABurnaby(Government Road / Lake City / SFU / Burnaby Mountain)</th>\n",
" <th>V6AVancouver(Strathcona / Chinatown / Downtown Eastside)</th>\n",
" <th>V7ARichmondSouth</th>\n",
" <th>V8APowell River</th>\n",
" <th>V9AVictoria(Vic West / Esquimalt)Canadian Forces(MARPAC)</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>V1BVernonEast</td>\n",
" <td>V2BKamloopsNorthwest</td>\n",
" <td>V3BPort CoquitlamCentral</td>\n",
" <td>V4BWhite Rock</td>\n",
" <td>V5BBurnaby(Parkcrest-Aubrey / Ardingley-Sprott)</td>\n",
" <td>V6BVancouver(NE Downtown / Gastown / Harbour C...</td>\n",
" <td>V7BRichmond(Sea Island / YVR)</td>\n",
" <td>V8BSquamish</td>\n",
" <td>V9BVictoria(West Highlands / North Langford / ...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>V1CCranbrook</td>\n",
" <td>V2CKamloopsCentral and Southeast</td>\n",
" <td>V3CPort CoquitlamSouth</td>\n",
" <td>V4CDeltaNortheast</td>\n",
" <td>V5CBurnaby(Burnaby Heights / Willingdon Height...</td>\n",
" <td>V6CVancouver(Waterfront / Coal Harbour / Canad...</td>\n",
" <td>V7CRichmondNorthwest</td>\n",
" <td>V8CKitimat</td>\n",
" <td>V9CVictoria(Colwood / South Langford / Metchosin)</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>V1ESalmon Arm</td>\n",
" <td>V2EKamloopsSouth and West</td>\n",
" <td>V3ECoquitlamNorth</td>\n",
" <td>V4EDeltaEast</td>\n",
" <td>V5EBurnaby(Lakeview-Mayfield / Richmond Park /...</td>\n",
" <td>V6EVancouver(SE West End / Davie Village)</td>\n",
" <td>V7ERichmondSouthwest</td>\n",
" <td>V8EWhistler</td>\n",
" <td>V9EVictoria(East Highlands / NW Saanich)</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>V1GDawson Creek</td>\n",
" <td>V2GWilliams Lake</td>\n",
" <td>V3GAbbotsfordEast</td>\n",
" <td>V4GDeltaEast Central</td>\n",
" <td>V5GBurnaby(Cascade-Schou / Douglas-Gilpin)</td>\n",
" <td>V6GVancouver(NW West End / Stanley Park)</td>\n",
" <td>V7GNorth Vancouver (district municipality)Oute...</td>\n",
" <td>V8GTerrace</td>\n",
" <td>V9GLadysmith</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>V1HVernonWest</td>\n",
" <td>V2HKamloopsNorth</td>\n",
" <td>V3HPort Moody</td>\n",
" <td>V4HNot assigned</td>\n",
" <td>V5HBurnaby(Maywood / Marlborough / Oakalla / W...</td>\n",
" <td>V6HVancouver(West Fairview / Granville Island ...</td>\n",
" <td>V7HNorth Vancouver (district municipality)Inne...</td>\n",
" <td>V8HNot assigned</td>\n",
" <td>V9HCampbell RiverOutskirts</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" V1AKimberley V2APenticton \\\n",
"0 V1BVernonEast V2BKamloopsNorthwest \n",
"1 V1CCranbrook V2CKamloopsCentral and Southeast \n",
"2 V1ESalmon Arm V2EKamloopsSouth and West \n",
"3 V1GDawson Creek V2GWilliams Lake \n",
"4 V1HVernonWest V2HKamloopsNorth \n",
"\n",
" V3ALangley Township(Langley City) V4ASurreySouthwest \\\n",
"0 V3BPort CoquitlamCentral V4BWhite Rock \n",
"1 V3CPort CoquitlamSouth V4CDeltaNortheast \n",
"2 V3ECoquitlamNorth V4EDeltaEast \n",
"3 V3GAbbotsfordEast V4GDeltaEast Central \n",
"4 V3HPort Moody V4HNot assigned \n",
"\n",
" V5ABurnaby(Government Road / Lake City / SFU / Burnaby Mountain) \\\n",
"0 V5BBurnaby(Parkcrest-Aubrey / Ardingley-Sprott) \n",
"1 V5CBurnaby(Burnaby Heights / Willingdon Height... \n",
"2 V5EBurnaby(Lakeview-Mayfield / Richmond Park /... \n",
"3 V5GBurnaby(Cascade-Schou / Douglas-Gilpin) \n",
"4 V5HBurnaby(Maywood / Marlborough / Oakalla / W... \n",
"\n",
" V6AVancouver(Strathcona / Chinatown / Downtown Eastside) \\\n",
"0 V6BVancouver(NE Downtown / Gastown / Harbour C... \n",
"1 V6CVancouver(Waterfront / Coal Harbour / Canad... \n",
"2 V6EVancouver(SE West End / Davie Village) \n",
"3 V6GVancouver(NW West End / Stanley Park) \n",
"4 V6HVancouver(West Fairview / Granville Island ... \n",
"\n",
" V7ARichmondSouth V8APowell River \\\n",
"0 V7BRichmond(Sea Island / YVR) V8BSquamish \n",
"1 V7CRichmondNorthwest V8CKitimat \n",
"2 V7ERichmondSouthwest V8EWhistler \n",
"3 V7GNorth Vancouver (district municipality)Oute... V8GTerrace \n",
"4 V7HNorth Vancouver (district municipality)Inne... V8HNot assigned \n",
"\n",
" V9AVictoria(Vic West / Esquimalt)Canadian Forces(MARPAC) \n",
"0 V9BVictoria(West Highlands / North Langford / ... \n",
"1 V9CVictoria(Colwood / South Langford / Metchosin) \n",
"2 V9EVictoria(East Highlands / NW Saanich) \n",
"3 V9GLadysmith \n",
"4 V9HCampbell RiverOutskirts "
]
},
"execution_count": 4,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"url = \"https://en.wikipedia.org/wiki/List_of_postal_codes_of_Canada:_V\"\n",
"df = pd.read_html(url, header=0)\n",
"df= df[0]\n",
"df.head()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### As we see, the table scraped isn't very readable. Hence, we convert the table to a list and iterate through each value to separate the postal codes and neighborhood values, and store them in a data frame.\n"
]
},
{
"cell_type": "code",
"execution_count": 5,
"metadata": {},
"outputs": [],
"source": [
"list_var = df.values.tolist()"
]
},
{
"cell_type": "code",
"execution_count": 6,
"metadata": {},
"outputs": [],
"source": [
"postal_code = []\n",
"neighborhood = []\n",
"for i in list_var:\n",
" for j in i:\n",
" postal_code.append(j[0:3])\n",
" j = j[3:]\n",
" neigh = j.split(\"(\")[0]\n",
" neighborhood.append(neigh)"
]
},
{
"cell_type": "code",
"execution_count": 7,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Postal Codes</th>\n",
" <th>Neighborhood</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>V1B</td>\n",
" <td>VernonEast</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>V2B</td>\n",
" <td>KamloopsNorthwest</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>V3B</td>\n",
" <td>Port CoquitlamCentral</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>V4B</td>\n",
" <td>White Rock</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>V5B</td>\n",
" <td>Burnaby</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Postal Codes Neighborhood\n",
"0 V1B VernonEast\n",
"1 V2B KamloopsNorthwest\n",
"2 V3B Port CoquitlamCentral\n",
"3 V4B White Rock\n",
"4 V5B Burnaby"
]
},
"execution_count": 7,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df = pd.DataFrame({'Postal Codes':postal_code,'Neighborhood':neighborhood})\n",
"df.head()"
]
},
{
"cell_type": "code",
"execution_count": 8,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Int64Index([39, 43, 48, 92, 156, 168], dtype='int64')\n",
"(165, 3)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>index</th>\n",
" <th>Postal Codes</th>\n",
" <th>Neighborhood</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>0</td>\n",
" <td>V1B</td>\n",
" <td>VernonEast</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>1</td>\n",
" <td>V2B</td>\n",
" <td>KamloopsNorthwest</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>2</td>\n",
" <td>V3B</td>\n",
" <td>Port CoquitlamCentral</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>3</td>\n",
" <td>V4B</td>\n",
" <td>White Rock</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>4</td>\n",
" <td>V5B</td>\n",
" <td>Burnaby</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" index Postal Codes Neighborhood\n",
"0 0 V1B VernonEast\n",
"1 1 V2B KamloopsNorthwest\n",
"2 2 V3B Port CoquitlamCentral\n",
"3 3 V4B White Rock\n",
"4 4 V5B Burnaby"
]
},
"execution_count": 8,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"remove = df[df['Neighborhood']=='Not assigned'].index\n",
"print(remove)\n",
"df.drop(remove,axis=0, inplace=True)\n",
"df.reset_index(inplace=True)\n",
"print(df.shape)\n",
"df.head()"
]
},
{
"cell_type": "code",
"execution_count": 9,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(165, 2)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Postal Codes</th>\n",
" <th>Neighborhood</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>V1B</td>\n",
" <td>VernonEast</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>V2B</td>\n",
" <td>KamloopsNorthwest</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>V3B</td>\n",
" <td>Port CoquitlamCentral</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>V4B</td>\n",
" <td>White Rock</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>V5B</td>\n",
" <td>Burnaby</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Postal Codes Neighborhood\n",
"0 V1B VernonEast\n",
"1 V2B KamloopsNorthwest\n",
"2 V3B Port CoquitlamCentral\n",
"3 V4B White Rock\n",
"4 V5B Burnaby"
]
},
"execution_count": 9,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df.drop(['index'], axis=1, inplace=True)\n",
"print(df.shape)\n",
"df.head()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Now that we have the address for each location, we install and import the libraries necessary for leveraging the geocoder package.\n"
]
},
{
"cell_type": "code",
"execution_count": 10,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Collecting package metadata (current_repodata.json): done\n",
"Solving environment: done\n",
"\n",
"## Package Plan ##\n",
"\n",
" environment location: /home/jupyterlab/conda/envs/python\n",
"\n",
" added / updated specs:\n",
" - geopy\n",
"\n",
"\n",
"The following packages will be downloaded:\n",
"\n",
" package | build\n",
" ---------------------------|-----------------\n",
" geographiclib-1.50 | py_0 34 KB conda-forge\n",
" geopy-1.22.0 | pyh9f0ad1d_0 63 KB conda-forge\n",
" ------------------------------------------------------------\n",
" Total: 97 KB\n",
"\n",
"The following NEW packages will be INSTALLED:\n",
"\n",
" geographiclib conda-forge/noarch::geographiclib-1.50-py_0\n",
" geopy conda-forge/noarch::geopy-1.22.0-pyh9f0ad1d_0\n",
"\n",
"\n",
"\n",
"Downloading and Extracting Packages\n",
"geopy-1.22.0 | 63 KB | ##################################### | 100% \n",
"geographiclib-1.50 | 34 KB | ##################################### | 100% \n",
"Preparing transaction: done\n",
"Verifying transaction: done\n",
"Executing transaction: done\n"
]
}
],
"source": [
"!conda install -c conda-forge geopy --yes "
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Using geocoder, we pass the location for each neighborhood and obtain its latitude and longitude values.\n"
]
},
{
"cell_type": "code",
"execution_count": 11,
"metadata": {},
"outputs": [],
"source": [
"from geopy.geocoders import Nominatim\n",
"geolocator = Nominatim(user_agent=\"My_App\")\n",
"from geopy.extra.rate_limiter import RateLimiter\n",
"obj = RateLimiter(geolocator.geocode, min_delay_seconds=1)\n",
"lat=[]\n",
"long=[]\n",
"for i in neighborhood:\n",
" location = obj(\"'\"+i+\"'', Canada\")\n",
" if location == None:\n",
" lat.append(\"None\")\n",
" long.append(\"None\")\n",
" else:\n",
" lat.append(str(location.latitude))\n",
" long.append(str(location.longitude))"
]
},
{
"cell_type": "code",
"execution_count": 12,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"79\n",
"79\n"
]
}
],
"source": [
"print(lat.count('None'))\n",
"print(long.count('None'))"
]
},
{
"cell_type": "code",
"execution_count": 13,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"dict_keys(['None', '49.0235357', '49.2433804', '49.2608724', '49.163168', '49.6980743', '48.4283182', '49.5107477', '54.0535577', '50.7005059', '50.1171903', '55.7605306', '52.129081', '49.3207133', '54.5172715', '48.9936579', '49.2822243', '56.2524039', '52.9794279', '54.3126572', '50.111704', '48.8296672', '49.3479861', '49.494891', '48.6505788', '48.7786872', '48.5946782', '49.6727575', '49.316171', '49.3179514', '49.099049', '49.857464', '49.1637594', '52.966077', '49.2207623', '49.2343668', '48.3825724'])"
]
},
"execution_count": 13,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"from collections import Counter\n",
"Counter(lat).keys()"
]
},
{
"cell_type": "code",
"execution_count": 14,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"dict_keys(['None', '-122.7979246', '-122.9725459', '-123.1139529', '-123.137414', '-123.1558612', '-123.3649533', '-115.7672772', '-128.6540519', '-119.2790529', '-122.9543022', '-120.2364453', '-122.1397346', '-123.0737831', '-128.5995482', '-123.8157964', '-122.8293424', '-120.846943', '-122.4936273', '-130.32549', '-120.7884227', '-123.51516139891447', '-124.4439409', '-117.290039', '-123.3983246', '-123.7080446', '-123.4207265', '-124.9276204', '-117.663574', '-124.3117397', '-117.713013', '-119.580688', '-123.9379719', '-114.4216167', '-122.6901534', '-124.8056517', '-123.7315177'])"
]
},
"execution_count": 14,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"Counter(long).keys()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Hence, we extract the coordinate values and can now store it in the data frame to obtain the required dataset. This completes our first method of obtaining the required dataset.\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### Second method to acquire the dataset needed:\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### In this method, we scrape the table consisting of the postal code, the neighborhood name, and the coordinate values from a website url given below. Next, we separately extract the coordinate values and the address values via a temporary table, clean them individually and merge them in a single data frame again to obtain our required dataset.\n"
]
},
{
"cell_type": "code",
"execution_count": 15,
"metadata": {},
"outputs": [],
"source": [
"url = \"https://www.geonames.org/postal-codes/CA/BC/british-columbia.html\"\n",
"df = pd.read_html(url, header=0)"
]
},
{
"cell_type": "code",
"execution_count": 16,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(385, 7)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Unnamed: 0</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" <th>Admin2</th>\n",
" <th>Admin3</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>1.0</td>\n",
" <td>Port Moody</td>\n",
" <td>V3H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>NaN</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>2.0</td>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>NaN</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>3.0</td>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Unnamed: 0 Place Code Country \\\n",
"0 1.0 Port Moody V3H Canada \n",
"1 NaN 49.323/-122.863 49.323/-122.863 49.323/-122.863 \n",
"2 2.0 Pitt Meadows V3Y Canada \n",
"3 NaN 49.221/-122.69 49.221/-122.69 49.221/-122.69 \n",
"4 3.0 White Rock V4B Canada \n",
"\n",
" Admin1 Admin2 Admin3 \n",
"0 British Columbia NaN NaN \n",
"1 49.323/-122.863 49.323/-122.863 49.323/-122.863 \n",
"2 British Columbia NaN NaN \n",
"3 49.221/-122.69 49.221/-122.69 49.221/-122.69 \n",
"4 British Columbia NaN NaN "
]
},
"execution_count": 16,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"print(df[2].shape)\n",
"df[2].head()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### As we see the table scraped from this website, is much more readable but also contains garbage values. Hence we initially clean the table by dropping unnecessary columns and indexes.\n"
]
},
{
"cell_type": "code",
"execution_count": 17,
"metadata": {},
"outputs": [],
"source": [
"df1 = df[2]"
]
},
{
"cell_type": "code",
"execution_count": 18,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(385, 7)\n"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
"/home/jupyterlab/conda/envs/python/lib/python3.6/site-packages/pandas/core/ops/array_ops.py:253: FutureWarning: elementwise comparison failed; returning scalar instead, but in the future will perform elementwise comparison\n",
" res_values = method(rvalues)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Unnamed: 0</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" <th>Admin2</th>\n",
" <th>Admin3</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>1.0</td>\n",
" <td>Port Moody</td>\n",
" <td>V3H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>NaN</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>2.0</td>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>NaN</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>3.0</td>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Unnamed: 0 Place Code Country \\\n",
"0 1.0 Port Moody V3H Canada \n",
"1 NaN 49.323/-122.863 49.323/-122.863 49.323/-122.863 \n",
"2 2.0 Pitt Meadows V3Y Canada \n",
"3 NaN 49.221/-122.69 49.221/-122.69 49.221/-122.69 \n",
"4 3.0 White Rock V4B Canada \n",
"\n",
" Admin1 Admin2 Admin3 \n",
"0 British Columbia NaN NaN \n",
"1 49.323/-122.863 49.323/-122.863 49.323/-122.863 \n",
"2 British Columbia NaN NaN \n",
"3 49.221/-122.69 49.221/-122.69 49.221/-122.69 \n",
"4 British Columbia NaN NaN "
]
},
"execution_count": 18,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"remove = df1[df1['Unnamed: 0']=='NaN'].index\n",
"df1.drop(remove,axis=0, inplace=True)\n",
"print(df1.shape)\n",
"df1.head()"
]
},
{
"cell_type": "code",
"execution_count": 19,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>index</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" <th>Admin2</th>\n",
" <th>Admin3</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>1.0</td>\n",
" <td>Port Moody</td>\n",
" <td>V3H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>NaN</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" <td>49.323/-122.863</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>2.0</td>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>NaN</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" <td>49.221/-122.69</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>3.0</td>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" index Place Code Country Admin1 \\\n",
"0 1.0 Port Moody V3H Canada British Columbia \n",
"1 NaN 49.323/-122.863 49.323/-122.863 49.323/-122.863 49.323/-122.863 \n",
"2 2.0 Pitt Meadows V3Y Canada British Columbia \n",
"3 NaN 49.221/-122.69 49.221/-122.69 49.221/-122.69 49.221/-122.69 \n",
"4 3.0 White Rock V4B Canada British Columbia \n",
"\n",
" Admin2 Admin3 \n",
"0 NaN NaN \n",
"1 49.323/-122.863 49.323/-122.863 \n",
"2 NaN NaN \n",
"3 49.221/-122.69 49.221/-122.69 \n",
"4 NaN NaN "
]
},
"execution_count": 19,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df1.rename(columns = {'Unnamed: 0':'index'}, inplace = True)\n",
"df1.head()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Now, we see that each row is followed by a row consisting of its coordinates. Hence extract the alternate rows and store the address data of each neighborhood in a temporary data frame and remove the null values.\n"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>index</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" <th>Admin2</th>\n",
" <th>Admin3</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>1.0</td>\n",
" <td>Port Moody</td>\n",
" <td>V3H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>2.0</td>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>3.0</td>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>6</th>\n",
" <td>4.0</td>\n",
" <td>Penticton</td>\n",
" <td>V2A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>8</th>\n",
" <td>5.0</td>\n",
" <td>Westbank</td>\n",
" <td>V4T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" index Place Code Country Admin1 Admin2 Admin3\n",
"0 1.0 Port Moody V3H Canada British Columbia NaN NaN\n",
"2 2.0 Pitt Meadows V3Y Canada British Columbia NaN NaN\n",
"4 3.0 White Rock V4B Canada British Columbia NaN NaN\n",
"6 4.0 Penticton V2A Canada British Columbia NaN NaN\n",
"8 5.0 Westbank V4T Canada British Columbia NaN NaN"
]
},
"execution_count": 20,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df2 = df1.iloc[::2]\n",
"df2.head()"
]
},
{
"cell_type": "code",
"execution_count": 20,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(193, 5)\n"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
"/home/jupyterlab/conda/envs/python/lib/python3.6/site-packages/pandas/core/frame.py:3997: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame\n",
"\n",
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
" errors=errors,\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>index</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>376</th>\n",
" <td>189.0</td>\n",
" <td>Vancouver (NE Downtown / Harbour Centre / Gast...</td>\n",
" <td>V6B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>378</th>\n",
" <td>190.0</td>\n",
" <td>Richmond South</td>\n",
" <td>V7A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>380</th>\n",
" <td>191.0</td>\n",
" <td>Duncan</td>\n",
" <td>V9L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>382</th>\n",
" <td>192.0</td>\n",
" <td>Parksville</td>\n",
" <td>V9P</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>384</th>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" index Place Code Country \\\n",
"376 189.0 Vancouver (NE Downtown / Harbour Centre / Gast... V6B Canada \n",
"378 190.0 Richmond South V7A Canada \n",
"380 191.0 Duncan V9L Canada \n",
"382 192.0 Parksville V9P Canada \n",
"384 NaN NaN NaN NaN \n",
"\n",
" Admin1 \n",
"376 British Columbia \n",
"378 British Columbia \n",
"380 British Columbia \n",
"382 British Columbia \n",
"384 NaN "
]
},
"execution_count": 20,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df2.drop(['Admin2', 'Admin3'], axis=1, inplace=True)\n",
"print(df2.shape)\n",
"df2.tail()"
]
},
{
"cell_type": "code",
"execution_count": 22,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(192, 5)\n"
]
},
{
"name": "stderr",
"output_type": "stream",
"text": [
"/home/jupyterlab/conda/envs/python/lib/python3.6/site-packages/ipykernel_launcher.py:1: SettingWithCopyWarning: \n",
"A value is trying to be set on a copy of a slice from a DataFrame\n",
"\n",
"See the caveats in the documentation: https://pandas.pydata.org/pandas-docs/stable/user_guide/indexing.html#returning-a-view-versus-a-copy\n",
" \"\"\"Entry point for launching an IPython kernel.\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>index</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>374</th>\n",
" <td>188.0</td>\n",
" <td>Vancouver (Strathcona / Chinatown / Downtown E...</td>\n",
" <td>V6A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>376</th>\n",
" <td>189.0</td>\n",
" <td>Vancouver (NE Downtown / Harbour Centre / Gast...</td>\n",
" <td>V6B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>378</th>\n",
" <td>190.0</td>\n",
" <td>Richmond South</td>\n",
" <td>V7A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>380</th>\n",
" <td>191.0</td>\n",
" <td>Duncan</td>\n",
" <td>V9L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>382</th>\n",
" <td>192.0</td>\n",
" <td>Parksville</td>\n",
" <td>V9P</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" index Place Code Country \\\n",
"374 188.0 Vancouver (Strathcona / Chinatown / Downtown E... V6A Canada \n",
"376 189.0 Vancouver (NE Downtown / Harbour Centre / Gast... V6B Canada \n",
"378 190.0 Richmond South V7A Canada \n",
"380 191.0 Duncan V9L Canada \n",
"382 192.0 Parksville V9P Canada \n",
"\n",
" Admin1 \n",
"374 British Columbia \n",
"376 British Columbia \n",
"378 British Columbia \n",
"380 British Columbia \n",
"382 British Columbia "
]
},
"execution_count": 22,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df2.dropna(subset = [\"index\"], inplace=True)\n",
"print(df2.shape)\n",
"df2.tail()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### In the main data frame, we are left with the coordinate values corresponding to each address in the temp data frame. All the cells of the row contain the same coordinate values given by latitude/longitude. Hence we drop all duplicate column, rename the column name as 'Coordinates', and merge the address values from the temporary data frame to the main data frame.\n"
]
},
{
"cell_type": "code",
"execution_count": 23,
"metadata": {},
"outputs": [],
"source": [
"j=1.0\n",
"for i in range(df1.shape[0]):\n",
" remove = df1[df1[\"index\"]==j].index\n",
" df1.drop(remove, axis=0, inplace=True)\n",
" j+=1.0"
]
},
{
"cell_type": "code",
"execution_count": 24,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>index</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" <th>Admin2</th>\n",
" <th>Admin3</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>377</th>\n",
" <td>NaN</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" </tr>\n",
" <tr>\n",
" <th>379</th>\n",
" <td>NaN</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" </tr>\n",
" <tr>\n",
" <th>381</th>\n",
" <td>NaN</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" </tr>\n",
" <tr>\n",
" <th>383</th>\n",
" <td>NaN</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" </tr>\n",
" <tr>\n",
" <th>384</th>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" index Place Code Country \\\n",
"377 NaN 49.279/-123.114 49.279/-123.114 49.279/-123.114 \n",
"379 NaN 49.12/-123.117 49.12/-123.117 49.12/-123.117 \n",
"381 NaN 48.783/-123.703 48.783/-123.703 48.783/-123.703 \n",
"383 NaN 49.316/-124.319 49.316/-124.319 49.316/-124.319 \n",
"384 NaN NaN NaN NaN \n",
"\n",
" Admin1 Admin2 Admin3 \n",
"377 49.279/-123.114 49.279/-123.114 49.279/-123.114 \n",
"379 49.12/-123.117 49.12/-123.117 49.12/-123.117 \n",
"381 48.783/-123.703 48.783/-123.703 48.783/-123.703 \n",
"383 49.316/-124.319 49.316/-124.319 49.316/-124.319 \n",
"384 NaN NaN NaN "
]
},
"execution_count": 24,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df1.tail()"
]
},
{
"cell_type": "code",
"execution_count": 25,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(192, 7)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>index</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" <th>Admin2</th>\n",
" <th>Admin3</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>375</th>\n",
" <td>NaN</td>\n",
" <td>49.278/-123.091</td>\n",
" <td>49.278/-123.091</td>\n",
" <td>49.278/-123.091</td>\n",
" <td>49.278/-123.091</td>\n",
" <td>49.278/-123.091</td>\n",
" <td>49.278/-123.091</td>\n",
" </tr>\n",
" <tr>\n",
" <th>377</th>\n",
" <td>NaN</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" <td>49.279/-123.114</td>\n",
" </tr>\n",
" <tr>\n",
" <th>379</th>\n",
" <td>NaN</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" <td>49.12/-123.117</td>\n",
" </tr>\n",
" <tr>\n",
" <th>381</th>\n",
" <td>NaN</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" <td>48.783/-123.703</td>\n",
" </tr>\n",
" <tr>\n",
" <th>383</th>\n",
" <td>NaN</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" <td>49.316/-124.319</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" index Place Code Country \\\n",
"375 NaN 49.278/-123.091 49.278/-123.091 49.278/-123.091 \n",
"377 NaN 49.279/-123.114 49.279/-123.114 49.279/-123.114 \n",
"379 NaN 49.12/-123.117 49.12/-123.117 49.12/-123.117 \n",
"381 NaN 48.783/-123.703 48.783/-123.703 48.783/-123.703 \n",
"383 NaN 49.316/-124.319 49.316/-124.319 49.316/-124.319 \n",
"\n",
" Admin1 Admin2 Admin3 \n",
"375 49.278/-123.091 49.278/-123.091 49.278/-123.091 \n",
"377 49.279/-123.114 49.279/-123.114 49.279/-123.114 \n",
"379 49.12/-123.117 49.12/-123.117 49.12/-123.117 \n",
"381 48.783/-123.703 48.783/-123.703 48.783/-123.703 \n",
"383 49.316/-124.319 49.316/-124.319 49.316/-124.319 "
]
},
"execution_count": 25,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df1.dropna(subset = [\"Place\"], inplace=True)\n",
"print(df1.shape)\n",
"df1.tail()"
]
},
{
"cell_type": "code",
"execution_count": 26,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(192, 1)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>49.323/-122.863</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>49.221/-122.69</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5</th>\n",
" <td>49.026/-122.806</td>\n",
" </tr>\n",
" <tr>\n",
" <th>7</th>\n",
" <td>49.481/-119.586</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9</th>\n",
" <td>49.866/-119.739</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place\n",
"1 49.323/-122.863\n",
"3 49.221/-122.69\n",
"5 49.026/-122.806\n",
"7 49.481/-119.586\n",
"9 49.866/-119.739"
]
},
"execution_count": 26,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df1.drop(['index','Code','Country','Admin1','Admin2','Admin3'], axis=1, inplace=True)\n",
"print(df1.shape)\n",
"df1.head()"
]
},
{
"cell_type": "code",
"execution_count": 27,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Coordinates</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>49.323/-122.863</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>49.221/-122.69</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5</th>\n",
" <td>49.026/-122.806</td>\n",
" </tr>\n",
" <tr>\n",
" <th>7</th>\n",
" <td>49.481/-119.586</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9</th>\n",
" <td>49.866/-119.739</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Coordinates\n",
"1 49.323/-122.863\n",
"3 49.221/-122.69\n",
"5 49.026/-122.806\n",
"7 49.481/-119.586\n",
"9 49.866/-119.739"
]
},
"execution_count": 27,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df1.rename(columns={'Place':'Coordinates'}, inplace=True)\n",
"df1.head()"
]
},
{
"cell_type": "code",
"execution_count": 28,
"metadata": {},
"outputs": [],
"source": [
"df1.reset_index(inplace = True, drop = True) \n",
"df2.reset_index(inplace = True, drop = True) "
]
},
{
"cell_type": "code",
"execution_count": 29,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Coordinates</th>\n",
" <th>Place</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>49.323/-122.863</td>\n",
" <td>Port Moody</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>49.221/-122.69</td>\n",
" <td>Pitt Meadows</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>49.026/-122.806</td>\n",
" <td>White Rock</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>49.481/-119.586</td>\n",
" <td>Penticton</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>49.866/-119.739</td>\n",
" <td>Westbank</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Coordinates Place\n",
"0 49.323/-122.863 Port Moody\n",
"1 49.221/-122.69 Pitt Meadows\n",
"2 49.026/-122.806 White Rock\n",
"3 49.481/-119.586 Penticton\n",
"4 49.866/-119.739 Westbank"
]
},
"execution_count": 29,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df1[\"Place\"]=df2[[\"Place\"]]\n",
"df1.head()"
]
},
{
"cell_type": "code",
"execution_count": 30,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>index</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>1.0</td>\n",
" <td>Port Moody</td>\n",
" <td>V3H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>2.0</td>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>3.0</td>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>4.0</td>\n",
" <td>Penticton</td>\n",
" <td>V2A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>5.0</td>\n",
" <td>Westbank</td>\n",
" <td>V4T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" index Place Code Country Admin1\n",
"0 1.0 Port Moody V3H Canada British Columbia\n",
"1 2.0 Pitt Meadows V3Y Canada British Columbia\n",
"2 3.0 White Rock V4B Canada British Columbia\n",
"3 4.0 Penticton V2A Canada British Columbia\n",
"4 5.0 Westbank V4T Canada British Columbia"
]
},
"execution_count": 30,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df2.head()"
]
},
{
"cell_type": "code",
"execution_count": 31,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Coordinates</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Admin1</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>49.323/-122.863</td>\n",
" <td>Port Moody</td>\n",
" <td>V3H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>49.221/-122.69</td>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>49.026/-122.806</td>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>49.481/-119.586</td>\n",
" <td>Penticton</td>\n",
" <td>V2A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>49.866/-119.739</td>\n",
" <td>Westbank</td>\n",
" <td>V4T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Coordinates Place Code Country Admin1\n",
"0 49.323/-122.863 Port Moody V3H Canada British Columbia\n",
"1 49.221/-122.69 Pitt Meadows V3Y Canada British Columbia\n",
"2 49.026/-122.806 White Rock V4B Canada British Columbia\n",
"3 49.481/-119.586 Penticton V2A Canada British Columbia\n",
"4 49.866/-119.739 Westbank V4T Canada British Columbia"
]
},
"execution_count": 31,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df1[\"Code\"]=df2[[\"Code\"]]\n",
"df1[\"Country\"]=df2[[\"Country\"]]\n",
"df1[\"Admin1\"]=df2[[\"Admin1\"]]\n",
"df1.head()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Now, we have obtained all the required data in one data frame. Upon checking the data types of each column, we find that that the coordinate values are in the 'string' data type,. Hence to use them in further processing, we split the values into latitude and longitude values, store them separately in the data frame and convert them to the float data type.\n"
]
},
{
"cell_type": "code",
"execution_count": 32,
"metadata": {},
"outputs": [],
"source": [
"coordinates = df1[[\"Coordinates\"]].values.tolist()"
]
},
{
"cell_type": "code",
"execution_count": 33,
"metadata": {},
"outputs": [],
"source": [
"lat=[]\n",
"long=[]\n",
"for i in range(len(coordinates)):\n",
" coord = coordinates[i][0].split(\"/\")\n",
" lat.append(coord[0])\n",
" long.append(coord[1])"
]
},
{
"cell_type": "code",
"execution_count": 34,
"metadata": {},
"outputs": [],
"source": [
"df1[\"Latitude\"] = lat\n",
"df1[\"Longitude\"] = long"
]
},
{
"cell_type": "code",
"execution_count": 35,
"metadata": {},
"outputs": [],
"source": [
"df1.rename(columns={'Admin1':'Province'}, inplace=True)"
]
},
{
"cell_type": "code",
"execution_count": 36,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Coordinates</th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Province</th>\n",
" <th>Latitude</th>\n",
" <th>Longitude</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>49.323/-122.863</td>\n",
" <td>Port Moody</td>\n",
" <td>V3H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.323</td>\n",
" <td>-122.863</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>49.221/-122.69</td>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.221</td>\n",
" <td>-122.69</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>49.026/-122.806</td>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.026</td>\n",
" <td>-122.806</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>49.481/-119.586</td>\n",
" <td>Penticton</td>\n",
" <td>V2A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.481</td>\n",
" <td>-119.586</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>49.866/-119.739</td>\n",
" <td>Westbank</td>\n",
" <td>V4T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.866</td>\n",
" <td>-119.739</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Coordinates Place Code Country Province Latitude \\\n",
"0 49.323/-122.863 Port Moody V3H Canada British Columbia 49.323 \n",
"1 49.221/-122.69 Pitt Meadows V3Y Canada British Columbia 49.221 \n",
"2 49.026/-122.806 White Rock V4B Canada British Columbia 49.026 \n",
"3 49.481/-119.586 Penticton V2A Canada British Columbia 49.481 \n",
"4 49.866/-119.739 Westbank V4T Canada British Columbia 49.866 \n",
"\n",
" Longitude \n",
"0 -122.863 \n",
"1 -122.69 \n",
"2 -122.806 \n",
"3 -119.586 \n",
"4 -119.739 "
]
},
"execution_count": 36,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df1.head()"
]
},
{
"cell_type": "code",
"execution_count": 37,
"metadata": {},
"outputs": [],
"source": [
"df1[['Latitude','Longitude']] = df1[['Latitude','Longitude']].astype(np.float16) "
]
},
{
"cell_type": "code",
"execution_count": 38,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(192, 7)\n"
]
},
{
"data": {
"text/plain": [
"Coordinates object\n",
"Place object\n",
"Code object\n",
"Country object\n",
"Province object\n",
"Latitude float16\n",
"Longitude float16\n",
"dtype: object"
]
},
"execution_count": 38,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"print(df1.shape)\n",
"df1.dtypes"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### We also notice that several different locations inside the same cities having different postal codes have been included in our dataset. Under the assumption that the popular places that we aim to explore in each city will be similar, we remove redundant city values from our data frame. For example, if we have Vancouver East and Vancouver West in our data frame, then we remove the 'East' and the 'West' part and combine them into one 'Vancouver.\n"
]
},
{
"cell_type": "code",
"execution_count": 39,
"metadata": {},
"outputs": [],
"source": [
"place = df1['Place'].tolist()"
]
},
{
"cell_type": "code",
"execution_count": 40,
"metadata": {},
"outputs": [],
"source": [
"new_place = []\n",
"for i in place:\n",
" new_place.append(i.split(\" (\")[0])"
]
},
{
"cell_type": "code",
"execution_count": 41,
"metadata": {},
"outputs": [],
"source": [
"df1['Place'] = new_place"
]
},
{
"cell_type": "code",
"execution_count": 73,
"metadata": {},
"outputs": [],
"source": [
"aggregation_functions = {'Code': 'first', 'Country': 'first', 'Province': 'first', 'Latitude' : 'mean', 'Longitude' : 'mean'}\n",
"df_new = df1.groupby(df1['Place']).aggregate(aggregation_functions)"
]
},
{
"cell_type": "code",
"execution_count": 74,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(155, 5)\n"
]
}
],
"source": [
"print(df_new.shape)\n",
"df_new.reset_index(inplace=True)"
]
},
{
"cell_type": "code",
"execution_count": 75,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Province</th>\n",
" <th>Latitude</th>\n",
" <th>Longitude</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford East</td>\n",
" <td>V3G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.06250</td>\n",
" <td>-122.1875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Abbotsford Southeast</td>\n",
" <td>V2S</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.03125</td>\n",
" <td>-122.3125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Abbotsford Southwest</td>\n",
" <td>V2T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.03125</td>\n",
" <td>-122.3750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Abbotsford West</td>\n",
" <td>V4X</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.09375</td>\n",
" <td>-122.3750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Atlin Region</td>\n",
" <td>V0W</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>59.62500</td>\n",
" <td>-133.5000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>...</th>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>150</th>\n",
" <td>Westbank</td>\n",
" <td>V4T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.87500</td>\n",
" <td>-119.7500</td>\n",
" </tr>\n",
" <tr>\n",
" <th>151</th>\n",
" <td>Whistler</td>\n",
" <td>V8E</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.12500</td>\n",
" <td>-122.9375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>152</th>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.03125</td>\n",
" <td>-122.8125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>153</th>\n",
" <td>Williams Lake</td>\n",
" <td>V2G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>52.15625</td>\n",
" <td>-122.1250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>154</th>\n",
" <td>Winfield</td>\n",
" <td>V4V</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.03125</td>\n",
" <td>-119.3750</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"<p>155 rows × 6 columns</p>\n",
"</div>"
],
"text/plain": [
" Place Code Country Province Latitude Longitude\n",
"0 Abbotsford East V3G Canada British Columbia 49.06250 -122.1875\n",
"1 Abbotsford Southeast V2S Canada British Columbia 49.03125 -122.3125\n",
"2 Abbotsford Southwest V2T Canada British Columbia 49.03125 -122.3750\n",
"3 Abbotsford West V4X Canada British Columbia 49.09375 -122.3750\n",
"4 Atlin Region V0W Canada British Columbia 59.62500 -133.5000\n",
".. ... ... ... ... ... ...\n",
"150 Westbank V4T Canada British Columbia 49.87500 -119.7500\n",
"151 Whistler V8E Canada British Columbia 50.12500 -122.9375\n",
"152 White Rock V4B Canada British Columbia 49.03125 -122.8125\n",
"153 Williams Lake V2G Canada British Columbia 52.15625 -122.1250\n",
"154 Winfield V4V Canada British Columbia 50.03125 -119.3750\n",
"\n",
"[155 rows x 6 columns]"
]
},
"execution_count": 75,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df_new"
]
},
{
"cell_type": "code",
"execution_count": 80,
"metadata": {},
"outputs": [],
"source": [
"place1 = df_new['Place'].tolist()"
]
},
{
"cell_type": "code",
"execution_count": 81,
"metadata": {},
"outputs": [],
"source": [
"new_place1 = []\n",
"for i in place1:\n",
" new_place1.append(i.split(\" \")[0])"
]
},
{
"cell_type": "code",
"execution_count": 82,
"metadata": {},
"outputs": [],
"source": [
"df_new['Distinct place'] = new_place1"
]
},
{
"cell_type": "code",
"execution_count": 83,
"metadata": {},
"outputs": [],
"source": [
"aggregation_functions = {'Place' : 'first' ,'Code': 'first', 'Country': 'first', 'Province': 'first', 'Latitude' : 'mean', 'Longitude' : 'mean'}\n",
"df_new = df_new.groupby(df_new['Distinct place']).aggregate(aggregation_functions)"
]
},
{
"cell_type": "code",
"execution_count": 84,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"['Abbotsford',\n",
" 'Atlin Region',\n",
" 'Burnaby',\n",
" 'Campbell River Central',\n",
" 'Cariboo and West Okanagan',\n",
" 'Castlegar',\n",
" 'Cedar',\n",
" 'Central Island',\n",
" 'Chilcotin',\n",
" 'Chilliwack Central',\n",
" 'Comox',\n",
" 'Coquitlam',\n",
" 'Courtenay Central',\n",
" 'Cranbrook',\n",
" 'Dawson Creek',\n",
" 'Delta Central',\n",
" 'Duncan',\n",
" 'East Kootenays',\n",
" 'Esquimalt',\n",
" 'Fort St. John',\n",
" 'Harrison Lake Region',\n",
" 'Highlands',\n",
" 'Inside Passage and the Queen Charlottes',\n",
" 'Juan de Fuca Shore',\n",
" 'Kamloops Central and',\n",
" 'Kelowna Central',\n",
" 'Kimberley',\n",
" 'Kitimat',\n",
" 'Ladysmith',\n",
" 'Langley City',\n",
" 'Lower Skeena',\n",
" 'Maple Ridge',\n",
" 'Merritt',\n",
" 'Metchosin',\n",
" 'Mission',\n",
" 'Nanaimo Central',\n",
" 'Nelson',\n",
" 'New Westminster Northeast',\n",
" 'North Central Island and Bute Inlet Region',\n",
" 'Northern British Columbia',\n",
" 'Oak Bay',\n",
" 'Omineca and Yellowhead',\n",
" 'Parksville',\n",
" 'Penticton',\n",
" 'Pitt Meadows',\n",
" 'Port Alberni',\n",
" 'Powell River',\n",
" 'Prince George Central',\n",
" 'Qualicum Beach',\n",
" 'Quesnel',\n",
" 'Richmond',\n",
" 'Saanich Central',\n",
" 'Salmon Arm',\n",
" 'Saltspring Island',\n",
" 'Sidney',\n",
" 'Similkameen',\n",
" 'Sooke',\n",
" 'South Okanagan',\n",
" 'Squamish',\n",
" 'Surrey',\n",
" 'Terrace',\n",
" 'Trail',\n",
" 'Upper Columbia Region',\n",
" 'Vancouver',\n",
" 'Vernon Central',\n",
" 'Victoria Central British Columbia Provincial Government',\n",
" 'West Kootenays',\n",
" 'Westbank',\n",
" 'Whistler',\n",
" 'White Rock',\n",
" 'Williams Lake',\n",
" 'Winfield']"
]
},
"execution_count": 84,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"modified_places = df_new['Place'].tolist()\n",
"for index, word in enumerate(modified_places):\n",
" if \" North Island, Sunshine Coast\" in word:\n",
" pass\n",
" elif \" Westminster\" in word:\n",
" pass\n",
" elif \" Northern\" in word:\n",
" pass\n",
" elif \" West Okanagan\" in word:\n",
" pass\n",
" elif \" East\" in word:\n",
" modified_places[index]=modified_places[index].replace(\" East\",\"\")\n",
" elif \" West\" in word:\n",
" modified_places[index]=modified_places[index].replace(\" West\",\"\")\n",
" elif \" Southeast\" in word:\n",
" modified_places[index]=modified_places[index].replace(\" Southeast\",\"\")\n",
" elif \" Northeast\" in word:\n",
" modified_places[index]=modified_places[index].replace(\" Northeast\",\"\")\n",
" elif \" North\" in word:\n",
" modified_places[index]=modified_places[index].replace(\" North\",\"\")\n",
" elif \" South\" in word:\n",
" modified_places[index]=modified_places[index].replace(\" South\",\"\")\n",
"modified_places"
]
},
{
"cell_type": "code",
"execution_count": 85,
"metadata": {},
"outputs": [],
"source": [
"df_new['Place'] = modified_places"
]
},
{
"cell_type": "code",
"execution_count": 86,
"metadata": {},
"outputs": [],
"source": [
"df_new.at[38, 'Place'] = \"North Island, Sunshine Coast\""
]
},
{
"cell_type": "code",
"execution_count": 89,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(73, 6)\n"
]
}
],
"source": [
"print(df_new.shape)\n",
"df_new.reset_index(inplace=True)"
]
},
{
"cell_type": "code",
"execution_count": 90,
"metadata": {},
"outputs": [],
"source": [
"df_new.drop(['Distinct place'], axis=1, inplace=True)"
]
},
{
"cell_type": "code",
"execution_count": 92,
"metadata": {},
"outputs": [],
"source": [
"pd.set_option('display.max_rows', df_new.shape[0]+1)"
]
},
{
"cell_type": "code",
"execution_count": 94,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(72, 6)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Province</th>\n",
" <th>Latitude</th>\n",
" <th>Longitude</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford</td>\n",
" <td>V3G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.06250</td>\n",
" <td>-122.3125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Atlin Region</td>\n",
" <td>V0W</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>59.62500</td>\n",
" <td>-133.5000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Burnaby</td>\n",
" <td>V3N</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.25000</td>\n",
" <td>-123.0000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Campbell River Central</td>\n",
" <td>V9W</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.00000</td>\n",
" <td>-125.5625</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Cariboo and West Okanagan</td>\n",
" <td>V0K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>51.43750</td>\n",
" <td>-121.6250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5</th>\n",
" <td>Castlegar</td>\n",
" <td>V1N</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.31250</td>\n",
" <td>-117.6875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>6</th>\n",
" <td>Cedar</td>\n",
" <td>V9X</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.03125</td>\n",
" <td>-124.0000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>7</th>\n",
" <td>Central Island</td>\n",
" <td>V0R</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.68750</td>\n",
" <td>-122.5000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>8</th>\n",
" <td>Chilcotin</td>\n",
" <td>V0L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>52.09375</td>\n",
" <td>-123.6250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9</th>\n",
" <td>Chilliwack Central</td>\n",
" <td>V2P</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.12500</td>\n",
" <td>-121.8125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>10</th>\n",
" <td>Comox</td>\n",
" <td>V9M</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.68750</td>\n",
" <td>-124.9375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>11</th>\n",
" <td>Coquitlam</td>\n",
" <td>V3J</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.25000</td>\n",
" <td>-122.8750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>12</th>\n",
" <td>Courtenay Central</td>\n",
" <td>V9N</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.68750</td>\n",
" <td>-125.1250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>13</th>\n",
" <td>Cranbrook</td>\n",
" <td>V1C</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.50000</td>\n",
" <td>-115.7500</td>\n",
" </tr>\n",
" <tr>\n",
" <th>14</th>\n",
" <td>Dawson Creek</td>\n",
" <td>V1G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>55.78125</td>\n",
" <td>-120.2500</td>\n",
" </tr>\n",
" <tr>\n",
" <th>15</th>\n",
" <td>Delta Central</td>\n",
" <td>V4K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.09375</td>\n",
" <td>-123.0000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>16</th>\n",
" <td>Duncan</td>\n",
" <td>V9L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.78125</td>\n",
" <td>-123.6875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>17</th>\n",
" <td>East Kootenays</td>\n",
" <td>V0B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.68750</td>\n",
" <td>-115.5625</td>\n",
" </tr>\n",
" <tr>\n",
" <th>18</th>\n",
" <td>Esquimalt</td>\n",
" <td>V9A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.43750</td>\n",
" <td>-123.4375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>19</th>\n",
" <td>Fort St. John</td>\n",
" <td>V1J</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>56.25000</td>\n",
" <td>-120.8750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>20</th>\n",
" <td>Harrison Lake Region</td>\n",
" <td>V0M</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.62500</td>\n",
" <td>-122.0625</td>\n",
" </tr>\n",
" <tr>\n",
" <th>21</th>\n",
" <td>Highlands</td>\n",
" <td>V9B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.46875</td>\n",
" <td>-123.5000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>22</th>\n",
" <td>Inside Passage and the Queen Charlottes</td>\n",
" <td>V0T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>52.21875</td>\n",
" <td>-126.1875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>23</th>\n",
" <td>Juan de Fuca Shore</td>\n",
" <td>V0S</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.53125</td>\n",
" <td>-123.6875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>24</th>\n",
" <td>Kamloops Central and</td>\n",
" <td>V2C</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.68750</td>\n",
" <td>-120.4375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>25</th>\n",
" <td>Kelowna Central</td>\n",
" <td>V1Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.90625</td>\n",
" <td>-119.4375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>26</th>\n",
" <td>Kimberley</td>\n",
" <td>V1A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.68750</td>\n",
" <td>-116.0000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>27</th>\n",
" <td>Kitimat</td>\n",
" <td>V8C</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>54.06250</td>\n",
" <td>-128.6250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>28</th>\n",
" <td>Ladysmith</td>\n",
" <td>V9G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.96875</td>\n",
" <td>-123.8125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>29</th>\n",
" <td>Langley City</td>\n",
" <td>V3A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.09375</td>\n",
" <td>-122.5625</td>\n",
" </tr>\n",
" <tr>\n",
" <th>30</th>\n",
" <td>Lower Skeena</td>\n",
" <td>V0V</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>53.96875</td>\n",
" <td>-129.8750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>31</th>\n",
" <td>Maple Ridge</td>\n",
" <td>V2W</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.25000</td>\n",
" <td>-122.5625</td>\n",
" </tr>\n",
" <tr>\n",
" <th>32</th>\n",
" <td>Merritt</td>\n",
" <td>V1K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.12500</td>\n",
" <td>-120.8125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>33</th>\n",
" <td>Metchosin</td>\n",
" <td>V9C</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.37500</td>\n",
" <td>-123.5625</td>\n",
" </tr>\n",
" <tr>\n",
" <th>34</th>\n",
" <td>Mission</td>\n",
" <td>V2V</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.43750</td>\n",
" <td>-122.4375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>35</th>\n",
" <td>Nanaimo Central</td>\n",
" <td>V9S</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.18750</td>\n",
" <td>-124.0000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>36</th>\n",
" <td>Nelson</td>\n",
" <td>V1L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.50000</td>\n",
" <td>-117.3125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>37</th>\n",
" <td>New Westminster Northeast</td>\n",
" <td>V3L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.18750</td>\n",
" <td>-122.8750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>38</th>\n",
" <td>North Central Island and Bute Inlet Region</td>\n",
" <td>V0P</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.56250</td>\n",
" <td>-123.6250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>39</th>\n",
" <td>Northern British Columbia</td>\n",
" <td>V0C</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>58.37500</td>\n",
" <td>-125.6875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>40</th>\n",
" <td>Oak Bay</td>\n",
" <td>V8R</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.43750</td>\n",
" <td>-123.3125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>41</th>\n",
" <td>Omineca and Yellowhead</td>\n",
" <td>V0J</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>56.00000</td>\n",
" <td>-126.8750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>42</th>\n",
" <td>Parksville</td>\n",
" <td>V9P</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.31250</td>\n",
" <td>-124.3125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>43</th>\n",
" <td>Penticton</td>\n",
" <td>V2A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.46875</td>\n",
" <td>-119.5625</td>\n",
" </tr>\n",
" <tr>\n",
" <th>44</th>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.21875</td>\n",
" <td>-122.6875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>45</th>\n",
" <td>Port Alberni</td>\n",
" <td>V9Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.28125</td>\n",
" <td>-123.1875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>46</th>\n",
" <td>Powell River</td>\n",
" <td>V8A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.03125</td>\n",
" <td>-124.3125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>47</th>\n",
" <td>Prince George Central</td>\n",
" <td>V2L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>53.96875</td>\n",
" <td>-124.3750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>48</th>\n",
" <td>Qualicum Beach</td>\n",
" <td>V9K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.34375</td>\n",
" <td>-124.4375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>49</th>\n",
" <td>Quesnel</td>\n",
" <td>V2J</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>52.96875</td>\n",
" <td>-122.5000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>50</th>\n",
" <td>Richmond</td>\n",
" <td>V7B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.15625</td>\n",
" <td>-123.1250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>51</th>\n",
" <td>Saanich Central</td>\n",
" <td>V8Z</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.50000</td>\n",
" <td>-123.3750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>52</th>\n",
" <td>Salmon Arm</td>\n",
" <td>V1E</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.68750</td>\n",
" <td>-119.2500</td>\n",
" </tr>\n",
" <tr>\n",
" <th>53</th>\n",
" <td>Saltspring Island</td>\n",
" <td>V8K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.81250</td>\n",
" <td>-123.5000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>54</th>\n",
" <td>Sidney</td>\n",
" <td>V8L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.65625</td>\n",
" <td>-123.3750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>55</th>\n",
" <td>Similkameen</td>\n",
" <td>V0X</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.37500</td>\n",
" <td>-120.6875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>56</th>\n",
" <td>Sooke</td>\n",
" <td>V9Z</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.37500</td>\n",
" <td>-123.7500</td>\n",
" </tr>\n",
" <tr>\n",
" <th>57</th>\n",
" <td>South Okanagan</td>\n",
" <td>V0H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.40625</td>\n",
" <td>-119.0000</td>\n",
" </tr>\n",
" <tr>\n",
" <th>58</th>\n",
" <td>Squamish</td>\n",
" <td>V8B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.68750</td>\n",
" <td>-123.1250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>59</th>\n",
" <td>Surrey</td>\n",
" <td>V3Z</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.12500</td>\n",
" <td>-122.8125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>60</th>\n",
" <td>Terrace</td>\n",
" <td>V8G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>54.53125</td>\n",
" <td>-128.6250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>61</th>\n",
" <td>Trail</td>\n",
" <td>V1R</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.09375</td>\n",
" <td>-117.6875</td>\n",
" </tr>\n",
" <tr>\n",
" <th>62</th>\n",
" <td>Upper Columbia Region</td>\n",
" <td>V0A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>51.31250</td>\n",
" <td>-116.9375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>63</th>\n",
" <td>Vancouver</td>\n",
" <td>V5K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.25000</td>\n",
" <td>-123.1250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>64</th>\n",
" <td>Vernon Central</td>\n",
" <td>V1T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.21875</td>\n",
" <td>-119.2500</td>\n",
" </tr>\n",
" <tr>\n",
" <th>65</th>\n",
" <td>Victoria Central British Columbia Provincial G...</td>\n",
" <td>V8W</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.43750</td>\n",
" <td>-123.3750</td>\n",
" </tr>\n",
" <tr>\n",
" <th>66</th>\n",
" <td>West Kootenays</td>\n",
" <td>V0G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.50000</td>\n",
" <td>-122.0625</td>\n",
" </tr>\n",
" <tr>\n",
" <th>67</th>\n",
" <td>Westbank</td>\n",
" <td>V4T</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.87500</td>\n",
" <td>-119.7500</td>\n",
" </tr>\n",
" <tr>\n",
" <th>68</th>\n",
" <td>Whistler</td>\n",
" <td>V8E</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.12500</td>\n",
" <td>-122.9375</td>\n",
" </tr>\n",
" <tr>\n",
" <th>69</th>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.03125</td>\n",
" <td>-122.8125</td>\n",
" </tr>\n",
" <tr>\n",
" <th>70</th>\n",
" <td>Williams Lake</td>\n",
" <td>V2G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>52.15625</td>\n",
" <td>-122.1250</td>\n",
" </tr>\n",
" <tr>\n",
" <th>71</th>\n",
" <td>Winfield</td>\n",
" <td>V4V</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.03125</td>\n",
" <td>-119.3750</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place Code Country \\\n",
"0 Abbotsford V3G Canada \n",
"1 Atlin Region V0W Canada \n",
"2 Burnaby V3N Canada \n",
"3 Campbell River Central V9W Canada \n",
"4 Cariboo and West Okanagan V0K Canada \n",
"5 Castlegar V1N Canada \n",
"6 Cedar V9X Canada \n",
"7 Central Island V0R Canada \n",
"8 Chilcotin V0L Canada \n",
"9 Chilliwack Central V2P Canada \n",
"10 Comox V9M Canada \n",
"11 Coquitlam V3J Canada \n",
"12 Courtenay Central V9N Canada \n",
"13 Cranbrook V1C Canada \n",
"14 Dawson Creek V1G Canada \n",
"15 Delta Central V4K Canada \n",
"16 Duncan V9L Canada \n",
"17 East Kootenays V0B Canada \n",
"18 Esquimalt V9A Canada \n",
"19 Fort St. John V1J Canada \n",
"20 Harrison Lake Region V0M Canada \n",
"21 Highlands V9B Canada \n",
"22 Inside Passage and the Queen Charlottes V0T Canada \n",
"23 Juan de Fuca Shore V0S Canada \n",
"24 Kamloops Central and V2C Canada \n",
"25 Kelowna Central V1Y Canada \n",
"26 Kimberley V1A Canada \n",
"27 Kitimat V8C Canada \n",
"28 Ladysmith V9G Canada \n",
"29 Langley City V3A Canada \n",
"30 Lower Skeena V0V Canada \n",
"31 Maple Ridge V2W Canada \n",
"32 Merritt V1K Canada \n",
"33 Metchosin V9C Canada \n",
"34 Mission V2V Canada \n",
"35 Nanaimo Central V9S Canada \n",
"36 Nelson V1L Canada \n",
"37 New Westminster Northeast V3L Canada \n",
"38 North Central Island and Bute Inlet Region V0P Canada \n",
"39 Northern British Columbia V0C Canada \n",
"40 Oak Bay V8R Canada \n",
"41 Omineca and Yellowhead V0J Canada \n",
"42 Parksville V9P Canada \n",
"43 Penticton V2A Canada \n",
"44 Pitt Meadows V3Y Canada \n",
"45 Port Alberni V9Y Canada \n",
"46 Powell River V8A Canada \n",
"47 Prince George Central V2L Canada \n",
"48 Qualicum Beach V9K Canada \n",
"49 Quesnel V2J Canada \n",
"50 Richmond V7B Canada \n",
"51 Saanich Central V8Z Canada \n",
"52 Salmon Arm V1E Canada \n",
"53 Saltspring Island V8K Canada \n",
"54 Sidney V8L Canada \n",
"55 Similkameen V0X Canada \n",
"56 Sooke V9Z Canada \n",
"57 South Okanagan V0H Canada \n",
"58 Squamish V8B Canada \n",
"59 Surrey V3Z Canada \n",
"60 Terrace V8G Canada \n",
"61 Trail V1R Canada \n",
"62 Upper Columbia Region V0A Canada \n",
"63 Vancouver V5K Canada \n",
"64 Vernon Central V1T Canada \n",
"65 Victoria Central British Columbia Provincial G... V8W Canada \n",
"66 West Kootenays V0G Canada \n",
"67 Westbank V4T Canada \n",
"68 Whistler V8E Canada \n",
"69 White Rock V4B Canada \n",
"70 Williams Lake V2G Canada \n",
"71 Winfield V4V Canada \n",
"\n",
" Province Latitude Longitude \n",
"0 British Columbia 49.06250 -122.3125 \n",
"1 British Columbia 59.62500 -133.5000 \n",
"2 British Columbia 49.25000 -123.0000 \n",
"3 British Columbia 50.00000 -125.5625 \n",
"4 British Columbia 51.43750 -121.6250 \n",
"5 British Columbia 49.31250 -117.6875 \n",
"6 British Columbia 49.03125 -124.0000 \n",
"7 British Columbia 49.68750 -122.5000 \n",
"8 British Columbia 52.09375 -123.6250 \n",
"9 British Columbia 49.12500 -121.8125 \n",
"10 British Columbia 49.68750 -124.9375 \n",
"11 British Columbia 49.25000 -122.8750 \n",
"12 British Columbia 49.68750 -125.1250 \n",
"13 British Columbia 49.50000 -115.7500 \n",
"14 British Columbia 55.78125 -120.2500 \n",
"15 British Columbia 49.09375 -123.0000 \n",
"16 British Columbia 48.78125 -123.6875 \n",
"17 British Columbia 49.68750 -115.5625 \n",
"18 British Columbia 48.43750 -123.4375 \n",
"19 British Columbia 56.25000 -120.8750 \n",
"20 British Columbia 49.62500 -122.0625 \n",
"21 British Columbia 48.46875 -123.5000 \n",
"22 British Columbia 52.21875 -126.1875 \n",
"23 British Columbia 48.53125 -123.6875 \n",
"24 British Columbia 50.68750 -120.4375 \n",
"25 British Columbia 49.90625 -119.4375 \n",
"26 British Columbia 49.68750 -116.0000 \n",
"27 British Columbia 54.06250 -128.6250 \n",
"28 British Columbia 48.96875 -123.8125 \n",
"29 British Columbia 49.09375 -122.5625 \n",
"30 British Columbia 53.96875 -129.8750 \n",
"31 British Columbia 49.25000 -122.5625 \n",
"32 British Columbia 50.12500 -120.8125 \n",
"33 British Columbia 48.37500 -123.5625 \n",
"34 British Columbia 49.43750 -122.4375 \n",
"35 British Columbia 49.18750 -124.0000 \n",
"36 British Columbia 49.50000 -117.3125 \n",
"37 British Columbia 49.18750 -122.8750 \n",
"38 British Columbia 49.56250 -123.6250 \n",
"39 British Columbia 58.37500 -125.6875 \n",
"40 British Columbia 48.43750 -123.3125 \n",
"41 British Columbia 56.00000 -126.8750 \n",
"42 British Columbia 49.31250 -124.3125 \n",
"43 British Columbia 49.46875 -119.5625 \n",
"44 British Columbia 49.21875 -122.6875 \n",
"45 British Columbia 49.28125 -123.1875 \n",
"46 British Columbia 50.03125 -124.3125 \n",
"47 British Columbia 53.96875 -124.3750 \n",
"48 British Columbia 49.34375 -124.4375 \n",
"49 British Columbia 52.96875 -122.5000 \n",
"50 British Columbia 49.15625 -123.1250 \n",
"51 British Columbia 48.50000 -123.3750 \n",
"52 British Columbia 50.68750 -119.2500 \n",
"53 British Columbia 48.81250 -123.5000 \n",
"54 British Columbia 48.65625 -123.3750 \n",
"55 British Columbia 49.37500 -120.6875 \n",
"56 British Columbia 48.37500 -123.7500 \n",
"57 British Columbia 49.40625 -119.0000 \n",
"58 British Columbia 49.68750 -123.1250 \n",
"59 British Columbia 49.12500 -122.8125 \n",
"60 British Columbia 54.53125 -128.6250 \n",
"61 British Columbia 49.09375 -117.6875 \n",
"62 British Columbia 51.31250 -116.9375 \n",
"63 British Columbia 49.25000 -123.1250 \n",
"64 British Columbia 50.21875 -119.2500 \n",
"65 British Columbia 48.43750 -123.3750 \n",
"66 British Columbia 49.50000 -122.0625 \n",
"67 British Columbia 49.87500 -119.7500 \n",
"68 British Columbia 50.12500 -122.9375 \n",
"69 British Columbia 49.03125 -122.8125 \n",
"70 British Columbia 52.15625 -122.1250 \n",
"71 British Columbia 50.03125 -119.3750 "
]
},
"execution_count": 94,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"df_new.dropna(subset = [\"Code\"], inplace=True)\n",
"print(df_new.shape)\n",
"df_new"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Hence, after all the necessary cleaning and preprocessing, we obtain the final data frame with 72 addresses and their latitude and longitude values. This completes our second method of obtaining data.\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"## Methodology <a name=\"methodology\"></a>\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### In the methodology section, we begin with outlining a map of British Columbia and mark all the neighborhoods from our data frame onto the map. For this purpose, we utilize the visualization libraries and hence our first step would be to install and import them. We also import the KMeans package for clustering from the Sklearn library for later use.\n"
]
},
{
"cell_type": "code",
"execution_count": 46,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Collecting package metadata (current_repodata.json): done\n",
"Solving environment: done\n",
"\n",
"# All requested packages already installed.\n",
"\n",
"Collecting package metadata (current_repodata.json): done\n",
"Solving environment: failed with initial frozen solve. Retrying with flexible solve.\n",
"Collecting package metadata (repodata.json): done\n",
"Solving environment: done\n",
"\n",
"## Package Plan ##\n",
"\n",
" environment location: /home/jupyterlab/conda/envs/python\n",
"\n",
" added / updated specs:\n",
" - folium=0.5.0\n",
"\n",
"\n",
"The following packages will be downloaded:\n",
"\n",
" package | build\n",
" ---------------------------|-----------------\n",
" altair-4.1.0 | py_1 614 KB conda-forge\n",
" branca-0.4.1 | py_0 26 KB conda-forge\n",
" folium-0.5.0 | py_0 45 KB conda-forge\n",
" pandas-1.0.4 | py36h830a2c2_0 10.1 MB conda-forge\n",
" toolz-0.10.0 | py_0 46 KB conda-forge\n",
" vincent-0.4.4 | py_1 28 KB conda-forge\n",
" ------------------------------------------------------------\n",
" Total: 10.9 MB\n",
"\n",
"The following NEW packages will be INSTALLED:\n",
"\n",
" altair conda-forge/noarch::altair-4.1.0-py_1\n",
" attrs conda-forge/noarch::attrs-19.3.0-py_0\n",
" branca conda-forge/noarch::branca-0.4.1-py_0\n",
" entrypoints conda-forge/linux-64::entrypoints-0.3-py36h9f0ad1d_1001\n",
" folium conda-forge/noarch::folium-0.5.0-py_0\n",
" importlib_metadata conda-forge/noarch::importlib_metadata-1.6.0-0\n",
" jinja2 conda-forge/noarch::jinja2-2.11.2-pyh9f0ad1d_0\n",
" jsonschema conda-forge/linux-64::jsonschema-3.2.0-py36h9f0ad1d_1\n",
" markupsafe conda-forge/linux-64::markupsafe-1.1.1-py36h8c4c3a4_1\n",
" pandas conda-forge/linux-64::pandas-1.0.4-py36h830a2c2_0\n",
" pyrsistent conda-forge/linux-64::pyrsistent-0.16.0-py36h8c4c3a4_0\n",
" pytz conda-forge/noarch::pytz-2020.1-pyh9f0ad1d_0\n",
" toolz conda-forge/noarch::toolz-0.10.0-py_0\n",
" vincent conda-forge/noarch::vincent-0.4.4-py_1\n",
"\n",
"\n",
"\n",
"Downloading and Extracting Packages\n",
"toolz-0.10.0 | 46 KB | ##################################### | 100% \n",
"folium-0.5.0 | 45 KB | ##################################### | 100% \n",
"altair-4.1.0 | 614 KB | ##################################### | 100% \n",
"branca-0.4.1 | 26 KB | ##################################### | 100% \n",
"pandas-1.0.4 | 10.1 MB | ##################################### | 100% \n",
"vincent-0.4.4 | 28 KB | ##################################### | 100% \n",
"Preparing transaction: done\n",
"Verifying transaction: done\n",
"Executing transaction: done\n",
"Libraries imported.\n"
]
}
],
"source": [
"!conda install -c conda-forge geopy --yes # uncomment this line if you haven't completed the Foursquare API lab\n",
"from geopy.geocoders import Nominatim # convert an address into latitude and longitude values\n",
"\n",
"import json # library to handle JSON files\n",
"\n",
"import requests # library to handle requests\n",
"from pandas import json_normalize # tranform JSON file into a pandas dataframe\n",
"\n",
"# Matplotlib and associated plotting modules\n",
"import matplotlib.cm as cm\n",
"import matplotlib.colors as colors\n",
"\n",
"# import k-means from clustering stage\n",
"from sklearn.cluster import KMeans\n",
"\n",
"!conda install -c conda-forge folium=0.5.0 --yes # uncomment this line if you haven't completed the Foursquare API lab\n",
"import folium # map rendering library\n",
"\n",
"print('Libraries imported.')"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### We obtain the coordinates for the British Columbia province using the geocoder package, as we did before in the data section.\n"
]
},
{
"cell_type": "code",
"execution_count": 47,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"The lat long values for British Columbia are: 55.001251, -125.002441\n"
]
}
],
"source": [
"address = 'British Columbia, CA'\n",
"\n",
"N_obj = Nominatim(user_agent='british_columbia_explorer')\n",
"geo_obj = N_obj.geocode(address)\n",
"lat = geo_obj.latitude\n",
"long = geo_obj.longitude\n",
"print(\"The lat long values for British Columbia are: {}, {}\".format(lat,long))"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Using the Folium library, we map the neighborhood coordinates onto the main British Columbia map.\n"
]
},
{
"cell_type": "code",
"execution_count": 95,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"55.001251 , -125.002441\n"
]
},
{
"data": {
"text/html": [
"<div style=\"width:100%;\"><div style=\"position:relative;width:100%;height:0;padding-bottom:60%;\"><span style=\"color:#565656\">Make this Notebook Trusted to load map: File -> Trust Notebook</span><iframe src=\"about:blank\" style=\"position:absolute;width:100%;height:100%;left:0;top:0;border:none !important;\" data-html=<!DOCTYPE html>
<head>    
    <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
    <script>L_PREFER_CANVAS = false; L_NO_TOUCH = false; L_DISABLE_3D = false;</script>
    <script src="https://cdn.jsdelivr.net/npm/leaflet@1.2.0/dist/leaflet.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.js"></script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/leaflet@1.2.0/dist/leaflet.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap-theme.min.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.6.3/css/font-awesome.min.css"/>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.css"/>
    <link rel="stylesheet" href="https://rawgit.com/python-visualization/folium/master/folium/templates/leaflet.awesome.rotate.css"/>
    <style>html, body {width: 100%;height: 100%;margin: 0;padding: 0;}</style>
    <style>#map {position:absolute;top:0;bottom:0;right:0;left:0;}</style>
    
            <style> #map_5e4b7a0b59764cc9a95b853d956cc498 {
                position : relative;
                width : 100.0%;
                height: 100.0%;
                left: 0.0%;
                top: 0.0%;
                }
            </style>
        
</head>
<body>    
    
            <div class="folium-map" id="map_5e4b7a0b59764cc9a95b853d956cc498" ></div>
        
</body>
<script>    
    

            
                var bounds = null;
            

            var map_5e4b7a0b59764cc9a95b853d956cc498 = L.map(
                                  'map_5e4b7a0b59764cc9a95b853d956cc498',
                                  {center: [55.001251,-125.002441],
                                  zoom: 5,
                                  maxBounds: bounds,
                                  layers: [],
                                  worldCopyJump: false,
                                  crs: L.CRS.EPSG3857
                                 });
            
        
    
            var tile_layer_fcae12acd35d49b0a2d69fed751e7ccf = L.tileLayer(
                'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',
                {
  "attribution": null,
  "detectRetina": false,
  "maxZoom": 18,
  "minZoom": 1,
  "noWrap": false,
  "subdomains": "abc"
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
        
    
            var circle_marker_79e38bb587d645c2b36f02941b23186c = L.circleMarker(
                [49.0625,-122.3125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_8f1876466724448f98129ad892e0f851 = L.popup({maxWidth: '300'});

            
                var html_9c2e42e3bc55407299b5f8913b22829c = $('<div id="html_9c2e42e3bc55407299b5f8913b22829c" style="width: 100.0%; height: 100.0%;">Abbotsford</div>')[0];
                popup_8f1876466724448f98129ad892e0f851.setContent(html_9c2e42e3bc55407299b5f8913b22829c);
            

            circle_marker_79e38bb587d645c2b36f02941b23186c.bindPopup(popup_8f1876466724448f98129ad892e0f851);

            
        
    
            var circle_marker_5c26018552b5419a92a7c5117a41805e = L.circleMarker(
                [59.625,-133.5],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_f7728937366d46ec9eea25c89677af1d = L.popup({maxWidth: '300'});

            
                var html_89b07579300b454095e33b80bdd595ba = $('<div id="html_89b07579300b454095e33b80bdd595ba" style="width: 100.0%; height: 100.0%;">Atlin Region</div>')[0];
                popup_f7728937366d46ec9eea25c89677af1d.setContent(html_89b07579300b454095e33b80bdd595ba);
            

            circle_marker_5c26018552b5419a92a7c5117a41805e.bindPopup(popup_f7728937366d46ec9eea25c89677af1d);

            
        
    
            var circle_marker_b75811db25264fdb9aae5b079b2c3607 = L.circleMarker(
                [49.25,-123.0],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_9d8a23460e4b424d85a0c89b211de276 = L.popup({maxWidth: '300'});

            
                var html_33d7878d5f364ab299fbf59e58be30f2 = $('<div id="html_33d7878d5f364ab299fbf59e58be30f2" style="width: 100.0%; height: 100.0%;">Burnaby</div>')[0];
                popup_9d8a23460e4b424d85a0c89b211de276.setContent(html_33d7878d5f364ab299fbf59e58be30f2);
            

            circle_marker_b75811db25264fdb9aae5b079b2c3607.bindPopup(popup_9d8a23460e4b424d85a0c89b211de276);

            
        
    
            var circle_marker_f300239f10694c3cae5559fabf42c203 = L.circleMarker(
                [50.0,-125.5625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_060338377b574a47b8f6ecac8c23fd77 = L.popup({maxWidth: '300'});

            
                var html_15cc4e0dc5cc4ce2a78ac39705277e85 = $('<div id="html_15cc4e0dc5cc4ce2a78ac39705277e85" style="width: 100.0%; height: 100.0%;">Campbell River Central</div>')[0];
                popup_060338377b574a47b8f6ecac8c23fd77.setContent(html_15cc4e0dc5cc4ce2a78ac39705277e85);
            

            circle_marker_f300239f10694c3cae5559fabf42c203.bindPopup(popup_060338377b574a47b8f6ecac8c23fd77);

            
        
    
            var circle_marker_b13649b9fc904e738fba370acc96d2a1 = L.circleMarker(
                [51.4375,-121.625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_7db420be6a244b31b6787332df5b6b45 = L.popup({maxWidth: '300'});

            
                var html_71c4cd518e894aa4bbcd14bd54429e67 = $('<div id="html_71c4cd518e894aa4bbcd14bd54429e67" style="width: 100.0%; height: 100.0%;">Cariboo and West Okanagan</div>')[0];
                popup_7db420be6a244b31b6787332df5b6b45.setContent(html_71c4cd518e894aa4bbcd14bd54429e67);
            

            circle_marker_b13649b9fc904e738fba370acc96d2a1.bindPopup(popup_7db420be6a244b31b6787332df5b6b45);

            
        
    
            var circle_marker_8b7f07c77c37488b928211f457ad9849 = L.circleMarker(
                [49.3125,-117.6875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_f0a21ae9e5364711a27748c659345a99 = L.popup({maxWidth: '300'});

            
                var html_5ca9dd5dd2094cc0965daa25ae9cbafd = $('<div id="html_5ca9dd5dd2094cc0965daa25ae9cbafd" style="width: 100.0%; height: 100.0%;">Castlegar</div>')[0];
                popup_f0a21ae9e5364711a27748c659345a99.setContent(html_5ca9dd5dd2094cc0965daa25ae9cbafd);
            

            circle_marker_8b7f07c77c37488b928211f457ad9849.bindPopup(popup_f0a21ae9e5364711a27748c659345a99);

            
        
    
            var circle_marker_eb9379ea3a294303b055f220cb5c0f08 = L.circleMarker(
                [49.03125,-124.0],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_0d20157dcd8b4fdebbfba78d340bcd4a = L.popup({maxWidth: '300'});

            
                var html_e93f870a92e64f8694645e5d7368573f = $('<div id="html_e93f870a92e64f8694645e5d7368573f" style="width: 100.0%; height: 100.0%;">Cedar</div>')[0];
                popup_0d20157dcd8b4fdebbfba78d340bcd4a.setContent(html_e93f870a92e64f8694645e5d7368573f);
            

            circle_marker_eb9379ea3a294303b055f220cb5c0f08.bindPopup(popup_0d20157dcd8b4fdebbfba78d340bcd4a);

            
        
    
            var circle_marker_614a13bcfc3c4823a84cce52b052348d = L.circleMarker(
                [49.6875,-122.5],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_4a90e0230a3646649cedf131038c9d14 = L.popup({maxWidth: '300'});

            
                var html_a607ccabad8c4a258bbbb62b82c8cc40 = $('<div id="html_a607ccabad8c4a258bbbb62b82c8cc40" style="width: 100.0%; height: 100.0%;">Central Island</div>')[0];
                popup_4a90e0230a3646649cedf131038c9d14.setContent(html_a607ccabad8c4a258bbbb62b82c8cc40);
            

            circle_marker_614a13bcfc3c4823a84cce52b052348d.bindPopup(popup_4a90e0230a3646649cedf131038c9d14);

            
        
    
            var circle_marker_2e8303d86b6f41f0a538aaa7f94fb3b1 = L.circleMarker(
                [52.09375,-123.625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_dae513ceb2814ff2aef3ba784057cf7a = L.popup({maxWidth: '300'});

            
                var html_0b6e722ecdb24dbc997a248fc4058dab = $('<div id="html_0b6e722ecdb24dbc997a248fc4058dab" style="width: 100.0%; height: 100.0%;">Chilcotin</div>')[0];
                popup_dae513ceb2814ff2aef3ba784057cf7a.setContent(html_0b6e722ecdb24dbc997a248fc4058dab);
            

            circle_marker_2e8303d86b6f41f0a538aaa7f94fb3b1.bindPopup(popup_dae513ceb2814ff2aef3ba784057cf7a);

            
        
    
            var circle_marker_7ab021d526cd4f13a1dfb9d245812a1e = L.circleMarker(
                [49.125,-121.8125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_ba576040b1e74669b909ef8159bda00a = L.popup({maxWidth: '300'});

            
                var html_6e5d6bec15194e54a7f112ff226f21fc = $('<div id="html_6e5d6bec15194e54a7f112ff226f21fc" style="width: 100.0%; height: 100.0%;">Chilliwack Central</div>')[0];
                popup_ba576040b1e74669b909ef8159bda00a.setContent(html_6e5d6bec15194e54a7f112ff226f21fc);
            

            circle_marker_7ab021d526cd4f13a1dfb9d245812a1e.bindPopup(popup_ba576040b1e74669b909ef8159bda00a);

            
        
    
            var circle_marker_c7316f08b99f49298700af00f384fb3f = L.circleMarker(
                [49.6875,-124.9375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_fcc72adc8ae349b0b54a83198aaaba12 = L.popup({maxWidth: '300'});

            
                var html_aa63b2f89cf34ed69fa86864a2ce57ca = $('<div id="html_aa63b2f89cf34ed69fa86864a2ce57ca" style="width: 100.0%; height: 100.0%;">Comox</div>')[0];
                popup_fcc72adc8ae349b0b54a83198aaaba12.setContent(html_aa63b2f89cf34ed69fa86864a2ce57ca);
            

            circle_marker_c7316f08b99f49298700af00f384fb3f.bindPopup(popup_fcc72adc8ae349b0b54a83198aaaba12);

            
        
    
            var circle_marker_515c2cbf8b134a979495fed9769d363c = L.circleMarker(
                [49.25,-122.875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_3f27c2cbc2c64a3eb5adda6e374c5d61 = L.popup({maxWidth: '300'});

            
                var html_3fb04a6478224dd590057eb6c85f3b87 = $('<div id="html_3fb04a6478224dd590057eb6c85f3b87" style="width: 100.0%; height: 100.0%;">Coquitlam</div>')[0];
                popup_3f27c2cbc2c64a3eb5adda6e374c5d61.setContent(html_3fb04a6478224dd590057eb6c85f3b87);
            

            circle_marker_515c2cbf8b134a979495fed9769d363c.bindPopup(popup_3f27c2cbc2c64a3eb5adda6e374c5d61);

            
        
    
            var circle_marker_3def17471bfb483cbdf611172f1433e6 = L.circleMarker(
                [49.6875,-125.125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_a809ebe572cc44eb93adcf4a74c54222 = L.popup({maxWidth: '300'});

            
                var html_95779f9382e5406396b3329efd12ff28 = $('<div id="html_95779f9382e5406396b3329efd12ff28" style="width: 100.0%; height: 100.0%;">Courtenay Central</div>')[0];
                popup_a809ebe572cc44eb93adcf4a74c54222.setContent(html_95779f9382e5406396b3329efd12ff28);
            

            circle_marker_3def17471bfb483cbdf611172f1433e6.bindPopup(popup_a809ebe572cc44eb93adcf4a74c54222);

            
        
    
            var circle_marker_b914780a309d4919b3cae5c34a3c35fb = L.circleMarker(
                [49.5,-115.75],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_81c1f3469f3746ab8374dccfe07270eb = L.popup({maxWidth: '300'});

            
                var html_b6966fa2c635400d8e4a32c24e92413b = $('<div id="html_b6966fa2c635400d8e4a32c24e92413b" style="width: 100.0%; height: 100.0%;">Cranbrook</div>')[0];
                popup_81c1f3469f3746ab8374dccfe07270eb.setContent(html_b6966fa2c635400d8e4a32c24e92413b);
            

            circle_marker_b914780a309d4919b3cae5c34a3c35fb.bindPopup(popup_81c1f3469f3746ab8374dccfe07270eb);

            
        
    
            var circle_marker_a5bd3d701e344feca3af2a8bcbe3e6b2 = L.circleMarker(
                [55.78125,-120.25],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_9d1d2b4e059d4b8c8568b38330bbc171 = L.popup({maxWidth: '300'});

            
                var html_ece580b8348244a9ba1b4e8a062ce43f = $('<div id="html_ece580b8348244a9ba1b4e8a062ce43f" style="width: 100.0%; height: 100.0%;">Dawson Creek</div>')[0];
                popup_9d1d2b4e059d4b8c8568b38330bbc171.setContent(html_ece580b8348244a9ba1b4e8a062ce43f);
            

            circle_marker_a5bd3d701e344feca3af2a8bcbe3e6b2.bindPopup(popup_9d1d2b4e059d4b8c8568b38330bbc171);

            
        
    
            var circle_marker_7a3ab858f4aa4ee182f2db96e1c66d6b = L.circleMarker(
                [49.09375,-123.0],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_0e5df52548a049dd8c7afb2d3122e781 = L.popup({maxWidth: '300'});

            
                var html_08fa31e03db443c393e20d6e576b8994 = $('<div id="html_08fa31e03db443c393e20d6e576b8994" style="width: 100.0%; height: 100.0%;">Delta Central</div>')[0];
                popup_0e5df52548a049dd8c7afb2d3122e781.setContent(html_08fa31e03db443c393e20d6e576b8994);
            

            circle_marker_7a3ab858f4aa4ee182f2db96e1c66d6b.bindPopup(popup_0e5df52548a049dd8c7afb2d3122e781);

            
        
    
            var circle_marker_e85f9a0b391747ac9b4a4328b89f3f78 = L.circleMarker(
                [48.78125,-123.6875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_2c63394c4d514683901acc17f07ea588 = L.popup({maxWidth: '300'});

            
                var html_cfdfdedd6ead4060a2ba48e6bd5b3a48 = $('<div id="html_cfdfdedd6ead4060a2ba48e6bd5b3a48" style="width: 100.0%; height: 100.0%;">Duncan</div>')[0];
                popup_2c63394c4d514683901acc17f07ea588.setContent(html_cfdfdedd6ead4060a2ba48e6bd5b3a48);
            

            circle_marker_e85f9a0b391747ac9b4a4328b89f3f78.bindPopup(popup_2c63394c4d514683901acc17f07ea588);

            
        
    
            var circle_marker_2fe07a9398334ecfa4df2ab383c00ed0 = L.circleMarker(
                [49.6875,-115.5625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_61c01f19c5384e47ae8f3ddf73784e32 = L.popup({maxWidth: '300'});

            
                var html_ee656b2a3cd3446598b4a95d4e09067d = $('<div id="html_ee656b2a3cd3446598b4a95d4e09067d" style="width: 100.0%; height: 100.0%;">East Kootenays</div>')[0];
                popup_61c01f19c5384e47ae8f3ddf73784e32.setContent(html_ee656b2a3cd3446598b4a95d4e09067d);
            

            circle_marker_2fe07a9398334ecfa4df2ab383c00ed0.bindPopup(popup_61c01f19c5384e47ae8f3ddf73784e32);

            
        
    
            var circle_marker_82c62e45a1e94d559841a9a48893c98f = L.circleMarker(
                [48.4375,-123.4375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_8b5dac1a4af14e6ca521468a0fee6db9 = L.popup({maxWidth: '300'});

            
                var html_66c115341a7e4df9a4ffdca9c9218430 = $('<div id="html_66c115341a7e4df9a4ffdca9c9218430" style="width: 100.0%; height: 100.0%;">Esquimalt</div>')[0];
                popup_8b5dac1a4af14e6ca521468a0fee6db9.setContent(html_66c115341a7e4df9a4ffdca9c9218430);
            

            circle_marker_82c62e45a1e94d559841a9a48893c98f.bindPopup(popup_8b5dac1a4af14e6ca521468a0fee6db9);

            
        
    
            var circle_marker_aa160c5f318b439fa4d7d0890fb9988c = L.circleMarker(
                [56.25,-120.875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_caf625ca64164b37b1ee1f56a05018c2 = L.popup({maxWidth: '300'});

            
                var html_d812fb68980e482da64c92d7adb39584 = $('<div id="html_d812fb68980e482da64c92d7adb39584" style="width: 100.0%; height: 100.0%;">Fort St. John</div>')[0];
                popup_caf625ca64164b37b1ee1f56a05018c2.setContent(html_d812fb68980e482da64c92d7adb39584);
            

            circle_marker_aa160c5f318b439fa4d7d0890fb9988c.bindPopup(popup_caf625ca64164b37b1ee1f56a05018c2);

            
        
    
            var circle_marker_86417c2eb35347b4a676ae6117643e6c = L.circleMarker(
                [49.625,-122.0625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_a4626b695f0d4237b978d58d66b8aaad = L.popup({maxWidth: '300'});

            
                var html_450546efe6414b94aacf68d3fb9b5f54 = $('<div id="html_450546efe6414b94aacf68d3fb9b5f54" style="width: 100.0%; height: 100.0%;">Harrison Lake Region</div>')[0];
                popup_a4626b695f0d4237b978d58d66b8aaad.setContent(html_450546efe6414b94aacf68d3fb9b5f54);
            

            circle_marker_86417c2eb35347b4a676ae6117643e6c.bindPopup(popup_a4626b695f0d4237b978d58d66b8aaad);

            
        
    
            var circle_marker_c7b5cebb9b0b44aaafb55b5d9355c82e = L.circleMarker(
                [48.46875,-123.5],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_d7e0938ec46b4dfa900cbd1ab2df35fa = L.popup({maxWidth: '300'});

            
                var html_61f1a4fd58084e9fbeb6f3dbc4bf14d3 = $('<div id="html_61f1a4fd58084e9fbeb6f3dbc4bf14d3" style="width: 100.0%; height: 100.0%;">Highlands</div>')[0];
                popup_d7e0938ec46b4dfa900cbd1ab2df35fa.setContent(html_61f1a4fd58084e9fbeb6f3dbc4bf14d3);
            

            circle_marker_c7b5cebb9b0b44aaafb55b5d9355c82e.bindPopup(popup_d7e0938ec46b4dfa900cbd1ab2df35fa);

            
        
    
            var circle_marker_9308b2846d034e2c8f2ca0ddded64d73 = L.circleMarker(
                [52.21875,-126.1875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_00f8405224d24718a0d762274a49bc2c = L.popup({maxWidth: '300'});

            
                var html_f7bc9473aa544573a25789cdb17ae84c = $('<div id="html_f7bc9473aa544573a25789cdb17ae84c" style="width: 100.0%; height: 100.0%;">Inside Passage and the Queen Charlottes</div>')[0];
                popup_00f8405224d24718a0d762274a49bc2c.setContent(html_f7bc9473aa544573a25789cdb17ae84c);
            

            circle_marker_9308b2846d034e2c8f2ca0ddded64d73.bindPopup(popup_00f8405224d24718a0d762274a49bc2c);

            
        
    
            var circle_marker_f8d3054663e840b4969f71d0fbf09126 = L.circleMarker(
                [48.53125,-123.6875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_f88ce489b1c54960b3b0df1c02c9154c = L.popup({maxWidth: '300'});

            
                var html_75e5ac0ac25e497f8f6aaccac32f9812 = $('<div id="html_75e5ac0ac25e497f8f6aaccac32f9812" style="width: 100.0%; height: 100.0%;">Juan de Fuca Shore</div>')[0];
                popup_f88ce489b1c54960b3b0df1c02c9154c.setContent(html_75e5ac0ac25e497f8f6aaccac32f9812);
            

            circle_marker_f8d3054663e840b4969f71d0fbf09126.bindPopup(popup_f88ce489b1c54960b3b0df1c02c9154c);

            
        
    
            var circle_marker_4df1d74c70ba4824978085249795b28d = L.circleMarker(
                [50.6875,-120.4375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_d0239b3ce8074a9faf5cd4828dd86bf9 = L.popup({maxWidth: '300'});

            
                var html_f2c16dcb0a5d4359a927d0d4d6b8074e = $('<div id="html_f2c16dcb0a5d4359a927d0d4d6b8074e" style="width: 100.0%; height: 100.0%;">Kamloops Central and</div>')[0];
                popup_d0239b3ce8074a9faf5cd4828dd86bf9.setContent(html_f2c16dcb0a5d4359a927d0d4d6b8074e);
            

            circle_marker_4df1d74c70ba4824978085249795b28d.bindPopup(popup_d0239b3ce8074a9faf5cd4828dd86bf9);

            
        
    
            var circle_marker_ff8799dea3434066bb2994352c3de47e = L.circleMarker(
                [49.90625,-119.4375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_f266538f8ad94ff3a0b1a85ed9228ed1 = L.popup({maxWidth: '300'});

            
                var html_295d79eeac6f4eefab2acd856b99a9d9 = $('<div id="html_295d79eeac6f4eefab2acd856b99a9d9" style="width: 100.0%; height: 100.0%;">Kelowna Central</div>')[0];
                popup_f266538f8ad94ff3a0b1a85ed9228ed1.setContent(html_295d79eeac6f4eefab2acd856b99a9d9);
            

            circle_marker_ff8799dea3434066bb2994352c3de47e.bindPopup(popup_f266538f8ad94ff3a0b1a85ed9228ed1);

            
        
    
            var circle_marker_f82ac10946214fdfba3ba48d6b856b3f = L.circleMarker(
                [49.6875,-116.0],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_3d69cfa020544541920dead7013e78df = L.popup({maxWidth: '300'});

            
                var html_fc1374c7619d40d4ac14ed22e6f511ea = $('<div id="html_fc1374c7619d40d4ac14ed22e6f511ea" style="width: 100.0%; height: 100.0%;">Kimberley</div>')[0];
                popup_3d69cfa020544541920dead7013e78df.setContent(html_fc1374c7619d40d4ac14ed22e6f511ea);
            

            circle_marker_f82ac10946214fdfba3ba48d6b856b3f.bindPopup(popup_3d69cfa020544541920dead7013e78df);

            
        
    
            var circle_marker_7cdb283fa9cd4b70af9c435e400b38aa = L.circleMarker(
                [54.0625,-128.625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_af93995ff936452392bba6515fd4c0d9 = L.popup({maxWidth: '300'});

            
                var html_ccf70723a40a40d9a71d3eeab8ba4687 = $('<div id="html_ccf70723a40a40d9a71d3eeab8ba4687" style="width: 100.0%; height: 100.0%;">Kitimat</div>')[0];
                popup_af93995ff936452392bba6515fd4c0d9.setContent(html_ccf70723a40a40d9a71d3eeab8ba4687);
            

            circle_marker_7cdb283fa9cd4b70af9c435e400b38aa.bindPopup(popup_af93995ff936452392bba6515fd4c0d9);

            
        
    
            var circle_marker_9c333c0588ff4057a73b3e93fb8c54bd = L.circleMarker(
                [48.96875,-123.8125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_bc0e4695e3b146aa80cd6abb79b22f6b = L.popup({maxWidth: '300'});

            
                var html_a7639df7f4444c4f895db4d78285079d = $('<div id="html_a7639df7f4444c4f895db4d78285079d" style="width: 100.0%; height: 100.0%;">Ladysmith</div>')[0];
                popup_bc0e4695e3b146aa80cd6abb79b22f6b.setContent(html_a7639df7f4444c4f895db4d78285079d);
            

            circle_marker_9c333c0588ff4057a73b3e93fb8c54bd.bindPopup(popup_bc0e4695e3b146aa80cd6abb79b22f6b);

            
        
    
            var circle_marker_9faa83ad80db4e87b4b649d4af00fd1e = L.circleMarker(
                [49.09375,-122.5625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_74c9b45293204f229286f8302bf0771e = L.popup({maxWidth: '300'});

            
                var html_75158daa39de445299774bebf3983ff1 = $('<div id="html_75158daa39de445299774bebf3983ff1" style="width: 100.0%; height: 100.0%;">Langley City</div>')[0];
                popup_74c9b45293204f229286f8302bf0771e.setContent(html_75158daa39de445299774bebf3983ff1);
            

            circle_marker_9faa83ad80db4e87b4b649d4af00fd1e.bindPopup(popup_74c9b45293204f229286f8302bf0771e);

            
        
    
            var circle_marker_9fe9cddbe2ee4b1290fe7e905ed02386 = L.circleMarker(
                [53.96875,-129.875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_d001c499159841bc8b2e702bbb2a36d5 = L.popup({maxWidth: '300'});

            
                var html_3121da3f0afb4171a4f64d45a9956394 = $('<div id="html_3121da3f0afb4171a4f64d45a9956394" style="width: 100.0%; height: 100.0%;">Lower Skeena</div>')[0];
                popup_d001c499159841bc8b2e702bbb2a36d5.setContent(html_3121da3f0afb4171a4f64d45a9956394);
            

            circle_marker_9fe9cddbe2ee4b1290fe7e905ed02386.bindPopup(popup_d001c499159841bc8b2e702bbb2a36d5);

            
        
    
            var circle_marker_1b6a98e5cb8d44b8b8de95707e2c5438 = L.circleMarker(
                [49.25,-122.5625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_32a94bbd51204a5f984adce06015fdf5 = L.popup({maxWidth: '300'});

            
                var html_108bf89dc5f8446aba84da584235fd22 = $('<div id="html_108bf89dc5f8446aba84da584235fd22" style="width: 100.0%; height: 100.0%;">Maple Ridge</div>')[0];
                popup_32a94bbd51204a5f984adce06015fdf5.setContent(html_108bf89dc5f8446aba84da584235fd22);
            

            circle_marker_1b6a98e5cb8d44b8b8de95707e2c5438.bindPopup(popup_32a94bbd51204a5f984adce06015fdf5);

            
        
    
            var circle_marker_01670b836ef941739a7a5869f36e7770 = L.circleMarker(
                [50.125,-120.8125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_781c5e975e714a2fb4a6097f63a151c5 = L.popup({maxWidth: '300'});

            
                var html_6c103b45aaff480e9a75bb38173e1773 = $('<div id="html_6c103b45aaff480e9a75bb38173e1773" style="width: 100.0%; height: 100.0%;">Merritt</div>')[0];
                popup_781c5e975e714a2fb4a6097f63a151c5.setContent(html_6c103b45aaff480e9a75bb38173e1773);
            

            circle_marker_01670b836ef941739a7a5869f36e7770.bindPopup(popup_781c5e975e714a2fb4a6097f63a151c5);

            
        
    
            var circle_marker_9aed3adb514b41c8a2c9b8a5ccba35af = L.circleMarker(
                [48.375,-123.5625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_306d78e125b142f5994b635a5fe444ae = L.popup({maxWidth: '300'});

            
                var html_8fca2e2af0ac4dd19d31e78c49930833 = $('<div id="html_8fca2e2af0ac4dd19d31e78c49930833" style="width: 100.0%; height: 100.0%;">Metchosin</div>')[0];
                popup_306d78e125b142f5994b635a5fe444ae.setContent(html_8fca2e2af0ac4dd19d31e78c49930833);
            

            circle_marker_9aed3adb514b41c8a2c9b8a5ccba35af.bindPopup(popup_306d78e125b142f5994b635a5fe444ae);

            
        
    
            var circle_marker_e34277e8a5be43f98e75d3ab136bfd33 = L.circleMarker(
                [49.4375,-122.4375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_ed991336acb3402cac1b59c51546c422 = L.popup({maxWidth: '300'});

            
                var html_ad21484cf1be4598ab1fa05667a368d7 = $('<div id="html_ad21484cf1be4598ab1fa05667a368d7" style="width: 100.0%; height: 100.0%;">Mission</div>')[0];
                popup_ed991336acb3402cac1b59c51546c422.setContent(html_ad21484cf1be4598ab1fa05667a368d7);
            

            circle_marker_e34277e8a5be43f98e75d3ab136bfd33.bindPopup(popup_ed991336acb3402cac1b59c51546c422);

            
        
    
            var circle_marker_9d09cb08d9294ccaacfd0c311e27774a = L.circleMarker(
                [49.1875,-124.0],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_654875259c264efd85888d51d0988492 = L.popup({maxWidth: '300'});

            
                var html_5f7b7101827f49a5a9433d66320999cd = $('<div id="html_5f7b7101827f49a5a9433d66320999cd" style="width: 100.0%; height: 100.0%;">Nanaimo Central</div>')[0];
                popup_654875259c264efd85888d51d0988492.setContent(html_5f7b7101827f49a5a9433d66320999cd);
            

            circle_marker_9d09cb08d9294ccaacfd0c311e27774a.bindPopup(popup_654875259c264efd85888d51d0988492);

            
        
    
            var circle_marker_915dbe99133841dbb4946c9469b7081d = L.circleMarker(
                [49.5,-117.3125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_e015236387dc4042838489f2c1a82655 = L.popup({maxWidth: '300'});

            
                var html_8fb15abd6b9d41d5b3a1beac999a951f = $('<div id="html_8fb15abd6b9d41d5b3a1beac999a951f" style="width: 100.0%; height: 100.0%;">Nelson</div>')[0];
                popup_e015236387dc4042838489f2c1a82655.setContent(html_8fb15abd6b9d41d5b3a1beac999a951f);
            

            circle_marker_915dbe99133841dbb4946c9469b7081d.bindPopup(popup_e015236387dc4042838489f2c1a82655);

            
        
    
            var circle_marker_f789599a986d4bdca684f87bee7295b6 = L.circleMarker(
                [49.1875,-122.875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_fd3a2193868148d1bac079f9ff67d5b1 = L.popup({maxWidth: '300'});

            
                var html_bd78cfdf592445ab8a87a74da488ddc6 = $('<div id="html_bd78cfdf592445ab8a87a74da488ddc6" style="width: 100.0%; height: 100.0%;">New Westminster Northeast</div>')[0];
                popup_fd3a2193868148d1bac079f9ff67d5b1.setContent(html_bd78cfdf592445ab8a87a74da488ddc6);
            

            circle_marker_f789599a986d4bdca684f87bee7295b6.bindPopup(popup_fd3a2193868148d1bac079f9ff67d5b1);

            
        
    
            var circle_marker_772a1e9dae314956b6f5de992cedf257 = L.circleMarker(
                [49.5625,-123.625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_d82d3361949b4ea0bfa0ad48266055e4 = L.popup({maxWidth: '300'});

            
                var html_9284a925f4ae4672ab1be24d9f1801b9 = $('<div id="html_9284a925f4ae4672ab1be24d9f1801b9" style="width: 100.0%; height: 100.0%;">North Central Island and Bute Inlet Region</div>')[0];
                popup_d82d3361949b4ea0bfa0ad48266055e4.setContent(html_9284a925f4ae4672ab1be24d9f1801b9);
            

            circle_marker_772a1e9dae314956b6f5de992cedf257.bindPopup(popup_d82d3361949b4ea0bfa0ad48266055e4);

            
        
    
            var circle_marker_e58f2c601adf4b4f9eb072e4cd140888 = L.circleMarker(
                [58.375,-125.6875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_d33d0c843ba14adaac811d853387d1f7 = L.popup({maxWidth: '300'});

            
                var html_9152a135fed446d885d8392af54d90b2 = $('<div id="html_9152a135fed446d885d8392af54d90b2" style="width: 100.0%; height: 100.0%;">Northern British Columbia</div>')[0];
                popup_d33d0c843ba14adaac811d853387d1f7.setContent(html_9152a135fed446d885d8392af54d90b2);
            

            circle_marker_e58f2c601adf4b4f9eb072e4cd140888.bindPopup(popup_d33d0c843ba14adaac811d853387d1f7);

            
        
    
            var circle_marker_d3cb45baa5fb4d8b8537387f720841f6 = L.circleMarker(
                [48.4375,-123.3125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_c59cf327b5cb4864b2a258c79ad03588 = L.popup({maxWidth: '300'});

            
                var html_37b2d48539ab476bb5932f0b8897347d = $('<div id="html_37b2d48539ab476bb5932f0b8897347d" style="width: 100.0%; height: 100.0%;">Oak Bay</div>')[0];
                popup_c59cf327b5cb4864b2a258c79ad03588.setContent(html_37b2d48539ab476bb5932f0b8897347d);
            

            circle_marker_d3cb45baa5fb4d8b8537387f720841f6.bindPopup(popup_c59cf327b5cb4864b2a258c79ad03588);

            
        
    
            var circle_marker_de9fc97d90fe4825b3ed13fbab18087f = L.circleMarker(
                [56.0,-126.875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_e4e91b051cdd4a20b2e2f153d50b1383 = L.popup({maxWidth: '300'});

            
                var html_1621c45aa6644683aac47a7402efbadf = $('<div id="html_1621c45aa6644683aac47a7402efbadf" style="width: 100.0%; height: 100.0%;">Omineca and Yellowhead</div>')[0];
                popup_e4e91b051cdd4a20b2e2f153d50b1383.setContent(html_1621c45aa6644683aac47a7402efbadf);
            

            circle_marker_de9fc97d90fe4825b3ed13fbab18087f.bindPopup(popup_e4e91b051cdd4a20b2e2f153d50b1383);

            
        
    
            var circle_marker_baa80b7cf0c84f55aba60cb5623fa369 = L.circleMarker(
                [49.3125,-124.3125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_dd830988e2fa4a3fb875f22f272b1089 = L.popup({maxWidth: '300'});

            
                var html_07e580de8f4a4f52a4341260bf2558fc = $('<div id="html_07e580de8f4a4f52a4341260bf2558fc" style="width: 100.0%; height: 100.0%;">Parksville</div>')[0];
                popup_dd830988e2fa4a3fb875f22f272b1089.setContent(html_07e580de8f4a4f52a4341260bf2558fc);
            

            circle_marker_baa80b7cf0c84f55aba60cb5623fa369.bindPopup(popup_dd830988e2fa4a3fb875f22f272b1089);

            
        
    
            var circle_marker_d2f8129b06f4416580ba60aeb0e460c1 = L.circleMarker(
                [49.46875,-119.5625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_16aebba82eb7435d9a3c9b7d9f1b52ad = L.popup({maxWidth: '300'});

            
                var html_14fd506643254110ab477c55bc9f0786 = $('<div id="html_14fd506643254110ab477c55bc9f0786" style="width: 100.0%; height: 100.0%;">Penticton</div>')[0];
                popup_16aebba82eb7435d9a3c9b7d9f1b52ad.setContent(html_14fd506643254110ab477c55bc9f0786);
            

            circle_marker_d2f8129b06f4416580ba60aeb0e460c1.bindPopup(popup_16aebba82eb7435d9a3c9b7d9f1b52ad);

            
        
    
            var circle_marker_a099ab9dc7344ab0b4c1bde42dbe45ac = L.circleMarker(
                [49.21875,-122.6875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_e11f68163ec34a29963c5c6ba3180857 = L.popup({maxWidth: '300'});

            
                var html_ac49d7d313314dc7bb32e4c6c6078280 = $('<div id="html_ac49d7d313314dc7bb32e4c6c6078280" style="width: 100.0%; height: 100.0%;">Pitt Meadows</div>')[0];
                popup_e11f68163ec34a29963c5c6ba3180857.setContent(html_ac49d7d313314dc7bb32e4c6c6078280);
            

            circle_marker_a099ab9dc7344ab0b4c1bde42dbe45ac.bindPopup(popup_e11f68163ec34a29963c5c6ba3180857);

            
        
    
            var circle_marker_ba84517f1eca4a4992811cd898d3bbd2 = L.circleMarker(
                [49.28125,-123.1875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_98f50d0df19e4bebadff4a700109d080 = L.popup({maxWidth: '300'});

            
                var html_fa48e1b95ace47209170e265078f95de = $('<div id="html_fa48e1b95ace47209170e265078f95de" style="width: 100.0%; height: 100.0%;">Port Alberni</div>')[0];
                popup_98f50d0df19e4bebadff4a700109d080.setContent(html_fa48e1b95ace47209170e265078f95de);
            

            circle_marker_ba84517f1eca4a4992811cd898d3bbd2.bindPopup(popup_98f50d0df19e4bebadff4a700109d080);

            
        
    
            var circle_marker_46c674ad639b4462bc9ae298c06001ff = L.circleMarker(
                [50.03125,-124.3125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_a0f004aa24124ee5b2cd41385d6abaa3 = L.popup({maxWidth: '300'});

            
                var html_aebebeb43bd84995bbac61d457b64c04 = $('<div id="html_aebebeb43bd84995bbac61d457b64c04" style="width: 100.0%; height: 100.0%;">Powell River</div>')[0];
                popup_a0f004aa24124ee5b2cd41385d6abaa3.setContent(html_aebebeb43bd84995bbac61d457b64c04);
            

            circle_marker_46c674ad639b4462bc9ae298c06001ff.bindPopup(popup_a0f004aa24124ee5b2cd41385d6abaa3);

            
        
    
            var circle_marker_f1db00d0b7d44aaca7df02be56839191 = L.circleMarker(
                [53.96875,-124.375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_7ae3d053ff6b4098ad9b0fe26e50f9d0 = L.popup({maxWidth: '300'});

            
                var html_a94f84168ffe42a280425d80209e6322 = $('<div id="html_a94f84168ffe42a280425d80209e6322" style="width: 100.0%; height: 100.0%;">Prince George Central</div>')[0];
                popup_7ae3d053ff6b4098ad9b0fe26e50f9d0.setContent(html_a94f84168ffe42a280425d80209e6322);
            

            circle_marker_f1db00d0b7d44aaca7df02be56839191.bindPopup(popup_7ae3d053ff6b4098ad9b0fe26e50f9d0);

            
        
    
            var circle_marker_7fbe5f63e8364d06bcc9a2471d103d0d = L.circleMarker(
                [49.34375,-124.4375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_d4ad737ca1904dc49e7a00f6875e6f01 = L.popup({maxWidth: '300'});

            
                var html_4559d5e14a634aeb81a5bd9017a09815 = $('<div id="html_4559d5e14a634aeb81a5bd9017a09815" style="width: 100.0%; height: 100.0%;">Qualicum Beach</div>')[0];
                popup_d4ad737ca1904dc49e7a00f6875e6f01.setContent(html_4559d5e14a634aeb81a5bd9017a09815);
            

            circle_marker_7fbe5f63e8364d06bcc9a2471d103d0d.bindPopup(popup_d4ad737ca1904dc49e7a00f6875e6f01);

            
        
    
            var circle_marker_1d44bce056624a758bc3756ccfe8e8f9 = L.circleMarker(
                [52.96875,-122.5],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_87b160f7e570410c96f96f3a8ff9316b = L.popup({maxWidth: '300'});

            
                var html_f7de773e3f08400cb11559850dbb05d0 = $('<div id="html_f7de773e3f08400cb11559850dbb05d0" style="width: 100.0%; height: 100.0%;">Quesnel</div>')[0];
                popup_87b160f7e570410c96f96f3a8ff9316b.setContent(html_f7de773e3f08400cb11559850dbb05d0);
            

            circle_marker_1d44bce056624a758bc3756ccfe8e8f9.bindPopup(popup_87b160f7e570410c96f96f3a8ff9316b);

            
        
    
            var circle_marker_ee33714fcb7b4076a7a5586de687ac41 = L.circleMarker(
                [49.15625,-123.125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_422064e24bd243209014f33c1a742a9c = L.popup({maxWidth: '300'});

            
                var html_724a06aa56b04f90868de4d446ef53e0 = $('<div id="html_724a06aa56b04f90868de4d446ef53e0" style="width: 100.0%; height: 100.0%;">Richmond</div>')[0];
                popup_422064e24bd243209014f33c1a742a9c.setContent(html_724a06aa56b04f90868de4d446ef53e0);
            

            circle_marker_ee33714fcb7b4076a7a5586de687ac41.bindPopup(popup_422064e24bd243209014f33c1a742a9c);

            
        
    
            var circle_marker_aa27b4bcd95b402d9c361413f7bf2958 = L.circleMarker(
                [48.5,-123.375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_899a041b2c65419c8ce2ca11b9739dc5 = L.popup({maxWidth: '300'});

            
                var html_12a81a9c60b249258d21fba5d6a0c815 = $('<div id="html_12a81a9c60b249258d21fba5d6a0c815" style="width: 100.0%; height: 100.0%;">Saanich Central</div>')[0];
                popup_899a041b2c65419c8ce2ca11b9739dc5.setContent(html_12a81a9c60b249258d21fba5d6a0c815);
            

            circle_marker_aa27b4bcd95b402d9c361413f7bf2958.bindPopup(popup_899a041b2c65419c8ce2ca11b9739dc5);

            
        
    
            var circle_marker_6a431f8dcd1944c497e67db9c92b1aed = L.circleMarker(
                [50.6875,-119.25],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_f36732c9efc24de2a211cbe10c0b4273 = L.popup({maxWidth: '300'});

            
                var html_10e891cc055d4f569ca2e1cfcde354c4 = $('<div id="html_10e891cc055d4f569ca2e1cfcde354c4" style="width: 100.0%; height: 100.0%;">Salmon Arm</div>')[0];
                popup_f36732c9efc24de2a211cbe10c0b4273.setContent(html_10e891cc055d4f569ca2e1cfcde354c4);
            

            circle_marker_6a431f8dcd1944c497e67db9c92b1aed.bindPopup(popup_f36732c9efc24de2a211cbe10c0b4273);

            
        
    
            var circle_marker_282e1ea6f8f24a56b09ebeda65f14f9c = L.circleMarker(
                [48.8125,-123.5],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_4f2fda33c67043169a337798dbf0c352 = L.popup({maxWidth: '300'});

            
                var html_0f94576f81724b9d80d849389315817c = $('<div id="html_0f94576f81724b9d80d849389315817c" style="width: 100.0%; height: 100.0%;">Saltspring Island</div>')[0];
                popup_4f2fda33c67043169a337798dbf0c352.setContent(html_0f94576f81724b9d80d849389315817c);
            

            circle_marker_282e1ea6f8f24a56b09ebeda65f14f9c.bindPopup(popup_4f2fda33c67043169a337798dbf0c352);

            
        
    
            var circle_marker_9f357e1d5f4e48129b1438a593ffa5f3 = L.circleMarker(
                [48.65625,-123.375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_43d639846f754ad9b422f6fbfeabc54e = L.popup({maxWidth: '300'});

            
                var html_00e61a197f014b938ddf62575e1a949a = $('<div id="html_00e61a197f014b938ddf62575e1a949a" style="width: 100.0%; height: 100.0%;">Sidney</div>')[0];
                popup_43d639846f754ad9b422f6fbfeabc54e.setContent(html_00e61a197f014b938ddf62575e1a949a);
            

            circle_marker_9f357e1d5f4e48129b1438a593ffa5f3.bindPopup(popup_43d639846f754ad9b422f6fbfeabc54e);

            
        
    
            var circle_marker_314e20db08364b6b9308ea124ccd228d = L.circleMarker(
                [49.375,-120.6875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_e0b540607fe9482c80618a9042ed7a49 = L.popup({maxWidth: '300'});

            
                var html_fa52b4b9acc942d399f7db8974a4f93d = $('<div id="html_fa52b4b9acc942d399f7db8974a4f93d" style="width: 100.0%; height: 100.0%;">Similkameen</div>')[0];
                popup_e0b540607fe9482c80618a9042ed7a49.setContent(html_fa52b4b9acc942d399f7db8974a4f93d);
            

            circle_marker_314e20db08364b6b9308ea124ccd228d.bindPopup(popup_e0b540607fe9482c80618a9042ed7a49);

            
        
    
            var circle_marker_8b4bbe0cf8b640cc9502dd2fe29c78e5 = L.circleMarker(
                [48.375,-123.75],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_fda36077743845c0b113f7c044712e8f = L.popup({maxWidth: '300'});

            
                var html_5259d0cb07634e11ab7da4ee19f907e2 = $('<div id="html_5259d0cb07634e11ab7da4ee19f907e2" style="width: 100.0%; height: 100.0%;">Sooke</div>')[0];
                popup_fda36077743845c0b113f7c044712e8f.setContent(html_5259d0cb07634e11ab7da4ee19f907e2);
            

            circle_marker_8b4bbe0cf8b640cc9502dd2fe29c78e5.bindPopup(popup_fda36077743845c0b113f7c044712e8f);

            
        
    
            var circle_marker_356217c33ab1416592ab5588cf4b6d1b = L.circleMarker(
                [49.40625,-119.0],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_ed053a32af4e4eaca7c76013ebe9c519 = L.popup({maxWidth: '300'});

            
                var html_aa7cfd78e3a441f697fb4c5476422417 = $('<div id="html_aa7cfd78e3a441f697fb4c5476422417" style="width: 100.0%; height: 100.0%;">South Okanagan</div>')[0];
                popup_ed053a32af4e4eaca7c76013ebe9c519.setContent(html_aa7cfd78e3a441f697fb4c5476422417);
            

            circle_marker_356217c33ab1416592ab5588cf4b6d1b.bindPopup(popup_ed053a32af4e4eaca7c76013ebe9c519);

            
        
    
            var circle_marker_b8bd7994abba427ba7a4efc0b794d0a1 = L.circleMarker(
                [49.6875,-123.125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_241bf631afca4a2c8e524c7b893746d9 = L.popup({maxWidth: '300'});

            
                var html_399b03c07b4643618efc5f4af26b90db = $('<div id="html_399b03c07b4643618efc5f4af26b90db" style="width: 100.0%; height: 100.0%;">Squamish</div>')[0];
                popup_241bf631afca4a2c8e524c7b893746d9.setContent(html_399b03c07b4643618efc5f4af26b90db);
            

            circle_marker_b8bd7994abba427ba7a4efc0b794d0a1.bindPopup(popup_241bf631afca4a2c8e524c7b893746d9);

            
        
    
            var circle_marker_5e7e8dd5744e4d8f91573d45fd9e3999 = L.circleMarker(
                [49.125,-122.8125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_5fef70c144ed47dfade342ad7bdf0006 = L.popup({maxWidth: '300'});

            
                var html_2bb5671ed3194c159767d9464487d6b4 = $('<div id="html_2bb5671ed3194c159767d9464487d6b4" style="width: 100.0%; height: 100.0%;">Surrey</div>')[0];
                popup_5fef70c144ed47dfade342ad7bdf0006.setContent(html_2bb5671ed3194c159767d9464487d6b4);
            

            circle_marker_5e7e8dd5744e4d8f91573d45fd9e3999.bindPopup(popup_5fef70c144ed47dfade342ad7bdf0006);

            
        
    
            var circle_marker_c7baea946d2e4a3d853f8cfc5d10a74d = L.circleMarker(
                [54.53125,-128.625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_0091fba412b64add8b1c527e5fd54d60 = L.popup({maxWidth: '300'});

            
                var html_e869dd094d234913bc6b8c863e71bd57 = $('<div id="html_e869dd094d234913bc6b8c863e71bd57" style="width: 100.0%; height: 100.0%;">Terrace</div>')[0];
                popup_0091fba412b64add8b1c527e5fd54d60.setContent(html_e869dd094d234913bc6b8c863e71bd57);
            

            circle_marker_c7baea946d2e4a3d853f8cfc5d10a74d.bindPopup(popup_0091fba412b64add8b1c527e5fd54d60);

            
        
    
            var circle_marker_c858b4e3135647539a10f17b96e8b2f1 = L.circleMarker(
                [49.09375,-117.6875],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_b20c78a414c5433f951f26b83403dcfc = L.popup({maxWidth: '300'});

            
                var html_41b2f859d43e495f9351d8b6974a618c = $('<div id="html_41b2f859d43e495f9351d8b6974a618c" style="width: 100.0%; height: 100.0%;">Trail</div>')[0];
                popup_b20c78a414c5433f951f26b83403dcfc.setContent(html_41b2f859d43e495f9351d8b6974a618c);
            

            circle_marker_c858b4e3135647539a10f17b96e8b2f1.bindPopup(popup_b20c78a414c5433f951f26b83403dcfc);

            
        
    
            var circle_marker_6e46e711f38d4343b9ca24fe37c69560 = L.circleMarker(
                [51.3125,-116.9375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_4eed102e0b2c4a018d2c36954544b695 = L.popup({maxWidth: '300'});

            
                var html_b25ead5ba1514fde98abdef723dc42db = $('<div id="html_b25ead5ba1514fde98abdef723dc42db" style="width: 100.0%; height: 100.0%;">Upper Columbia Region</div>')[0];
                popup_4eed102e0b2c4a018d2c36954544b695.setContent(html_b25ead5ba1514fde98abdef723dc42db);
            

            circle_marker_6e46e711f38d4343b9ca24fe37c69560.bindPopup(popup_4eed102e0b2c4a018d2c36954544b695);

            
        
    
            var circle_marker_53114465d30d4019904a4a062eaf423a = L.circleMarker(
                [49.25,-123.125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_e2431391c7554df3b640ff16a36d8ff3 = L.popup({maxWidth: '300'});

            
                var html_d8e2bd25f4e94c28ad56618beeb7617e = $('<div id="html_d8e2bd25f4e94c28ad56618beeb7617e" style="width: 100.0%; height: 100.0%;">Vancouver</div>')[0];
                popup_e2431391c7554df3b640ff16a36d8ff3.setContent(html_d8e2bd25f4e94c28ad56618beeb7617e);
            

            circle_marker_53114465d30d4019904a4a062eaf423a.bindPopup(popup_e2431391c7554df3b640ff16a36d8ff3);

            
        
    
            var circle_marker_960b1bfc648f4af6b0efd43827798ac9 = L.circleMarker(
                [50.21875,-119.25],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_c2809c71ba464ee5a07248f26626f678 = L.popup({maxWidth: '300'});

            
                var html_74eb6576e90b43dab5c4f7eaa236feae = $('<div id="html_74eb6576e90b43dab5c4f7eaa236feae" style="width: 100.0%; height: 100.0%;">Vernon Central</div>')[0];
                popup_c2809c71ba464ee5a07248f26626f678.setContent(html_74eb6576e90b43dab5c4f7eaa236feae);
            

            circle_marker_960b1bfc648f4af6b0efd43827798ac9.bindPopup(popup_c2809c71ba464ee5a07248f26626f678);

            
        
    
            var circle_marker_ff8ac929618f47428d1ef1cae0c89f7a = L.circleMarker(
                [48.4375,-123.375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_6a65952531b049a59ab5d5881adae1c9 = L.popup({maxWidth: '300'});

            
                var html_6884c8cd06114df2b6d13d4660f67b9f = $('<div id="html_6884c8cd06114df2b6d13d4660f67b9f" style="width: 100.0%; height: 100.0%;">Victoria Central British Columbia Provincial Government</div>')[0];
                popup_6a65952531b049a59ab5d5881adae1c9.setContent(html_6884c8cd06114df2b6d13d4660f67b9f);
            

            circle_marker_ff8ac929618f47428d1ef1cae0c89f7a.bindPopup(popup_6a65952531b049a59ab5d5881adae1c9);

            
        
    
            var circle_marker_bc1feba4535b43e78e7c6dbf479dcb70 = L.circleMarker(
                [49.5,-122.0625],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_389997ceffa447ff87e2b38d86add4d7 = L.popup({maxWidth: '300'});

            
                var html_fdc8264f0eba4a9caf56128a351c4049 = $('<div id="html_fdc8264f0eba4a9caf56128a351c4049" style="width: 100.0%; height: 100.0%;">West Kootenays</div>')[0];
                popup_389997ceffa447ff87e2b38d86add4d7.setContent(html_fdc8264f0eba4a9caf56128a351c4049);
            

            circle_marker_bc1feba4535b43e78e7c6dbf479dcb70.bindPopup(popup_389997ceffa447ff87e2b38d86add4d7);

            
        
    
            var circle_marker_88328334327d48598eed6a6bcd72059c = L.circleMarker(
                [49.875,-119.75],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_d3c072f241bd43b7aa02011a044b876e = L.popup({maxWidth: '300'});

            
                var html_5c8c8903c707490781c1e5d791ad545d = $('<div id="html_5c8c8903c707490781c1e5d791ad545d" style="width: 100.0%; height: 100.0%;">Westbank</div>')[0];
                popup_d3c072f241bd43b7aa02011a044b876e.setContent(html_5c8c8903c707490781c1e5d791ad545d);
            

            circle_marker_88328334327d48598eed6a6bcd72059c.bindPopup(popup_d3c072f241bd43b7aa02011a044b876e);

            
        
    
            var circle_marker_1c397740c43b4f7c9f0802ae7333464b = L.circleMarker(
                [50.125,-122.9375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_1974419d6aa743988891e87202ed5d03 = L.popup({maxWidth: '300'});

            
                var html_4ade1ab6a6e04e4b83893170228e61da = $('<div id="html_4ade1ab6a6e04e4b83893170228e61da" style="width: 100.0%; height: 100.0%;">Whistler</div>')[0];
                popup_1974419d6aa743988891e87202ed5d03.setContent(html_4ade1ab6a6e04e4b83893170228e61da);
            

            circle_marker_1c397740c43b4f7c9f0802ae7333464b.bindPopup(popup_1974419d6aa743988891e87202ed5d03);

            
        
    
            var circle_marker_16e940b9b5b847c4a0337dc37aa64fe1 = L.circleMarker(
                [49.03125,-122.8125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_6e50905cf53642ef98d05780a8a8ebb4 = L.popup({maxWidth: '300'});

            
                var html_a9143d5cce884c90baa38cff986d1d66 = $('<div id="html_a9143d5cce884c90baa38cff986d1d66" style="width: 100.0%; height: 100.0%;">White Rock</div>')[0];
                popup_6e50905cf53642ef98d05780a8a8ebb4.setContent(html_a9143d5cce884c90baa38cff986d1d66);
            

            circle_marker_16e940b9b5b847c4a0337dc37aa64fe1.bindPopup(popup_6e50905cf53642ef98d05780a8a8ebb4);

            
        
    
            var circle_marker_358e4782679749288a699470d694593d = L.circleMarker(
                [52.15625,-122.125],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_5065b6bdac984b88afb5083c1d9acf6c = L.popup({maxWidth: '300'});

            
                var html_0478d509bb1040758c60f94890bf164c = $('<div id="html_0478d509bb1040758c60f94890bf164c" style="width: 100.0%; height: 100.0%;">Williams Lake</div>')[0];
                popup_5065b6bdac984b88afb5083c1d9acf6c.setContent(html_0478d509bb1040758c60f94890bf164c);
            

            circle_marker_358e4782679749288a699470d694593d.bindPopup(popup_5065b6bdac984b88afb5083c1d9acf6c);

            
        
    
            var circle_marker_42bb3b75f1024d5cb966a03629d88298 = L.circleMarker(
                [50.03125,-119.375],
                {
  "bubblingMouseEvents": true,
  "color": "blue",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#3186cc",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_5e4b7a0b59764cc9a95b853d956cc498);
            
    
            var popup_fbdb29d11da146efab45df417a72cf82 = L.popup({maxWidth: '300'});

            
                var html_c9a5a859b034403ca8672648e2c51ff0 = $('<div id="html_c9a5a859b034403ca8672648e2c51ff0" style="width: 100.0%; height: 100.0%;">Winfield</div>')[0];
                popup_fbdb29d11da146efab45df417a72cf82.setContent(html_c9a5a859b034403ca8672648e2c51ff0);
            

            circle_marker_42bb3b75f1024d5cb966a03629d88298.bindPopup(popup_fbdb29d11da146efab45df417a72cf82);

            
        
</script> onload=\"this.contentDocument.open();this.contentDocument.write(atob(this.getAttribute('data-html')));this.contentDocument.close();\" allowfullscreen webkitallowfullscreen mozallowfullscreen></iframe></div></div>"
],
"text/plain": [
"<folium.folium.Map at 0x7fef7f14d550>"
]
},
"execution_count": 95,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"map_bc = folium.Map(location=[lat, long], zoom_start=5)\n",
"print(\"{} , {}\".format(lat,long))\n",
"for lati, lng, label in zip(df_new['Latitude'], df_new['Longitude'], df_new['Place']):\n",
" label = folium.Popup(label, parse_html=True)\n",
" folium.CircleMarker(\n",
" [lati, lng],\n",
" radius=5,\n",
" popup=label,\n",
" color='blue',\n",
" fill=True,\n",
" fill_color='#3186cc',\n",
" fill_opacity=0.7,\n",
" parse_html=False).add_to(map_bc)\n",
" \n",
"map_bc"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### We leverage the Foursquare API to explore the nearby locations of each neighborhood. To do so, we first define our Foursqaure credentials and version.\n"
]
},
{
"cell_type": "code",
"execution_count": 49,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Your credentails:\n",
"CLIENT_ID: QIQC42VYJTUBVEV1B0DBVBEFM4TR2YKVTUJOI21ELHIIIFLP\n",
"CLIENT_SECRET:ZXKAIHJSAPDYD1X5YUOJE0GIMO3C3O5DVG41FXGPT2JEUQCI\n"
]
}
],
"source": [
"CLIENT_ID = 'QIQC42VYJTUBVEV1B0DBVBEFM4TR2YKVTUJOI21ELHIIIFLP' # your Foursquare ID\n",
"CLIENT_SECRET = 'ZXKAIHJSAPDYD1X5YUOJE0GIMO3C3O5DVG41FXGPT2JEUQCI' # your Foursquare Secret\n",
"VERSION = '20180605' # Foursquare API version\n",
"\n",
"print('Your credentails:')\n",
"print('CLIENT_ID: ' + CLIENT_ID)\n",
"print('CLIENT_SECRET:' + CLIENT_SECRET)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### We also combine the entire process of creating the url request for each location, extracting the locations from the response file and storing them into a data frame, into a function named as 'getNearbyVenues'. \n"
]
},
{
"cell_type": "code",
"execution_count": 50,
"metadata": {},
"outputs": [],
"source": [
"def getNearbyVenues(names, latitudes, longitudes, radius=500, limit=150):\n",
" \n",
" venues_list=[]\n",
" for name, lat, lng in zip(names, latitudes, longitudes):\n",
" print(name)\n",
" \n",
" # create the API request URL\n",
" url = 'https://api.foursquare.com/v2/venues/explore?&client_id={}&client_secret={}&v={}&ll={},{}&radius={}&limit={}'.format(\n",
" CLIENT_ID, \n",
" CLIENT_SECRET, \n",
" VERSION, \n",
" lat, \n",
" lng, \n",
" radius, \n",
" limit)\n",
" \n",
" # make the GET request\n",
" results = requests.get(url).json()[\"response\"]['groups'][0]['items']\n",
" \n",
" # return only relevant information for each nearby venue\n",
" venues_list.append([(\n",
" name, \n",
" lat, \n",
" lng, \n",
" v['venue']['name'], \n",
" v['venue']['location']['lat'], \n",
" v['venue']['location']['lng'], \n",
" v['venue']['categories'][0]['name']) for v in results])\n",
"\n",
" #print(venues_list)\n",
" nearby_venues = pd.DataFrame([item for var in venues_list for item in var])\n",
" nearby_venues.columns = ['Neighborhood', \n",
" 'Neighborhood Latitude', \n",
" 'Neighborhood Longitude', \n",
" 'Venue', \n",
" 'Venue Latitude',\n",
" 'Venue Longitude', \n",
" 'Venue Category']\n",
" \n",
" return(nearby_venues)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Call the function using values from our data frame.\n"
]
},
{
"cell_type": "code",
"execution_count": 96,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"Abbotsford\n",
"Atlin Region\n",
"Burnaby\n",
"Campbell River Central\n",
"Cariboo and West Okanagan\n",
"Castlegar\n",
"Cedar\n",
"Central Island\n",
"Chilcotin\n",
"Chilliwack Central\n",
"Comox\n",
"Coquitlam\n",
"Courtenay Central\n",
"Cranbrook\n",
"Dawson Creek\n",
"Delta Central\n",
"Duncan\n",
"East Kootenays\n",
"Esquimalt\n",
"Fort St. John\n",
"Harrison Lake Region\n",
"Highlands\n",
"Inside Passage and the Queen Charlottes\n",
"Juan de Fuca Shore\n",
"Kamloops Central and\n",
"Kelowna Central\n",
"Kimberley\n",
"Kitimat\n",
"Ladysmith\n",
"Langley City\n",
"Lower Skeena\n",
"Maple Ridge\n",
"Merritt\n",
"Metchosin\n",
"Mission\n",
"Nanaimo Central\n",
"Nelson\n",
"New Westminster Northeast\n",
"North Central Island and Bute Inlet Region\n",
"Northern British Columbia\n",
"Oak Bay\n",
"Omineca and Yellowhead\n",
"Parksville\n",
"Penticton\n",
"Pitt Meadows\n",
"Port Alberni\n",
"Powell River\n",
"Prince George Central\n",
"Qualicum Beach\n",
"Quesnel\n",
"Richmond\n",
"Saanich Central\n",
"Salmon Arm\n",
"Saltspring Island\n",
"Sidney\n",
"Similkameen\n",
"Sooke\n",
"South Okanagan\n",
"Squamish\n",
"Surrey\n",
"Terrace\n",
"Trail\n",
"Upper Columbia Region\n",
"Vancouver\n",
"Vernon Central\n",
"Victoria Central British Columbia Provincial Government\n",
"West Kootenays\n",
"Westbank\n",
"Whistler\n",
"White Rock\n",
"Williams Lake\n",
"Winfield\n"
]
}
],
"source": [
"neighborhood_venues = getNearbyVenues(names=df_new['Place'],\n",
" latitudes=df_new['Latitude'],\n",
" longitudes=df_new['Longitude']\n",
" )"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Checking the size of the resulting data frame.\n"
]
},
{
"cell_type": "code",
"execution_count": 97,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(145, 7)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Neighborhood</th>\n",
" <th>Neighborhood Latitude</th>\n",
" <th>Neighborhood Longitude</th>\n",
" <th>Venue</th>\n",
" <th>Venue Latitude</th>\n",
" <th>Venue Longitude</th>\n",
" <th>Venue Category</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford</td>\n",
" <td>49.0625</td>\n",
" <td>-122.3125</td>\n",
" <td>Discovery Trail</td>\n",
" <td>49.060245</td>\n",
" <td>-122.315565</td>\n",
" <td>Trail</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Abbotsford</td>\n",
" <td>49.0625</td>\n",
" <td>-122.3125</td>\n",
" <td>Grandmas Market Gladwin Rd</td>\n",
" <td>49.066149</td>\n",
" <td>-122.313659</td>\n",
" <td>Grocery Store</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Burnaby</td>\n",
" <td>49.2500</td>\n",
" <td>-123.0000</td>\n",
" <td>BCITSA's Stand Central SE2</td>\n",
" <td>49.251424</td>\n",
" <td>-123.001384</td>\n",
" <td>Snack Place</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Burnaby</td>\n",
" <td>49.2500</td>\n",
" <td>-123.0000</td>\n",
" <td>BCIT Bookstore</td>\n",
" <td>49.251548</td>\n",
" <td>-123.001364</td>\n",
" <td>Bookstore</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Burnaby</td>\n",
" <td>49.2500</td>\n",
" <td>-123.0000</td>\n",
" <td>The Rix @ BCIT</td>\n",
" <td>49.251153</td>\n",
" <td>-123.000636</td>\n",
" <td>Coffee Shop</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Neighborhood Neighborhood Latitude Neighborhood Longitude \\\n",
"0 Abbotsford 49.0625 -122.3125 \n",
"1 Abbotsford 49.0625 -122.3125 \n",
"2 Burnaby 49.2500 -123.0000 \n",
"3 Burnaby 49.2500 -123.0000 \n",
"4 Burnaby 49.2500 -123.0000 \n",
"\n",
" Venue Venue Latitude Venue Longitude Venue Category \n",
"0 Discovery Trail 49.060245 -122.315565 Trail \n",
"1 Grandmas Market Gladwin Rd 49.066149 -122.313659 Grocery Store \n",
"2 BCITSA's Stand Central SE2 49.251424 -123.001384 Snack Place \n",
"3 BCIT Bookstore 49.251548 -123.001364 Bookstore \n",
"4 The Rix @ BCIT 49.251153 -123.000636 Coffee Shop "
]
},
"execution_count": 97,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"print(neighborhood_venues.shape)\n",
"neighborhood_venues.head()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Checking how many venues were returned for each neighborhood.\n"
]
},
{
"cell_type": "code",
"execution_count": 98,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Neighborhood Latitude</th>\n",
" <th>Neighborhood Longitude</th>\n",
" <th>Venue</th>\n",
" <th>Venue Latitude</th>\n",
" <th>Venue Longitude</th>\n",
" <th>Venue Category</th>\n",
" </tr>\n",
" <tr>\n",
" <th>Neighborhood</th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" <th></th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>Abbotsford</th>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Burnaby</th>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Comox</th>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Coquitlam</th>\n",
" <td>5</td>\n",
" <td>5</td>\n",
" <td>5</td>\n",
" <td>5</td>\n",
" <td>5</td>\n",
" <td>5</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Cranbrook</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Duncan</th>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Esquimalt</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Fort St. John</th>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Highlands</th>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Kelowna Central</th>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Kimberley</th>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Kitimat</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Langley City</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Nanaimo Central</th>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Nelson</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>New Westminster Northeast</th>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" <td>3</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Oak Bay</th>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Parksville</th>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Pitt Meadows</th>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" <td>6</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Qualicum Beach</th>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Richmond</th>\n",
" <td>27</td>\n",
" <td>27</td>\n",
" <td>27</td>\n",
" <td>27</td>\n",
" <td>27</td>\n",
" <td>27</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Saanich Central</th>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Salmon Arm</th>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Sooke</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>South Okanagan</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Surrey</th>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" <td>2</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Terrace</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Trail</th>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" <td>1</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Vancouver</th>\n",
" <td>20</td>\n",
" <td>20</td>\n",
" <td>20</td>\n",
" <td>20</td>\n",
" <td>20</td>\n",
" <td>20</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Victoria Central British Columbia Provincial Government</th>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" <td>9</td>\n",
" </tr>\n",
" <tr>\n",
" <th>Whistler</th>\n",
" <td>7</td>\n",
" <td>7</td>\n",
" <td>7</td>\n",
" <td>7</td>\n",
" <td>7</td>\n",
" <td>7</td>\n",
" </tr>\n",
" <tr>\n",
" <th>White Rock</th>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" <td>4</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Neighborhood Latitude \\\n",
"Neighborhood \n",
"Abbotsford 2 \n",
"Burnaby 9 \n",
"Comox 6 \n",
"Coquitlam 5 \n",
"Cranbrook 1 \n",
"Duncan 3 \n",
"Esquimalt 1 \n",
"Fort St. John 2 \n",
"Highlands 4 \n",
"Kelowna Central 2 \n",
"Kimberley 4 \n",
"Kitimat 1 \n",
"Langley City 1 \n",
"Nanaimo Central 2 \n",
"Nelson 1 \n",
"New Westminster Northeast 3 \n",
"Oak Bay 9 \n",
"Parksville 2 \n",
"Pitt Meadows 6 \n",
"Qualicum Beach 4 \n",
"Richmond 27 \n",
"Saanich Central 2 \n",
"Salmon Arm 2 \n",
"Sooke 1 \n",
"South Okanagan 1 \n",
"Surrey 2 \n",
"Terrace 1 \n",
"Trail 1 \n",
"Vancouver 20 \n",
"Victoria Central British Columbia Provincial Go... 9 \n",
"Whistler 7 \n",
"White Rock 4 \n",
"\n",
" Neighborhood Longitude \\\n",
"Neighborhood \n",
"Abbotsford 2 \n",
"Burnaby 9 \n",
"Comox 6 \n",
"Coquitlam 5 \n",
"Cranbrook 1 \n",
"Duncan 3 \n",
"Esquimalt 1 \n",
"Fort St. John 2 \n",
"Highlands 4 \n",
"Kelowna Central 2 \n",
"Kimberley 4 \n",
"Kitimat 1 \n",
"Langley City 1 \n",
"Nanaimo Central 2 \n",
"Nelson 1 \n",
"New Westminster Northeast 3 \n",
"Oak Bay 9 \n",
"Parksville 2 \n",
"Pitt Meadows 6 \n",
"Qualicum Beach 4 \n",
"Richmond 27 \n",
"Saanich Central 2 \n",
"Salmon Arm 2 \n",
"Sooke 1 \n",
"South Okanagan 1 \n",
"Surrey 2 \n",
"Terrace 1 \n",
"Trail 1 \n",
"Vancouver 20 \n",
"Victoria Central British Columbia Provincial Go... 9 \n",
"Whistler 7 \n",
"White Rock 4 \n",
"\n",
" Venue Venue Latitude \\\n",
"Neighborhood \n",
"Abbotsford 2 2 \n",
"Burnaby 9 9 \n",
"Comox 6 6 \n",
"Coquitlam 5 5 \n",
"Cranbrook 1 1 \n",
"Duncan 3 3 \n",
"Esquimalt 1 1 \n",
"Fort St. John 2 2 \n",
"Highlands 4 4 \n",
"Kelowna Central 2 2 \n",
"Kimberley 4 4 \n",
"Kitimat 1 1 \n",
"Langley City 1 1 \n",
"Nanaimo Central 2 2 \n",
"Nelson 1 1 \n",
"New Westminster Northeast 3 3 \n",
"Oak Bay 9 9 \n",
"Parksville 2 2 \n",
"Pitt Meadows 6 6 \n",
"Qualicum Beach 4 4 \n",
"Richmond 27 27 \n",
"Saanich Central 2 2 \n",
"Salmon Arm 2 2 \n",
"Sooke 1 1 \n",
"South Okanagan 1 1 \n",
"Surrey 2 2 \n",
"Terrace 1 1 \n",
"Trail 1 1 \n",
"Vancouver 20 20 \n",
"Victoria Central British Columbia Provincial Go... 9 9 \n",
"Whistler 7 7 \n",
"White Rock 4 4 \n",
"\n",
" Venue Longitude \\\n",
"Neighborhood \n",
"Abbotsford 2 \n",
"Burnaby 9 \n",
"Comox 6 \n",
"Coquitlam 5 \n",
"Cranbrook 1 \n",
"Duncan 3 \n",
"Esquimalt 1 \n",
"Fort St. John 2 \n",
"Highlands 4 \n",
"Kelowna Central 2 \n",
"Kimberley 4 \n",
"Kitimat 1 \n",
"Langley City 1 \n",
"Nanaimo Central 2 \n",
"Nelson 1 \n",
"New Westminster Northeast 3 \n",
"Oak Bay 9 \n",
"Parksville 2 \n",
"Pitt Meadows 6 \n",
"Qualicum Beach 4 \n",
"Richmond 27 \n",
"Saanich Central 2 \n",
"Salmon Arm 2 \n",
"Sooke 1 \n",
"South Okanagan 1 \n",
"Surrey 2 \n",
"Terrace 1 \n",
"Trail 1 \n",
"Vancouver 20 \n",
"Victoria Central British Columbia Provincial Go... 9 \n",
"Whistler 7 \n",
"White Rock 4 \n",
"\n",
" Venue Category \n",
"Neighborhood \n",
"Abbotsford 2 \n",
"Burnaby 9 \n",
"Comox 6 \n",
"Coquitlam 5 \n",
"Cranbrook 1 \n",
"Duncan 3 \n",
"Esquimalt 1 \n",
"Fort St. John 2 \n",
"Highlands 4 \n",
"Kelowna Central 2 \n",
"Kimberley 4 \n",
"Kitimat 1 \n",
"Langley City 1 \n",
"Nanaimo Central 2 \n",
"Nelson 1 \n",
"New Westminster Northeast 3 \n",
"Oak Bay 9 \n",
"Parksville 2 \n",
"Pitt Meadows 6 \n",
"Qualicum Beach 4 \n",
"Richmond 27 \n",
"Saanich Central 2 \n",
"Salmon Arm 2 \n",
"Sooke 1 \n",
"South Okanagan 1 \n",
"Surrey 2 \n",
"Terrace 1 \n",
"Trail 1 \n",
"Vancouver 20 \n",
"Victoria Central British Columbia Provincial Go... 9 \n",
"Whistler 7 \n",
"White Rock 4 "
]
},
"execution_count": 98,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"neighborhood_venues.groupby('Neighborhood').count()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Unique categories all over British Columbia.\n"
]
},
{
"cell_type": "code",
"execution_count": 99,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"There are 76 uniques categories.\n"
]
}
],
"source": [
"print('There are {} uniques categories.'.format(len(neighborhood_venues['Venue Category'].unique())))"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"\n",
"## Analyze each neighborhood <a name=\"analysis\"></a>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### We analyze the nearby locations of each neighborhood using the one hot encoding technique.\n"
]
},
{
"cell_type": "code",
"execution_count": 134,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(145, 76)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>American Restaurant</th>\n",
" <th>Asian Restaurant</th>\n",
" <th>Athletics &amp; Sports</th>\n",
" <th>Auto Workshop</th>\n",
" <th>Bakery</th>\n",
" <th>Bank</th>\n",
" <th>Baseball Field</th>\n",
" <th>Beach</th>\n",
" <th>Boat or Ferry</th>\n",
" <th>Bookstore</th>\n",
" <th>Breakfast Spot</th>\n",
" <th>Brewery</th>\n",
" <th>Bubble Tea Shop</th>\n",
" <th>Burger Joint</th>\n",
" <th>Bus Station</th>\n",
" <th>Bus Stop</th>\n",
" <th>Business Service</th>\n",
" <th>Café</th>\n",
" <th>Chinese Restaurant</th>\n",
" <th>Coffee Shop</th>\n",
" <th>Construction &amp; Landscaping</th>\n",
" <th>Convenience Store</th>\n",
" <th>Dessert Shop</th>\n",
" <th>Dim Sum Restaurant</th>\n",
" <th>Dog Run</th>\n",
" <th>Elementary School</th>\n",
" <th>Falafel Restaurant</th>\n",
" <th>Fast Food Restaurant</th>\n",
" <th>Fish &amp; Chips Shop</th>\n",
" <th>Fried Chicken Joint</th>\n",
" <th>Garden</th>\n",
" <th>Gas Station</th>\n",
" <th>Gastropub</th>\n",
" <th>Gift Shop</th>\n",
" <th>Golf Course</th>\n",
" <th>Greek Restaurant</th>\n",
" <th>Grocery Store</th>\n",
" <th>Gym</th>\n",
" <th>Gym / Fitness Center</th>\n",
" <th>Home Service</th>\n",
" <th>Hot Dog Joint</th>\n",
" <th>Hotel</th>\n",
" <th>Indian Restaurant</th>\n",
" <th>Juice Bar</th>\n",
" <th>Korean Restaurant</th>\n",
" <th>Lake</th>\n",
" <th>Liquor Store</th>\n",
" <th>Malay Restaurant</th>\n",
" <th>Men's Store</th>\n",
" <th>Motorcycle Shop</th>\n",
" <th>Mountain</th>\n",
" <th>Park</th>\n",
" <th>Pet Store</th>\n",
" <th>Pharmacy</th>\n",
" <th>Pizza Place</th>\n",
" <th>Playground</th>\n",
" <th>Plaza</th>\n",
" <th>Pub</th>\n",
" <th>Recreation Center</th>\n",
" <th>Restaurant</th>\n",
" <th>Salon / Barbershop</th>\n",
" <th>Sandwich Place</th>\n",
" <th>Shipping Store</th>\n",
" <th>Ski Area</th>\n",
" <th>Ski Lodge</th>\n",
" <th>Snack Place</th>\n",
" <th>Sporting Goods Shop</th>\n",
" <th>Sushi Restaurant</th>\n",
" <th>Theme Park</th>\n",
" <th>Tourist Information Center</th>\n",
" <th>Toy / Game Store</th>\n",
" <th>Trail</th>\n",
" <th>Vacation Rental</th>\n",
" <th>Vietnamese Restaurant</th>\n",
" <th>Wine Shop</th>\n",
" <th>Zoo</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" American Restaurant Asian Restaurant Athletics & Sports Auto Workshop \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Bakery Bank Baseball Field Beach Boat or Ferry Bookstore \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 1 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Breakfast Spot Brewery Bubble Tea Shop Burger Joint Bus Station \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Bus Stop Business Service Café Chinese Restaurant Coffee Shop \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 1 \n",
"\n",
" Construction & Landscaping Convenience Store Dessert Shop \\\n",
"0 0 0 0 \n",
"1 0 0 0 \n",
"2 0 0 0 \n",
"3 0 0 0 \n",
"4 0 0 0 \n",
"\n",
" Dim Sum Restaurant Dog Run Elementary School Falafel Restaurant \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Fast Food Restaurant Fish & Chips Shop Fried Chicken Joint Garden \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Gas Station Gastropub Gift Shop Golf Course Greek Restaurant \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Grocery Store Gym Gym / Fitness Center Home Service Hot Dog Joint \\\n",
"0 0 0 0 0 0 \n",
"1 1 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Hotel Indian Restaurant Juice Bar Korean Restaurant Lake Liquor Store \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Malay Restaurant Men's Store Motorcycle Shop Mountain Park Pet Store \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Pharmacy Pizza Place Playground Plaza Pub Recreation Center \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Restaurant Salon / Barbershop Sandwich Place Shipping Store Ski Area \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Ski Lodge Snack Place Sporting Goods Shop Sushi Restaurant Theme Park \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 1 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Tourist Information Center Toy / Game Store Trail Vacation Rental \\\n",
"0 0 0 1 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Vietnamese Restaurant Wine Shop Zoo \n",
"0 0 0 0 \n",
"1 0 0 0 \n",
"2 0 0 0 \n",
"3 0 0 0 \n",
"4 0 0 0 "
]
},
"execution_count": 134,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"one_hot = pd.get_dummies(neighborhood_venues[['Venue Category']], prefix=\"\", prefix_sep=\"\")\n",
"print(one_hot.shape)\n",
"one_hot.head()"
]
},
{
"cell_type": "code",
"execution_count": 135,
"metadata": {},
"outputs": [],
"source": [
"pd.set_option('display.max_columns', one_hot.shape[1]+1)"
]
},
{
"cell_type": "code",
"execution_count": 136,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>American Restaurant</th>\n",
" <th>Asian Restaurant</th>\n",
" <th>Athletics &amp; Sports</th>\n",
" <th>Auto Workshop</th>\n",
" <th>Bakery</th>\n",
" <th>Bank</th>\n",
" <th>Baseball Field</th>\n",
" <th>Beach</th>\n",
" <th>Boat or Ferry</th>\n",
" <th>Bookstore</th>\n",
" <th>Breakfast Spot</th>\n",
" <th>Brewery</th>\n",
" <th>Bubble Tea Shop</th>\n",
" <th>Burger Joint</th>\n",
" <th>Bus Station</th>\n",
" <th>Bus Stop</th>\n",
" <th>Business Service</th>\n",
" <th>Café</th>\n",
" <th>Chinese Restaurant</th>\n",
" <th>Coffee Shop</th>\n",
" <th>Construction &amp; Landscaping</th>\n",
" <th>Convenience Store</th>\n",
" <th>Dessert Shop</th>\n",
" <th>Dim Sum Restaurant</th>\n",
" <th>Dog Run</th>\n",
" <th>Elementary School</th>\n",
" <th>Falafel Restaurant</th>\n",
" <th>Fast Food Restaurant</th>\n",
" <th>Fish &amp; Chips Shop</th>\n",
" <th>Fried Chicken Joint</th>\n",
" <th>Garden</th>\n",
" <th>Gas Station</th>\n",
" <th>Gastropub</th>\n",
" <th>Gift Shop</th>\n",
" <th>Golf Course</th>\n",
" <th>Greek Restaurant</th>\n",
" <th>Grocery Store</th>\n",
" <th>Gym</th>\n",
" <th>Gym / Fitness Center</th>\n",
" <th>Home Service</th>\n",
" <th>Hot Dog Joint</th>\n",
" <th>Hotel</th>\n",
" <th>Indian Restaurant</th>\n",
" <th>Juice Bar</th>\n",
" <th>Korean Restaurant</th>\n",
" <th>Lake</th>\n",
" <th>Liquor Store</th>\n",
" <th>Malay Restaurant</th>\n",
" <th>Men's Store</th>\n",
" <th>Motorcycle Shop</th>\n",
" <th>Mountain</th>\n",
" <th>Park</th>\n",
" <th>Pet Store</th>\n",
" <th>Pharmacy</th>\n",
" <th>Pizza Place</th>\n",
" <th>Playground</th>\n",
" <th>Plaza</th>\n",
" <th>Pub</th>\n",
" <th>Recreation Center</th>\n",
" <th>Restaurant</th>\n",
" <th>Salon / Barbershop</th>\n",
" <th>Sandwich Place</th>\n",
" <th>Shipping Store</th>\n",
" <th>Ski Area</th>\n",
" <th>Ski Lodge</th>\n",
" <th>Snack Place</th>\n",
" <th>Sporting Goods Shop</th>\n",
" <th>Sushi Restaurant</th>\n",
" <th>Theme Park</th>\n",
" <th>Tourist Information Center</th>\n",
" <th>Toy / Game Store</th>\n",
" <th>Trail</th>\n",
" <th>Vacation Rental</th>\n",
" <th>Vietnamese Restaurant</th>\n",
" <th>Wine Shop</th>\n",
" <th>Zoo</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>...</th>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" <td>...</td>\n",
" </tr>\n",
" <tr>\n",
" <th>140</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>141</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>142</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>143</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>144</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"<p>145 rows × 76 columns</p>\n",
"</div>"
],
"text/plain": [
" American Restaurant Asian Restaurant Athletics & Sports Auto Workshop \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
".. ... ... ... ... \n",
"140 0 0 0 0 \n",
"141 0 0 0 0 \n",
"142 0 0 0 0 \n",
"143 0 0 0 0 \n",
"144 0 0 1 0 \n",
"\n",
" Bakery Bank Baseball Field Beach Boat or Ferry Bookstore \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 1 \n",
"4 0 0 0 0 0 0 \n",
".. ... ... ... ... ... ... \n",
"140 0 0 0 0 0 0 \n",
"141 0 0 0 0 0 0 \n",
"142 0 0 0 0 0 0 \n",
"143 0 0 0 0 0 0 \n",
"144 0 0 0 0 0 0 \n",
"\n",
" Breakfast Spot Brewery Bubble Tea Shop Burger Joint Bus Station \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
".. ... ... ... ... ... \n",
"140 0 0 0 0 0 \n",
"141 0 0 0 0 0 \n",
"142 0 0 0 0 0 \n",
"143 0 0 0 0 0 \n",
"144 0 0 0 0 0 \n",
"\n",
" Bus Stop Business Service Café Chinese Restaurant Coffee Shop \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 1 \n",
".. ... ... ... ... ... \n",
"140 0 0 0 0 0 \n",
"141 0 0 0 0 0 \n",
"142 0 0 0 0 0 \n",
"143 0 0 0 0 0 \n",
"144 0 0 0 0 0 \n",
"\n",
" Construction & Landscaping Convenience Store Dessert Shop \\\n",
"0 0 0 0 \n",
"1 0 0 0 \n",
"2 0 0 0 \n",
"3 0 0 0 \n",
"4 0 0 0 \n",
".. ... ... ... \n",
"140 0 0 0 \n",
"141 0 0 0 \n",
"142 0 0 0 \n",
"143 0 0 0 \n",
"144 0 0 0 \n",
"\n",
" Dim Sum Restaurant Dog Run Elementary School Falafel Restaurant \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
".. ... ... ... ... \n",
"140 0 0 0 0 \n",
"141 0 0 0 0 \n",
"142 0 0 0 0 \n",
"143 0 0 0 0 \n",
"144 0 0 0 0 \n",
"\n",
" Fast Food Restaurant Fish & Chips Shop Fried Chicken Joint Garden \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
".. ... ... ... ... \n",
"140 0 0 0 0 \n",
"141 0 0 0 0 \n",
"142 0 0 0 0 \n",
"143 0 0 0 0 \n",
"144 0 0 0 0 \n",
"\n",
" Gas Station Gastropub Gift Shop Golf Course Greek Restaurant \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
".. ... ... ... ... ... \n",
"140 0 0 0 0 0 \n",
"141 0 0 0 0 0 \n",
"142 0 0 0 0 0 \n",
"143 0 0 0 0 0 \n",
"144 0 0 0 0 0 \n",
"\n",
" Grocery Store Gym Gym / Fitness Center Home Service Hot Dog Joint \\\n",
"0 0 0 0 0 0 \n",
"1 1 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
".. ... ... ... ... ... \n",
"140 0 0 0 0 0 \n",
"141 0 0 0 0 0 \n",
"142 0 0 0 0 0 \n",
"143 0 0 1 0 0 \n",
"144 0 0 0 0 0 \n",
"\n",
" Hotel Indian Restaurant Juice Bar Korean Restaurant Lake \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
".. ... ... ... ... ... \n",
"140 1 0 0 0 0 \n",
"141 0 0 0 0 0 \n",
"142 0 0 0 0 0 \n",
"143 0 0 0 0 0 \n",
"144 0 0 0 0 0 \n",
"\n",
" Liquor Store Malay Restaurant Men's Store Motorcycle Shop Mountain \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
".. ... ... ... ... ... \n",
"140 0 0 0 0 0 \n",
"141 0 0 0 0 0 \n",
"142 0 0 0 0 0 \n",
"143 0 0 0 0 0 \n",
"144 0 0 0 0 0 \n",
"\n",
" Park Pet Store Pharmacy Pizza Place Playground Plaza Pub \\\n",
"0 0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 0 \n",
".. ... ... ... ... ... ... ... \n",
"140 0 0 0 0 0 0 0 \n",
"141 1 0 0 0 0 0 0 \n",
"142 1 0 0 0 0 0 0 \n",
"143 0 0 0 0 0 0 0 \n",
"144 0 0 0 0 0 0 0 \n",
"\n",
" Recreation Center Restaurant Salon / Barbershop Sandwich Place \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
".. ... ... ... ... \n",
"140 0 0 0 0 \n",
"141 0 0 0 0 \n",
"142 0 0 0 0 \n",
"143 0 0 0 0 \n",
"144 0 0 0 0 \n",
"\n",
" Shipping Store Ski Area Ski Lodge Snack Place Sporting Goods Shop \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 1 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
".. ... ... ... ... ... \n",
"140 0 0 0 0 0 \n",
"141 0 0 0 0 0 \n",
"142 0 0 0 0 0 \n",
"143 0 0 0 0 0 \n",
"144 0 0 0 0 0 \n",
"\n",
" Sushi Restaurant Theme Park Tourist Information Center \\\n",
"0 0 0 0 \n",
"1 0 0 0 \n",
"2 0 0 0 \n",
"3 0 0 0 \n",
"4 0 0 0 \n",
".. ... ... ... \n",
"140 0 0 0 \n",
"141 0 0 0 \n",
"142 0 0 0 \n",
"143 0 0 0 \n",
"144 0 0 0 \n",
"\n",
" Toy / Game Store Trail Vacation Rental Vietnamese Restaurant \\\n",
"0 0 1 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
".. ... ... ... ... \n",
"140 0 0 0 0 \n",
"141 0 0 0 0 \n",
"142 0 0 0 0 \n",
"143 0 0 0 0 \n",
"144 0 0 0 0 \n",
"\n",
" Wine Shop Zoo \n",
"0 0 0 \n",
"1 0 0 \n",
"2 0 0 \n",
"3 0 0 \n",
"4 0 0 \n",
".. ... ... \n",
"140 0 0 \n",
"141 0 0 \n",
"142 0 0 \n",
"143 0 0 \n",
"144 0 0 \n",
"\n",
"[145 rows x 76 columns]"
]
},
"execution_count": 136,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"one_hot"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Add neighborhood values corresponding to their nearby locations.\n"
]
},
{
"cell_type": "code",
"execution_count": 138,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>American Restaurant</th>\n",
" <th>Asian Restaurant</th>\n",
" <th>Athletics &amp; Sports</th>\n",
" <th>Auto Workshop</th>\n",
" <th>Bakery</th>\n",
" <th>Bank</th>\n",
" <th>Baseball Field</th>\n",
" <th>Beach</th>\n",
" <th>Boat or Ferry</th>\n",
" <th>Bookstore</th>\n",
" <th>Breakfast Spot</th>\n",
" <th>Brewery</th>\n",
" <th>Bubble Tea Shop</th>\n",
" <th>Burger Joint</th>\n",
" <th>Bus Station</th>\n",
" <th>Bus Stop</th>\n",
" <th>Business Service</th>\n",
" <th>Café</th>\n",
" <th>Chinese Restaurant</th>\n",
" <th>Coffee Shop</th>\n",
" <th>Construction &amp; Landscaping</th>\n",
" <th>Convenience Store</th>\n",
" <th>Dessert Shop</th>\n",
" <th>Dim Sum Restaurant</th>\n",
" <th>Dog Run</th>\n",
" <th>Elementary School</th>\n",
" <th>Falafel Restaurant</th>\n",
" <th>Fast Food Restaurant</th>\n",
" <th>Fish &amp; Chips Shop</th>\n",
" <th>Fried Chicken Joint</th>\n",
" <th>Garden</th>\n",
" <th>Gas Station</th>\n",
" <th>Gastropub</th>\n",
" <th>Gift Shop</th>\n",
" <th>Golf Course</th>\n",
" <th>Greek Restaurant</th>\n",
" <th>Grocery Store</th>\n",
" <th>Gym</th>\n",
" <th>Gym / Fitness Center</th>\n",
" <th>Home Service</th>\n",
" <th>Hot Dog Joint</th>\n",
" <th>Hotel</th>\n",
" <th>Indian Restaurant</th>\n",
" <th>Juice Bar</th>\n",
" <th>Korean Restaurant</th>\n",
" <th>Lake</th>\n",
" <th>Liquor Store</th>\n",
" <th>Malay Restaurant</th>\n",
" <th>Men's Store</th>\n",
" <th>Motorcycle Shop</th>\n",
" <th>Mountain</th>\n",
" <th>Park</th>\n",
" <th>Pet Store</th>\n",
" <th>Pharmacy</th>\n",
" <th>Pizza Place</th>\n",
" <th>Playground</th>\n",
" <th>Plaza</th>\n",
" <th>Pub</th>\n",
" <th>Recreation Center</th>\n",
" <th>Restaurant</th>\n",
" <th>Salon / Barbershop</th>\n",
" <th>Sandwich Place</th>\n",
" <th>Shipping Store</th>\n",
" <th>Ski Area</th>\n",
" <th>Ski Lodge</th>\n",
" <th>Snack Place</th>\n",
" <th>Sporting Goods Shop</th>\n",
" <th>Sushi Restaurant</th>\n",
" <th>Theme Park</th>\n",
" <th>Tourist Information Center</th>\n",
" <th>Toy / Game Store</th>\n",
" <th>Trail</th>\n",
" <th>Vacation Rental</th>\n",
" <th>Vietnamese Restaurant</th>\n",
" <th>Wine Shop</th>\n",
" <th>Zoo</th>\n",
" <th>Neighborhood</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>Abbotsford</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>Abbotsford</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>Burnaby</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>Burnaby</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>Burnaby</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" American Restaurant Asian Restaurant Athletics & Sports Auto Workshop \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Bakery Bank Baseball Field Beach Boat or Ferry Bookstore \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 1 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Breakfast Spot Brewery Bubble Tea Shop Burger Joint Bus Station \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Bus Stop Business Service Café Chinese Restaurant Coffee Shop \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 1 \n",
"\n",
" Construction & Landscaping Convenience Store Dessert Shop \\\n",
"0 0 0 0 \n",
"1 0 0 0 \n",
"2 0 0 0 \n",
"3 0 0 0 \n",
"4 0 0 0 \n",
"\n",
" Dim Sum Restaurant Dog Run Elementary School Falafel Restaurant \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Fast Food Restaurant Fish & Chips Shop Fried Chicken Joint Garden \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Gas Station Gastropub Gift Shop Golf Course Greek Restaurant \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Grocery Store Gym Gym / Fitness Center Home Service Hot Dog Joint \\\n",
"0 0 0 0 0 0 \n",
"1 1 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Hotel Indian Restaurant Juice Bar Korean Restaurant Lake Liquor Store \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Malay Restaurant Men's Store Motorcycle Shop Mountain Park Pet Store \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Pharmacy Pizza Place Playground Plaza Pub Recreation Center \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Restaurant Salon / Barbershop Sandwich Place Shipping Store Ski Area \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Ski Lodge Snack Place Sporting Goods Shop Sushi Restaurant Theme Park \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 1 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Tourist Information Center Toy / Game Store Trail Vacation Rental \\\n",
"0 0 0 1 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Vietnamese Restaurant Wine Shop Zoo Neighborhood \n",
"0 0 0 0 Abbotsford \n",
"1 0 0 0 Abbotsford \n",
"2 0 0 0 Burnaby \n",
"3 0 0 0 Burnaby \n",
"4 0 0 0 Burnaby "
]
},
"execution_count": 138,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"one_hot['Neighborhood'] = neighborhood_venues['Neighborhood'] \n",
"one_hot.head()"
]
},
{
"cell_type": "code",
"execution_count": 139,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Neighborhood</th>\n",
" <th>American Restaurant</th>\n",
" <th>Asian Restaurant</th>\n",
" <th>Athletics &amp; Sports</th>\n",
" <th>Auto Workshop</th>\n",
" <th>Bakery</th>\n",
" <th>Bank</th>\n",
" <th>Baseball Field</th>\n",
" <th>Beach</th>\n",
" <th>Boat or Ferry</th>\n",
" <th>Bookstore</th>\n",
" <th>Breakfast Spot</th>\n",
" <th>Brewery</th>\n",
" <th>Bubble Tea Shop</th>\n",
" <th>Burger Joint</th>\n",
" <th>Bus Station</th>\n",
" <th>Bus Stop</th>\n",
" <th>Business Service</th>\n",
" <th>Café</th>\n",
" <th>Chinese Restaurant</th>\n",
" <th>Coffee Shop</th>\n",
" <th>Construction &amp; Landscaping</th>\n",
" <th>Convenience Store</th>\n",
" <th>Dessert Shop</th>\n",
" <th>Dim Sum Restaurant</th>\n",
" <th>Dog Run</th>\n",
" <th>Elementary School</th>\n",
" <th>Falafel Restaurant</th>\n",
" <th>Fast Food Restaurant</th>\n",
" <th>Fish &amp; Chips Shop</th>\n",
" <th>Fried Chicken Joint</th>\n",
" <th>Garden</th>\n",
" <th>Gas Station</th>\n",
" <th>Gastropub</th>\n",
" <th>Gift Shop</th>\n",
" <th>Golf Course</th>\n",
" <th>Greek Restaurant</th>\n",
" <th>Grocery Store</th>\n",
" <th>Gym</th>\n",
" <th>Gym / Fitness Center</th>\n",
" <th>Home Service</th>\n",
" <th>Hot Dog Joint</th>\n",
" <th>Hotel</th>\n",
" <th>Indian Restaurant</th>\n",
" <th>Juice Bar</th>\n",
" <th>Korean Restaurant</th>\n",
" <th>Lake</th>\n",
" <th>Liquor Store</th>\n",
" <th>Malay Restaurant</th>\n",
" <th>Men's Store</th>\n",
" <th>Motorcycle Shop</th>\n",
" <th>Mountain</th>\n",
" <th>Park</th>\n",
" <th>Pet Store</th>\n",
" <th>Pharmacy</th>\n",
" <th>Pizza Place</th>\n",
" <th>Playground</th>\n",
" <th>Plaza</th>\n",
" <th>Pub</th>\n",
" <th>Recreation Center</th>\n",
" <th>Restaurant</th>\n",
" <th>Salon / Barbershop</th>\n",
" <th>Sandwich Place</th>\n",
" <th>Shipping Store</th>\n",
" <th>Ski Area</th>\n",
" <th>Ski Lodge</th>\n",
" <th>Snack Place</th>\n",
" <th>Sporting Goods Shop</th>\n",
" <th>Sushi Restaurant</th>\n",
" <th>Theme Park</th>\n",
" <th>Tourist Information Center</th>\n",
" <th>Toy / Game Store</th>\n",
" <th>Trail</th>\n",
" <th>Vacation Rental</th>\n",
" <th>Vietnamese Restaurant</th>\n",
" <th>Wine Shop</th>\n",
" <th>Zoo</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Abbotsford</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Burnaby</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Burnaby</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Burnaby</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>1</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" <td>0</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Neighborhood American Restaurant Asian Restaurant Athletics & Sports \\\n",
"0 Abbotsford 0 0 0 \n",
"1 Abbotsford 0 0 0 \n",
"2 Burnaby 0 0 0 \n",
"3 Burnaby 0 0 0 \n",
"4 Burnaby 0 0 0 \n",
"\n",
" Auto Workshop Bakery Bank Baseball Field Beach Boat or Ferry \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Bookstore Breakfast Spot Brewery Bubble Tea Shop Burger Joint \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 1 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Bus Station Bus Stop Business Service Café Chinese Restaurant \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Coffee Shop Construction & Landscaping Convenience Store Dessert Shop \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 1 0 0 0 \n",
"\n",
" Dim Sum Restaurant Dog Run Elementary School Falafel Restaurant \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Fast Food Restaurant Fish & Chips Shop Fried Chicken Joint Garden \\\n",
"0 0 0 0 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Gas Station Gastropub Gift Shop Golf Course Greek Restaurant \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Grocery Store Gym Gym / Fitness Center Home Service Hot Dog Joint \\\n",
"0 0 0 0 0 0 \n",
"1 1 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Hotel Indian Restaurant Juice Bar Korean Restaurant Lake Liquor Store \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Malay Restaurant Men's Store Motorcycle Shop Mountain Park Pet Store \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Pharmacy Pizza Place Playground Plaza Pub Recreation Center \\\n",
"0 0 0 0 0 0 0 \n",
"1 0 0 0 0 0 0 \n",
"2 0 0 0 0 0 0 \n",
"3 0 0 0 0 0 0 \n",
"4 0 0 0 0 0 0 \n",
"\n",
" Restaurant Salon / Barbershop Sandwich Place Shipping Store Ski Area \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 0 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Ski Lodge Snack Place Sporting Goods Shop Sushi Restaurant Theme Park \\\n",
"0 0 0 0 0 0 \n",
"1 0 0 0 0 0 \n",
"2 0 1 0 0 0 \n",
"3 0 0 0 0 0 \n",
"4 0 0 0 0 0 \n",
"\n",
" Tourist Information Center Toy / Game Store Trail Vacation Rental \\\n",
"0 0 0 1 0 \n",
"1 0 0 0 0 \n",
"2 0 0 0 0 \n",
"3 0 0 0 0 \n",
"4 0 0 0 0 \n",
"\n",
" Vietnamese Restaurant Wine Shop Zoo \n",
"0 0 0 0 \n",
"1 0 0 0 \n",
"2 0 0 0 \n",
"3 0 0 0 \n",
"4 0 0 0 "
]
},
"execution_count": 139,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"fixed_columns = [one_hot.columns[-1]] + list(one_hot.columns[:-1])\n",
"one_hot = one_hot[fixed_columns]\n",
"one_hot.head()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Checking the size of our new data frame.\n"
]
},
{
"cell_type": "code",
"execution_count": 140,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(145, 77)"
]
},
"execution_count": 140,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"one_hot.shape"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Next, let's group rows by neighborhood and by taking the mean of the frequency of occurrence of each category.\n"
]
},
{
"cell_type": "code",
"execution_count": 141,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Neighborhood</th>\n",
" <th>American Restaurant</th>\n",
" <th>Asian Restaurant</th>\n",
" <th>Athletics &amp; Sports</th>\n",
" <th>Auto Workshop</th>\n",
" <th>Bakery</th>\n",
" <th>Bank</th>\n",
" <th>Baseball Field</th>\n",
" <th>Beach</th>\n",
" <th>Boat or Ferry</th>\n",
" <th>Bookstore</th>\n",
" <th>Breakfast Spot</th>\n",
" <th>Brewery</th>\n",
" <th>Bubble Tea Shop</th>\n",
" <th>Burger Joint</th>\n",
" <th>Bus Station</th>\n",
" <th>Bus Stop</th>\n",
" <th>Business Service</th>\n",
" <th>Café</th>\n",
" <th>Chinese Restaurant</th>\n",
" <th>Coffee Shop</th>\n",
" <th>Construction &amp; Landscaping</th>\n",
" <th>Convenience Store</th>\n",
" <th>Dessert Shop</th>\n",
" <th>Dim Sum Restaurant</th>\n",
" <th>Dog Run</th>\n",
" <th>Elementary School</th>\n",
" <th>Falafel Restaurant</th>\n",
" <th>Fast Food Restaurant</th>\n",
" <th>Fish &amp; Chips Shop</th>\n",
" <th>Fried Chicken Joint</th>\n",
" <th>Garden</th>\n",
" <th>Gas Station</th>\n",
" <th>Gastropub</th>\n",
" <th>Gift Shop</th>\n",
" <th>Golf Course</th>\n",
" <th>Greek Restaurant</th>\n",
" <th>Grocery Store</th>\n",
" <th>Gym</th>\n",
" <th>Gym / Fitness Center</th>\n",
" <th>Home Service</th>\n",
" <th>Hot Dog Joint</th>\n",
" <th>Hotel</th>\n",
" <th>Indian Restaurant</th>\n",
" <th>Juice Bar</th>\n",
" <th>Korean Restaurant</th>\n",
" <th>Lake</th>\n",
" <th>Liquor Store</th>\n",
" <th>Malay Restaurant</th>\n",
" <th>Men's Store</th>\n",
" <th>Motorcycle Shop</th>\n",
" <th>Mountain</th>\n",
" <th>Park</th>\n",
" <th>Pet Store</th>\n",
" <th>Pharmacy</th>\n",
" <th>Pizza Place</th>\n",
" <th>Playground</th>\n",
" <th>Plaza</th>\n",
" <th>Pub</th>\n",
" <th>Recreation Center</th>\n",
" <th>Restaurant</th>\n",
" <th>Salon / Barbershop</th>\n",
" <th>Sandwich Place</th>\n",
" <th>Shipping Store</th>\n",
" <th>Ski Area</th>\n",
" <th>Ski Lodge</th>\n",
" <th>Snack Place</th>\n",
" <th>Sporting Goods Shop</th>\n",
" <th>Sushi Restaurant</th>\n",
" <th>Theme Park</th>\n",
" <th>Tourist Information Center</th>\n",
" <th>Toy / Game Store</th>\n",
" <th>Trail</th>\n",
" <th>Vacation Rental</th>\n",
" <th>Vietnamese Restaurant</th>\n",
" <th>Wine Shop</th>\n",
" <th>Zoo</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.000000</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.5</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.5</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Burnaby</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.111111</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.111111</td>\n",
" <td>0.111111</td>\n",
" <td>0.222222</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.111111</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.111111</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.111111</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.111111</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Comox</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.000000</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.166667</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.333333</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.166667</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.166667</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.166667</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Coquitlam</td>\n",
" <td>0.0</td>\n",
" <td>0.2</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.000000</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.200000</td>\n",
" <td>0.0</td>\n",
" <td>0.2</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.2</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.2</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Cranbrook</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.000000</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>1.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.000000</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" <td>0.0</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Neighborhood American Restaurant Asian Restaurant Athletics & Sports \\\n",
"0 Abbotsford 0.0 0.0 0.0 \n",
"1 Burnaby 0.0 0.0 0.0 \n",
"2 Comox 0.0 0.0 0.0 \n",
"3 Coquitlam 0.0 0.2 0.0 \n",
"4 Cranbrook 0.0 0.0 0.0 \n",
"\n",
" Auto Workshop Bakery Bank Baseball Field Beach Boat or Ferry \\\n",
"0 0.0 0.0 0.0 0.0 0.0 0.0 \n",
"1 0.0 0.0 0.0 0.0 0.0 0.0 \n",
"2 0.0 0.0 0.0 0.0 0.0 0.0 \n",
"3 0.0 0.0 0.0 0.0 0.0 0.0 \n",
"4 0.0 0.0 0.0 0.0 0.0 0.0 \n",
"\n",
" Bookstore Breakfast Spot Brewery Bubble Tea Shop Burger Joint \\\n",
"0 0.000000 0.0 0.0 0.0 0.000000 \n",
"1 0.111111 0.0 0.0 0.0 0.111111 \n",
"2 0.000000 0.0 0.0 0.0 0.000000 \n",
"3 0.000000 0.0 0.0 0.0 0.000000 \n",
"4 0.000000 0.0 0.0 0.0 0.000000 \n",
"\n",
" Bus Station Bus Stop Business Service Café Chinese Restaurant \\\n",
"0 0.000000 0.000000 0.0 0.0 0.0 \n",
"1 0.111111 0.222222 0.0 0.0 0.0 \n",
"2 0.000000 0.000000 0.0 0.0 0.0 \n",
"3 0.000000 0.000000 0.0 0.0 0.0 \n",
"4 0.000000 0.000000 0.0 0.0 0.0 \n",
"\n",
" Coffee Shop Construction & Landscaping Convenience Store Dessert Shop \\\n",
"0 0.000000 0.0 0.0 0.0 \n",
"1 0.111111 0.0 0.0 0.0 \n",
"2 0.166667 0.0 0.0 0.0 \n",
"3 0.200000 0.0 0.2 0.0 \n",
"4 0.000000 1.0 0.0 0.0 \n",
"\n",
" Dim Sum Restaurant Dog Run Elementary School Falafel Restaurant \\\n",
"0 0.0 0.0 0.0 0.0 \n",
"1 0.0 0.0 0.0 0.0 \n",
"2 0.0 0.0 0.0 0.0 \n",
"3 0.0 0.0 0.0 0.0 \n",
"4 0.0 0.0 0.0 0.0 \n",
"\n",
" Fast Food Restaurant Fish & Chips Shop Fried Chicken Joint Garden \\\n",
"0 0.000000 0.0 0.0 0.0 \n",
"1 0.000000 0.0 0.0 0.0 \n",
"2 0.333333 0.0 0.0 0.0 \n",
"3 0.000000 0.0 0.0 0.0 \n",
"4 0.000000 0.0 0.0 0.0 \n",
"\n",
" Gas Station Gastropub Gift Shop Golf Course Greek Restaurant \\\n",
"0 0.0 0.0 0.0 0.0 0.0 \n",
"1 0.0 0.0 0.0 0.0 0.0 \n",
"2 0.0 0.0 0.0 0.0 0.0 \n",
"3 0.2 0.0 0.0 0.2 0.0 \n",
"4 0.0 0.0 0.0 0.0 0.0 \n",
"\n",
" Grocery Store Gym Gym / Fitness Center Home Service Hot Dog Joint \\\n",
"0 0.5 0.0 0.0 0.0 0.0 \n",
"1 0.0 0.0 0.0 0.0 0.0 \n",
"2 0.0 0.0 0.0 0.0 0.0 \n",
"3 0.0 0.0 0.0 0.0 0.0 \n",
"4 0.0 0.0 0.0 0.0 0.0 \n",
"\n",
" Hotel Indian Restaurant Juice Bar Korean Restaurant Lake Liquor Store \\\n",
"0 0.0 0.0 0.000000 0.0 0.0 0.0 \n",
"1 0.0 0.0 0.000000 0.0 0.0 0.0 \n",
"2 0.0 0.0 0.166667 0.0 0.0 0.0 \n",
"3 0.0 0.0 0.000000 0.0 0.0 0.0 \n",
"4 0.0 0.0 0.000000 0.0 0.0 0.0 \n",
"\n",
" Malay Restaurant Men's Store Motorcycle Shop Mountain Park \\\n",
"0 0.0 0.0 0.0 0.0 0.000000 \n",
"1 0.0 0.0 0.0 0.0 0.111111 \n",
"2 0.0 0.0 0.0 0.0 0.000000 \n",
"3 0.0 0.0 0.0 0.0 0.000000 \n",
"4 0.0 0.0 0.0 0.0 0.000000 \n",
"\n",
" Pet Store Pharmacy Pizza Place Playground Plaza Pub \\\n",
"0 0.0 0.000000 0.0 0.0 0.0 0.0 \n",
"1 0.0 0.000000 0.0 0.0 0.0 0.0 \n",
"2 0.0 0.166667 0.0 0.0 0.0 0.0 \n",
"3 0.0 0.000000 0.0 0.0 0.0 0.0 \n",
"4 0.0 0.000000 0.0 0.0 0.0 0.0 \n",
"\n",
" Recreation Center Restaurant Salon / Barbershop Sandwich Place \\\n",
"0 0.0 0.0 0.0 0.000000 \n",
"1 0.0 0.0 0.0 0.111111 \n",
"2 0.0 0.0 0.0 0.166667 \n",
"3 0.0 0.0 0.0 0.000000 \n",
"4 0.0 0.0 0.0 0.000000 \n",
"\n",
" Shipping Store Ski Area Ski Lodge Snack Place Sporting Goods Shop \\\n",
"0 0.0 0.0 0.0 0.000000 0.0 \n",
"1 0.0 0.0 0.0 0.111111 0.0 \n",
"2 0.0 0.0 0.0 0.000000 0.0 \n",
"3 0.0 0.0 0.0 0.000000 0.0 \n",
"4 0.0 0.0 0.0 0.000000 0.0 \n",
"\n",
" Sushi Restaurant Theme Park Tourist Information Center Toy / Game Store \\\n",
"0 0.0 0.0 0.0 0.0 \n",
"1 0.0 0.0 0.0 0.0 \n",
"2 0.0 0.0 0.0 0.0 \n",
"3 0.0 0.0 0.0 0.0 \n",
"4 0.0 0.0 0.0 0.0 \n",
"\n",
" Trail Vacation Rental Vietnamese Restaurant Wine Shop Zoo \n",
"0 0.5 0.0 0.0 0.0 0.0 \n",
"1 0.0 0.0 0.0 0.0 0.0 \n",
"2 0.0 0.0 0.0 0.0 0.0 \n",
"3 0.0 0.0 0.0 0.0 0.0 \n",
"4 0.0 0.0 0.0 0.0 0.0 "
]
},
"execution_count": 141,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"british_columbia_grouped = one_hot.groupby('Neighborhood').mean().reset_index()\n",
"british_columbia_grouped.head()"
]
},
{
"cell_type": "code",
"execution_count": 142,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"(32, 77)"
]
},
"execution_count": 142,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"british_columbia_grouped.shape"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### We define a function to sort the venues in descending order.\n"
]
},
{
"cell_type": "code",
"execution_count": 143,
"metadata": {},
"outputs": [],
"source": [
"def return_most_common_venues(row, num_top_venues):\n",
" row_categories = row.iloc[1:]\n",
" row_categories_sorted = row_categories.sort_values(ascending=False)\n",
" \n",
" return row_categories_sorted.index.values[0:num_top_venues]"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Now we create the new data frame and display the top 10 venues for each neighborhood.\n"
]
},
{
"cell_type": "code",
"execution_count": 147,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Neighborhood</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford</td>\n",
" <td>Grocery Store</td>\n",
" <td>Trail</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Burnaby</td>\n",
" <td>Bus Stop</td>\n",
" <td>Bookstore</td>\n",
" <td>Snack Place</td>\n",
" <td>Park</td>\n",
" <td>Bus Station</td>\n",
" <td>Burger Joint</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Comox</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Pharmacy</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Juice Bar</td>\n",
" <td>Elementary School</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Coquitlam</td>\n",
" <td>Asian Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Golf Course</td>\n",
" <td>Gas Station</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Cranbrook</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5</th>\n",
" <td>Duncan</td>\n",
" <td>Convenience Store</td>\n",
" <td>Gas Station</td>\n",
" <td>Dog Run</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>6</th>\n",
" <td>Esquimalt</td>\n",
" <td>Boat or Ferry</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Zoo</td>\n",
" </tr>\n",
" <tr>\n",
" <th>7</th>\n",
" <td>Fort St. John</td>\n",
" <td>American Restaurant</td>\n",
" <td>Gas Station</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>8</th>\n",
" <td>Highlands</td>\n",
" <td>Zoo</td>\n",
" <td>Theme Park</td>\n",
" <td>Boat or Ferry</td>\n",
" <td>Wine Shop</td>\n",
" <td>Auto Workshop</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9</th>\n",
" <td>Kelowna Central</td>\n",
" <td>Park</td>\n",
" <td>Mountain</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>10</th>\n",
" <td>Kimberley</td>\n",
" <td>American Restaurant</td>\n",
" <td>Ski Lodge</td>\n",
" <td>Hotel</td>\n",
" <td>Ski Area</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>11</th>\n",
" <td>Kitimat</td>\n",
" <td>Business Service</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>12</th>\n",
" <td>Langley City</td>\n",
" <td>Baseball Field</td>\n",
" <td>Zoo</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>13</th>\n",
" <td>Nanaimo Central</td>\n",
" <td>Tourist Information Center</td>\n",
" <td>Brewery</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>14</th>\n",
" <td>Nelson</td>\n",
" <td>Trail</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>15</th>\n",
" <td>New Westminster Northeast</td>\n",
" <td>Hot Dog Joint</td>\n",
" <td>Garden</td>\n",
" <td>Playground</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>16</th>\n",
" <td>Oak Bay</td>\n",
" <td>Gym</td>\n",
" <td>Bookstore</td>\n",
" <td>Gift Shop</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Men's Store</td>\n",
" <td>Breakfast Spot</td>\n",
" <td>Café</td>\n",
" <td>Bakery</td>\n",
" <td>Toy / Game Store</td>\n",
" <td>Bank</td>\n",
" </tr>\n",
" <tr>\n",
" <th>17</th>\n",
" <td>Parksville</td>\n",
" <td>Bookstore</td>\n",
" <td>Home Service</td>\n",
" <td>Zoo</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>18</th>\n",
" <td>Pitt Meadows</td>\n",
" <td>Gym / Fitness Center</td>\n",
" <td>Plaza</td>\n",
" <td>Elementary School</td>\n",
" <td>Pub</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>19</th>\n",
" <td>Qualicum Beach</td>\n",
" <td>American Restaurant</td>\n",
" <td>Restaurant</td>\n",
" <td>Pharmacy</td>\n",
" <td>Grocery Store</td>\n",
" <td>Gastropub</td>\n",
" <td>Gas Station</td>\n",
" <td>Garden</td>\n",
" <td>Fried Chicken Joint</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>20</th>\n",
" <td>Richmond</td>\n",
" <td>Gym</td>\n",
" <td>Grocery Store</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Sushi Restaurant</td>\n",
" <td>Pizza Place</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Pub</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Indian Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>21</th>\n",
" <td>Saanich Central</td>\n",
" <td>Bank</td>\n",
" <td>Zoo</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>22</th>\n",
" <td>Salmon Arm</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>23</th>\n",
" <td>Sooke</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>24</th>\n",
" <td>South Okanagan</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>25</th>\n",
" <td>Surrey</td>\n",
" <td>Recreation Center</td>\n",
" <td>Auto Workshop</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>26</th>\n",
" <td>Terrace</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>27</th>\n",
" <td>Trail</td>\n",
" <td>Pub</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Zoo</td>\n",
" </tr>\n",
" <tr>\n",
" <th>28</th>\n",
" <td>Vancouver</td>\n",
" <td>Bank</td>\n",
" <td>Sushi Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Park</td>\n",
" <td>Gym</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Greek Restaurant</td>\n",
" <td>Grocery Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Liquor Store</td>\n",
" </tr>\n",
" <tr>\n",
" <th>29</th>\n",
" <td>Victoria Central British Columbia Provincial G...</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Brewery</td>\n",
" <td>Restaurant</td>\n",
" <td>Motorcycle Shop</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Gym</td>\n",
" <td>Gastropub</td>\n",
" <td>Fried Chicken Joint</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>30</th>\n",
" <td>Whistler</td>\n",
" <td>Hotel</td>\n",
" <td>Vacation Rental</td>\n",
" <td>Beach</td>\n",
" <td>Lake</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>31</th>\n",
" <td>White Rock</td>\n",
" <td>Park</td>\n",
" <td>Gym / Fitness Center</td>\n",
" <td>Athletics &amp; Sports</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Neighborhood \\\n",
"0 Abbotsford \n",
"1 Burnaby \n",
"2 Comox \n",
"3 Coquitlam \n",
"4 Cranbrook \n",
"5 Duncan \n",
"6 Esquimalt \n",
"7 Fort St. John \n",
"8 Highlands \n",
"9 Kelowna Central \n",
"10 Kimberley \n",
"11 Kitimat \n",
"12 Langley City \n",
"13 Nanaimo Central \n",
"14 Nelson \n",
"15 New Westminster Northeast \n",
"16 Oak Bay \n",
"17 Parksville \n",
"18 Pitt Meadows \n",
"19 Qualicum Beach \n",
"20 Richmond \n",
"21 Saanich Central \n",
"22 Salmon Arm \n",
"23 Sooke \n",
"24 South Okanagan \n",
"25 Surrey \n",
"26 Terrace \n",
"27 Trail \n",
"28 Vancouver \n",
"29 Victoria Central British Columbia Provincial G... \n",
"30 Whistler \n",
"31 White Rock \n",
"\n",
" 1st Most Common Venue 2nd Most Common Venue 3rd Most Common Venue \\\n",
"0 Grocery Store Trail Falafel Restaurant \n",
"1 Bus Stop Bookstore Snack Place \n",
"2 Fast Food Restaurant Coffee Shop Pharmacy \n",
"3 Asian Restaurant Convenience Store Golf Course \n",
"4 Construction & Landscaping Zoo Fast Food Restaurant \n",
"5 Convenience Store Gas Station Dog Run \n",
"6 Boat or Ferry Fish & Chips Shop Convenience Store \n",
"7 American Restaurant Gas Station Fast Food Restaurant \n",
"8 Zoo Theme Park Boat or Ferry \n",
"9 Park Mountain Zoo \n",
"10 American Restaurant Ski Lodge Hotel \n",
"11 Business Service Zoo Fast Food Restaurant \n",
"12 Baseball Field Zoo Fish & Chips Shop \n",
"13 Tourist Information Center Brewery Zoo \n",
"14 Trail Zoo Fast Food Restaurant \n",
"15 Hot Dog Joint Garden Playground \n",
"16 Gym Bookstore Gift Shop \n",
"17 Bookstore Home Service Zoo \n",
"18 Gym / Fitness Center Plaza Elementary School \n",
"19 American Restaurant Restaurant Pharmacy \n",
"20 Gym Grocery Store Dim Sum Restaurant \n",
"21 Bank Zoo Fish & Chips Shop \n",
"22 Construction & Landscaping Zoo Fast Food Restaurant \n",
"23 Construction & Landscaping Zoo Fast Food Restaurant \n",
"24 Construction & Landscaping Zoo Fast Food Restaurant \n",
"25 Recreation Center Auto Workshop Zoo \n",
"26 Construction & Landscaping Zoo Fast Food Restaurant \n",
"27 Pub Falafel Restaurant Coffee Shop \n",
"28 Bank Sushi Restaurant Coffee Shop \n",
"29 Coffee Shop Brewery Restaurant \n",
"30 Hotel Vacation Rental Beach \n",
"31 Park Gym / Fitness Center Athletics & Sports \n",
"\n",
" 4th Most Common Venue 5th Most Common Venue \\\n",
"0 Coffee Shop Construction & Landscaping \n",
"1 Park Bus Station \n",
"2 Sandwich Place Juice Bar \n",
"3 Gas Station Coffee Shop \n",
"4 Convenience Store Dessert Shop \n",
"5 Zoo Fast Food Restaurant \n",
"6 Dessert Shop Dim Sum Restaurant \n",
"7 Construction & Landscaping Convenience Store \n",
"8 Wine Shop Auto Workshop \n",
"9 Falafel Restaurant Convenience Store \n",
"10 Ski Area Construction & Landscaping \n",
"11 Convenience Store Dessert Shop \n",
"12 Convenience Store Dessert Shop \n",
"13 Falafel Restaurant Construction & Landscaping \n",
"14 Construction & Landscaping Convenience Store \n",
"15 Zoo Falafel Restaurant \n",
"16 Fish & Chips Shop Men's Store \n",
"17 Convenience Store Dessert Shop \n",
"18 Pub Coffee Shop \n",
"19 Grocery Store Gastropub \n",
"20 Sushi Restaurant Pizza Place \n",
"21 Convenience Store Dessert Shop \n",
"22 Convenience Store Dessert Shop \n",
"23 Convenience Store Dessert Shop \n",
"24 Convenience Store Dessert Shop \n",
"25 Falafel Restaurant Construction & Landscaping \n",
"26 Convenience Store Dessert Shop \n",
"27 Construction & Landscaping Convenience Store \n",
"28 Park Gym \n",
"29 Motorcycle Shop Sandwich Place \n",
"30 Lake Zoo \n",
"31 Zoo Fast Food Restaurant \n",
"\n",
" 6th Most Common Venue 7th Most Common Venue \\\n",
"0 Convenience Store Dessert Shop \n",
"1 Burger Joint Sandwich Place \n",
"2 Elementary School Construction & Landscaping \n",
"3 Zoo Falafel Restaurant \n",
"4 Dim Sum Restaurant Dog Run \n",
"5 Construction & Landscaping Dessert Shop \n",
"6 Dog Run Elementary School \n",
"7 Dessert Shop Dim Sum Restaurant \n",
"8 Fish & Chips Shop Dessert Shop \n",
"9 Dessert Shop Dim Sum Restaurant \n",
"10 Convenience Store Dessert Shop \n",
"11 Dim Sum Restaurant Dog Run \n",
"12 Dim Sum Restaurant Dog Run \n",
"13 Convenience Store Dessert Shop \n",
"14 Dessert Shop Dim Sum Restaurant \n",
"15 Construction & Landscaping Convenience Store \n",
"16 Breakfast Spot Café \n",
"17 Dim Sum Restaurant Dog Run \n",
"18 Construction & Landscaping Convenience Store \n",
"19 Gas Station Garden \n",
"20 Sandwich Place Pub \n",
"21 Dim Sum Restaurant Dog Run \n",
"22 Dim Sum Restaurant Dog Run \n",
"23 Dim Sum Restaurant Dog Run \n",
"24 Dim Sum Restaurant Dog Run \n",
"25 Convenience Store Dessert Shop \n",
"26 Dim Sum Restaurant Dog Run \n",
"27 Dessert Shop Dim Sum Restaurant \n",
"28 Sandwich Place Greek Restaurant \n",
"29 Gym Gastropub \n",
"30 Fast Food Restaurant Convenience Store \n",
"31 Convenience Store Dessert Shop \n",
"\n",
" 8th Most Common Venue 9th Most Common Venue 10th Most Common Venue \n",
"0 Dim Sum Restaurant Dog Run Elementary School \n",
"1 Coffee Shop Fast Food Restaurant Falafel Restaurant \n",
"2 Convenience Store Dessert Shop Dim Sum Restaurant \n",
"3 Dessert Shop Dim Sum Restaurant Dog Run \n",
"4 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"5 Dim Sum Restaurant Elementary School Falafel Restaurant \n",
"6 Falafel Restaurant Fast Food Restaurant Zoo \n",
"7 Dog Run Elementary School Falafel Restaurant \n",
"8 Dim Sum Restaurant Dog Run Elementary School \n",
"9 Dog Run Elementary School Fast Food Restaurant \n",
"10 Dim Sum Restaurant Dog Run Elementary School \n",
"11 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"12 Elementary School Falafel Restaurant Fast Food Restaurant \n",
"13 Dim Sum Restaurant Dog Run Elementary School \n",
"14 Dog Run Elementary School Falafel Restaurant \n",
"15 Dessert Shop Dim Sum Restaurant Dog Run \n",
"16 Bakery Toy / Game Store Bank \n",
"17 Elementary School Falafel Restaurant Fast Food Restaurant \n",
"18 Dessert Shop Dim Sum Restaurant Dog Run \n",
"19 Fried Chicken Joint Fish & Chips Shop Fast Food Restaurant \n",
"20 Fast Food Restaurant Falafel Restaurant Indian Restaurant \n",
"21 Elementary School Falafel Restaurant Fast Food Restaurant \n",
"22 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"23 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"24 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"25 Dim Sum Restaurant Dog Run Elementary School \n",
"26 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"27 Dog Run Elementary School Zoo \n",
"28 Grocery Store Dessert Shop Liquor Store \n",
"29 Fried Chicken Joint Fish & Chips Shop Fast Food Restaurant \n",
"30 Dessert Shop Dim Sum Restaurant Dog Run \n",
"31 Dim Sum Restaurant Dog Run Elementary School "
]
},
"execution_count": 147,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"indicators = ['st', 'nd', 'rd']\n",
"\n",
"# create columns according to number of top venues\n",
"columns = ['Neighborhood']\n",
"for ind in np.arange(10):\n",
" try:\n",
" columns.append('{}{} Most Common Venue'.format(ind+1, indicators[ind]))\n",
" except:\n",
" columns.append('{}th Most Common Venue'.format(ind+1))\n",
"\n",
"# create a new dataframe\n",
"neigh_top_venues = pd.DataFrame(columns=columns)\n",
"neigh_top_venues['Neighborhood'] = british_columbia_grouped['Neighborhood']\n",
"\n",
"for ind in np.arange(british_columbia_grouped.shape[0]):\n",
" neigh_top_venues.iloc[ind, 1:] = return_most_common_venues(british_columbia_grouped.iloc[ind, :], 10)\n",
"\n",
"neigh_top_venues"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"## Cluster Neighborhoods <a name=\"cluster\"></a>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Here, we cluster the neighborhoods using the k-means clustering based on similar nearby locations. One of the most important factor in K-Means Clustering is to choose the value of 'k', or the number of clusters for th dataset. To decide this, we plot a graph with the 'sum of squared distances' on the y-axis and the 'k' value on the x-axis. Ideally, from this graph, the best 'k' value would be the one with the least sum of squared distance but that usually results in a very high k value. Hence, we apply the elbow method to choose the optimum k value. In the graph, as we increase the value of k, the distance decreases. The point which shows a steep decline in the distance, after which the distance decrease is comparatively less is known as the optimal value of k ( also known as the elbow point ). \n"
]
},
{
"cell_type": "code",
"execution_count": 176,
"metadata": {},
"outputs": [],
"source": [
"british_columbia_clustering = british_columbia_grouped.drop('Neighborhood', 1)"
]
},
{
"cell_type": "code",
"execution_count": 177,
"metadata": {},
"outputs": [],
"source": [
"Sum_of_squared_distances = []\n",
"K = range(1,15)\n",
"for k in K:\n",
" km = KMeans(n_clusters=k)\n",
" km = km.fit(british_columbia_clustering)\n",
" Sum_of_squared_distances.append(km.inertia_)"
]
},
{
"cell_type": "code",
"execution_count": 178,
"metadata": {},
"outputs": [],
"source": [
"import matplotlib.pyplot as plt"
]
},
{
"cell_type": "code",
"execution_count": 179,
"metadata": {},
"outputs": [
{
"data": {
"image/png": "iVBORw0KGgoAAAANSUhEUgAAAX8AAAEWCAYAAACOv5f1AAAABHNCSVQICAgIfAhkiAAAAAlwSFlzAAALEgAACxIB0t1+/AAAADh0RVh0U29mdHdhcmUAbWF0cGxvdGxpYiB2ZXJzaW9uMy4xLjEsIGh0dHA6Ly9tYXRwbG90bGliLm9yZy8QZhcZAAAgAElEQVR4nO3de7yVc/r/8dfVQaRSUUiSDMm57KacJRkS5RBiJ+OQ+Y3zDA2jMYyRMGMm4zAyRqFSEjmrL1tJThUphJmhA1EUUirV9fvjc2+tdru91732Wt1r7/V+Ph7rsfZ9r8N97VX7uu/1OVwfc3dERKSw1Eo6ABER2fyU/EVECpCSv4hIAVLyFxEpQEr+IiIFSMlfRKQAKfnLBszsHDObkrLtZvazJGPKlmz+Lmb2qZkdnY33ygdm9r2ZtcnB+27w/6nMY62jf5M62T6uVE7JvwBFieuH6A++9HZn0nHBT8nCzez2Mvt7RfuHpfk+L5vZ+TkJsvJjDzOz1WU+39Oz+P49zOxNM1tuZl+b2Qgzaxnj9Rt9Nu7ewN3/l60YJf8p+ReuE6I/+NLbxUkHlOK/wOllrgjPBj5KKJ5M3Frm8x0d9w3MrHY5+04FRgJDgO2AvYFVwBQza1LVoKVwKPlLOrqb2f/M7Cszu83MagGYWS0zG2hmc81skZk9aGbbRI8NN7PfRj/vFF21/zra/pmZLTEz28TxvgBmAb+Int8UOBh4MvVJZtbZzKaa2TdmNtPMjoz23wQcBtxZzreao83sYzNbamZ3lcZQ0e8SPd43euxrM7s20w/SzNpFV97fmNl7ZnZiymPDzOweM3vWzJYDXcq81oC/An929xHu/oO7fwGcD3wPXBE97xwze9XM/mFm35rZHDPrWtFnk9okFsVxt5k9Fz3nVTPbwcz+Hn1uc8ysfUpcV5vZf81smZm9b2YnZfjZnBJ9K90nk9dLPEr+ko6TgCKgA9ATODfaf0506wK0ARoApYl2EnBk9PMRwP+ie4DDgVe84toiDxKu9gHOAMYTrnCBcEIBngH+DDQFrgQeM7Nm7n4t8ApwcTnfanoAHYH9gdOITjAV/S5mthdwD9AXaAFsC6TdzJISc13gKWAC0By4BBhhZm1TnnYmcBPQECjbVt4WaAU8mrrT3dcBjwHdUnZ3Inzm2wF/BMaZWdNKPptUpwEDo9evAl4DZkTbY4HUZrn/Ek4o2wA3AA+b2Y4VfhhlmNkvgVuAo919dpzXSmaU/AvXE9HVZ+ntggqee4u7L3H3ecDfgT7R/rOA2939f+7+PXANcEbUXDMJOCz6lnA4cCtwSPS6I6LHK/I4cGR09X024WSQqhh41t2fdfd17j4RmAZ0r+R9B7v7N9HvUgIckMbvcirwtLtPdvdVwB+AdZUc58qUz/araF9nwkllsLuvdveXgKdZ/3kCjHf3V6PfaWWZ99wuul9YzvEWpjwOsAj4u7v/GDU5fQgcX0nMqR539+lRDI8DK939QXdfC4wGfrryd/dH3f3zKObRwMfAz2Mc63LgKuBId/9PjNdJFSj5F65e7t445XZfBc+dn/LzXMLVL9H93DKP1QG2d/f/EpoiDiBcFT4NfB5d5Vaa/N39B8KV/UBgO3d/tcxTdgF6p57AgEOByq44v0j5eQUhGVf4u0SP/fQZuPty4OtKjvOXlM+2NCm3AOZHV+qpx9kpZTv1sy6r9CRS3u+4Y8rjAJ+V+WaV+u+Wji9Tfv6hnO3Szw0zO9vM3kn5d9iHDU9ElbkKuMvdF8R4jVSRkr+kY+eUn1sBn0c/f05IwqmPrWF9ophEuGrewt0/i7bPBpoA76Rx3AeB3wIPlfPYfOChMiewrd19cPR43HK1Ff0uC0n5DMysPqHpJ67PgZ1L+0xSjvNZynZFcX8ILAB6p+6M3u8U4MWU3TuV6VNJ/XfLWilfM9sFuA+4GNjW3RsDs4FN9eeU5xhgoJmdkq24pHJK/pKOq8ysiZntDFxG+NoPMAq4wsx2NbMGwCBgtLuviR6fREgKk6Ptlwnt3FOi5oPKTCK0Y/+jnMceBk4ws1+YWW0z29LMjrT1Qx6/JLTdp6ui32Us0MPMDjWzLYA/kdnfzhvAcmCAmdWNOqhPAB5J58XRlfyVhER5ppltZWY7AP8CGgF/S3l6c+DS6Di9gXbAs9FjcT+bimxNOJkshp/a7uN22L4HHAvcldoBLrml5F+4nrINx6E/XsFzxwPTCVfrzwD3R/v/Tbgqnwx8AqwkJPdSkwgdl6XJfwpQP2W7Qh686O5LynlsPqHz+feExDOf0HxQ+n96CHBqNDrljjQOt8nfxd3fAy4iDLFcCCwlXIHH4u6rgROB4whNNHcDZ7v7nBjvMZrQ8XxF9B7vA1sBh7h7alPUG8Du0XNuAk5NeTzuZ1NRPO8TRiC9Rjip7AuUbaJL531mEjrj7zOz46oSk6THtJiLSM1iZucA57v7oUnHIvlLV/4iIgVIyV9EpACp2UdEpADpyl9EpABVm1Kq2223nbdu3TrpMEREqpXp06d/5e7Nyu6vNsm/devWTJs2LekwRESqFTObW95+NfuIiBQgJX8RkQKk5C8iUoCU/EVEClBOk7+Z/TtaFWl2mf2XmNmH0UpGt+YyBhER2Viur/yHEar1/cTMuhAKcu3n7nsDf8nFgW+9FUpKNtxXUhL2i4gUupwmf3efDJStyPj/CCsZrYqesygXx+7YEU47bf0JoKQkbHfsmIujiYhUL0m0+e9BWN7vDTObZGY5ScddusCYMdCrFxx3XEj8Y8aE/SIihS6J5F+HsJJTZ0L99TFlVhz6iZn1N7NpZjZt8eLFsQ/UpQvssgs8/zxccIESv4hIqSSS/wJgXLRQx5uEhbDLXe/T3Ye6e5G7FzVrttHs5EqVlMC8eeHnu+7auA9ARKRQJZH8nwCOAjCzPYAt2HDh6awobeMfOxZ22AH23XfDPgARkUKW66GeowjLu7U1swVmdh5hubw20fDPR4B+noO60m+9Fdr4jz4a+vSBN9+Ef/0r7BcRKXTVpp5/UVGRZ1rYbcYMOPBA+Oc/4cILsxyYiEgeM7Pp7l5Udn9BzPBt3x7atYOHH046EhGR/FAQyd8MiothyhT45JOkoxERSV5BJH+AM88M9yNHJhuHiEg+KJjk37o1HHZYaPqpJt0cIiI5UzDJH0LTz5w5oQNYRKSQFVTy790btthCHb8iIgWV/Js0gR49YNQoWLMm6WhERJJTUMkfQtPPl1/Ciy8mHYmISHIKLvl37w6NG8NDDyUdiYhIcgou+derF2r8PP44fP990tGIiCSj4JI/hKafFSvgiSeSjkREJBkFmfwPOSTU+deoHxEpVAWZ/GvVgrPOgokT4Ysvko5GRGTzK8jkDyH5r1sHjzySdCQiIptfwSb/vfaCDh3U9CMihalgkz9A374wfTp88EHSkYiIbF4FnfzPOCO0/48YkXQkIiKbV0En/x12gG7dQvJfty7paERENp+CTv4Qxvx/+ilMnZp0JCIim0/BJ/9evaB+fZV7EJHCUvDJv0EDOOkkGDMGVq1KOhoRkc0jp8nfzP5tZovMbHY5j11pZm5m2+UyhnQUF8M338CzzyYdiYjI5pHrK/9hwLFld5rZzkA3YF6Oj5+Wo4+G5s015l9ECkdOk7+7TwaWlPPQ34ABQF6splunDvTpA08/DUuXJh2NiEjubfY2fzM7EfjM3Wdu7mNXpLgYVq+GsWOTjkREJPc2a/I3s/rAtcB1aT6/v5lNM7NpixcvzmlsBx4Ibduq6UdECsPmvvLfDdgVmGlmnwItgRlmtkN5T3b3oe5e5O5FzZo1y2lgZqHcw+TJMHduTg8lIpK4zZr83X2Wuzd399bu3hpYAHRw97worHzmmeF+5Mhk4xARybVcD/UcBbwGtDWzBWZ2Xi6PV1W77gqHHhomfHledEWLiORGrkf79HH3Hd29rru3dPf7yzze2t2/ymUMcRUXhyqf77yTdCQiIrmTdvI3s8vMrJEF95vZDDM7JpfBJaF3b6hbV+UeRKRmi3Plf667fwccAzQDfgkMzklUCWraFI4/HkaNgjVrko5GRCQ34iR/i+67Aw9E4/StgudXW8XFYW3fl15KOhIRkdyIk/ynm9kEQvJ/wcwaAjWyCv7xx8M222jMv4jUXHGS/3nA1UBHd18BbEFo+qlxttwytP2PGwfLlycdjYhI9sVJ/g7sBVwabW8NbJn1iPJEcXFI/OPHJx2JiEj2xUn+dwMHAX2i7WXAXVmPKE8cdhi0aqWmHxGpmeIk/07ufhGwEsDdlxKafmqkWrXgrLNgwgT48sukoxERya44yf9HM6tNVIbZzJpRQzt8SxUXw9q1MHp00pGIiGRXnOR/B/A40NzMbgKmAINyElWe2GsvaN9eTT8iUvOknfzdfQRhAZabgYVAL3d/NFeB5YviYnjrLfjww6QjERHJnjjlHToTFmG5y93vBBaYWafchZYfzjgjtP+PGJF0JCIi2ROn2ece4PuU7eXRvhqtRQvo2jU0/ajSp4jUFLHKO7ivT3/uvg6ok/2Q8k9xMXzyCUydmnQkIiLZESf5/8/MLjWzutHtMuB/uQosn5x0Emy1lTp+RaTmiJP8fwUcDHxGWIGrE9A/F0Hlm4YNoVevMORz9eqkoxERqbo4o30WufsZ0TKM27v7me6+KJfB5ZO+fWHpUnjuuaQjERGpurTb7KNJXRcArVNf5+7nZj+s/NOtGzRrFpp+evZMOhoRkaqJ02E7HngF+D9gbW7CyV916kCfPnDvvfDNN9C4cdIRiYhkLk6bf313/527j3H3x0pvOYssDxUXw6pV8FhB/dYiUhPFSf5Pm1n3nEVSDRQVwR57aNSPiFR/cZL/ZYQTwA9m9p2ZLTOz73IVWD4yC1f/L78M8+YlHY2ISObijPZp6O613H0rd28UbTeq6DVm9m8zW2Rms1P23WZmc8zsXTN73MyqVev5WWeF+1Gjko1DRKQq4lz5Y2ZNzOznZnZ46a2SlwwDji2zbyKwj7vvB3wEXBMnhqS1aQMHHwwPPaRyDyJSfcUp7HY+MBl4Abghur++ote4+2RgSZl9E9x9TbT5OtAyRrx5obgY3nsPZs5MOhIRkczEbfPvCMx19y5Ae2BxFY9/LrDJaVNm1t/MppnZtMWLq3qo7DntNKhbVx2/IlJ9xUn+K919JYCZ1XP3OUDbTA9sZtcCa4BNFkt296HuXuTuRc2aNcv0UFm37bbQvTuMHBlW+hIRqW7iJP8FUefsE8BEMxsPfJ7JQc2sH9ADOCu1Umh1ceutcMABsHAhlJSEfSUlYb+ISHWQ9gxfdz8p+vF6MysBtqGCJptNMbNjgd8BR7j7irivzwcdO4amn/r1Q9NP7dphe8yYpCMTEUlPnA7fh0p/dvdJ7v4k8O9KXjMKeA1oa2YLzOw84E6gIeHbwztm9s/MQk9Oly4h0a9bF5p+evcO2126JB2ZiEh64tT22Tt1w8xqAwdW9AJ371PO7vtjHDNvdekSav088ECo+9Oy2o1ZEpFCVumVv5ldY2bLgP2imb3fRduLCMXeClJJCTz1VFjjd9Ei2H9/1fwRkeqj0uTv7je7e0Pgtmhmb+ns3m3dvVpN0MqWkpL1bfyjRoXF3X/8EU49Fa64Qgu+iEj+i1vYbWsAMys2s9vNbJccxZXX3nprwzb+Pn3gmWfCzN+//x2OPBLmz080RBGRCsVJ/vcAK8xsf2AAMBd4MCdR5bkBAzbu3D3mGHj11XBSmDUL2reHF15IJj4RkcrESf5rojH5PYEh7j6EMGpHUvTuDdOnQ4sWcNxxcN11mggmIvknTvJfZmbXAMXAM9Fon7q5Cat622MPeP116NcPbrwRfvGL0CksIpIv4iT/04FVwHnu/gWwE3BbTqKqAerXD8NA778/NAe1bw9TpiQdlYhIEKee/xfufru7vxJtz3P3gmzzj+Pcc8O3gPr1Q0fwbbepFLSIJC+dcf5TovtlKeP8C3Ilr0ztvz9Mmwa9eoXO4pNOCovAi4gkJZ1x/odG9w1TxvmntZKXrLfNNvDoo2Eo6DPPQIcOoWNYRCQJ6Vz5N63otjmCrCnM4LLL4JVXYM2aMC/g3nvVDCQim186bf7TgWnR/WLC0osfRz/r2jUDnTvDjBlhrsCvfgV9+8L33ycdlYgUknSafXZ19zaEZRtPcPft3H1bQj3+cbkOsKbabjt49tkwFHTUKPj5z+H995OOSkQKRZyhnh3d/dnSDXd/Djgi+yEVjlq1YOBAmDABvv46rBMwcmTSUYlIIYiT/L8ys4Fm1trMdomWYfw6V4EVkq5d4e234cAD4ayzQrNQ2dIQWilMRLIpTvLvAzQDHo9uzaJ9kgUtWsBLL4WhoG+8AT16rP8WUFpFtGPHZGMUkZrDsrWErpn9w90vycqblaOoqMinTZuWq7fPK08+CWeeCStWwMknw6RJWilMRDJjZtPdvajs/jhX/pU5JIvvVdBOPDFUBt1hh7BATOPG0Lp10lGJSE2SzeQvWfTpp2GBmG7d4D//gT33hMGDwz4RkapS8s9DqSuFTZgAjzwS9l9zjQrEiUh2ZDP5Wxbfq6CVXSns9NPh+edDiehly+Cww+D888PwUBGRTGQz+Q8pu8PM/m1mi8xsdsq+pmY20cw+ju6bZDGGGqG8lcK6dIFhw8JEsKuuCj/vuScMH67yECISX6WjfczsKWCTT3L3Eyt47eHA98CD7r5PtO9WYIm7Dzazq4Em7v67ygItpNE+6Xj33VAa4rXX4Igj4J57oF27pKMSkXxTldE+fwH+CnwC/ADcF92+B2ZX8DrcfTKwpMzunsDw6OfhQK80YpAy9tsvtP0PHQozZ4ay0QMHwg8/JB2ZiFQH6dT2meTuk4D27n66uz8V3c4EDs3gmNu7+8LovRcCzTf1RDPrb2bTzGza4sWLMzhUzVarFlxwAXz4YegXuOkm2Hff0EksIlKROG3+zcysTemGme1KmOWbM+4+1N2L3L2oWbOcHqpaa94cHnoIXnwRatcOawafcQYsXJh0ZCKSr+Ik/yuAl83sZTN7GSgBLs/gmF+a2Y4A0b2WNs+So44KfQE33ABPPBE6hO+6C9auTToyEck3cdbwfR7YHbgsurV19xcqflW5ngT6RT/3A8Zn8B6yCfXqwXXXhRnCHTvCxRfDQQeFwnEiIqXSTv5mVh+4CrjY3WcCrcysRyWvGQW8BrQ1swVmdh4wGOhmZh8D3aJtybLdd4eJE2HECJg7F4qK4IorwjwBEZE4zT4PAKuBg6LtBcCfK3qBu/dx9x3dva67t3T3+939a3fv6u67R/dlRwNJlpiFAnFz5kD//jBkCLRsGZqFUkf4qly0SOGJk/x3c/dbgR8B3P0HNKu3WmjSJMwDmDo1rCB2/fVh/eBPP1W5aJFCVSfGc1eb2VZEE77MbDdgVU6ikpzo3DkMC73kEvjnP0PTUL16oXNY5aJFCkucK/8/As8DO5vZCOBFYEBOopKcqVMnfAu49FJYswaWLw/lJKZPTzoyEdmc0kr+ZmbAHOBk4BxgFFDk7i/nLDLJmZKSsErYwIHQsGFo/vn5z+G3vw0nAxGp+dJK/h4KAD0RddY+4+5Pu/tXOY5NciC1XPSNN8L48WGmcPfucPvtsPfeoYKoiNRscZp9XjczdQtWc2XLRXfpAo8+GspET54MW20Fxx0XFpJfpOl3IjVW2mv4mtn7wB7AXGA5YaSPu/t+uQtvPVX13DxWrYKbb4ZBg6BBA/jrX+Gcc8KwURGpfrKxhu9xwG7AUcAJQI/oXmqQevXCUNCZM0MT0LnnQteu8PHHSUcmItkUp7zDXHefSyjr7Ck3qYHatYNJk8KQ0OnTQ7XQQYO0hrBITRGnvMOJUUmGT4BJwKfAczmKS/JArVpw4YXwwQdwwglw7bXQoQO8/nrSkYlIVcVp9rkR6Ax85O67Al2BV3MSleSVFi1Cp/D48bB0aZgdfMkl8N13SUcmIpmKk/x/dPevgVpmVsvdS4ADchSX5KETTwxrCF98cSgVvdde8OSTSUclIpmIk/y/MbMGwGRghJkNAdbkJizJV40awR13hLWDmzaFnj3h1FO1cIxIdRMn+fckdPZeQSjz8F802qdgdeoUOoIHDYKnnw4dxPfeC+vWJR2ZiKQjzmif5e6+1t3XuPtwd78jagaSAlW3LlxzTVg45sAD4Ve/gjZt4IEHNnyeSkaL5J84o32Wmdl30W2lma01M3X5CbvvDv/3fyHpL1kS5gacfTasXKmS0SL5Ku2Szu7eMHXbzHoBP896RFItmYWZwN27hwVkHnoIxo0Lj40apZLRIvkmTpv/Btz9CcJsX5GfNG8evgWcfXaoELp8ORQXw+9/D19+mXR0IlIqTrPPySm3U81sMJrhK+UoKYFnn4U//AEaN4b27WHwYGjdGi66CD75JOkIRSTOlf8JKbdfAMsII4BEfpJaMvpPfwpNP++9B8OHh28A990X+giKi0NHsYgkI85on1+m3C5w95vcXUV/ZQPllYweMybMA7jvvnDVf/nlYbbwfvtBjx7wquaJi2x2cUo631HR4+5+aawDm10BnE9oOpoF/NLdV27q+SrpXLMsWQJ33w1DhsBXX8Ghh8LVV4cOY5WPFsmebJR03hLoAHwc3Q4A1gLTo1ucYHYCLiUsBbkPUBs4I857SPXWtGlYRnLu3DBjeN688C1g//3DEpNrNHdcJKfiJP/dgS7u/g93/wehsNsB0YSv4Rkcuw6wlZnVAeoDn2fwHlLN1a8fisT95z+hX2Dt2rCK2B57hIXmV27yu6CIVEWc5N8CSB3r3yDaF5u7fwb8BZgHLAS+dfcJZZ9nZv3NbJqZTVu8eHEmh5Jqom7dMDx01ix44okwZPTXvw4jhAYPhm+/TTpCkZolTvIfDLxtZsPMbBgwAxiUyUHNrAlhpNCuhBPI1mZWXPZ57j7U3YvcvahZs2aZHEqqmVq1QrG4114LI4cOOCCUkGjVKnQeP/bYhs9X6QiRzMQZ7fMA0Al4PLodlGFzD8DRwCfuvtjdfwTGAQdn+F5SA5nBkUfC88+HAnLHHgsvvxwqiPbsGUYNqXSESObiTPI6BFjm7uMJzT8DzGyXDI87D+hsZvXNzAj9Bx9k+F5Sw3XoAKNHw0cfwfHHhzUEdtstjAy66y6VjhDJRJxmn3uAFWa2P3AVMBd4MJODuvsbwFhC09GsKI6hmbyXFI7ddw/loy+/HNxh9erQT3D55SodIRJXnOS/xsOkgJ7AHe4+hA07gGNx9z+6+57uvo+793X3VZm+lxSOkhJ4+OH1pSOOOgruvDOUkr7mmjB/QEQqFyf5LzOza4Bi4Bkzqw3UzU1YIhsrWzpi7Ngwo/iBB6BXL7jlFth1V7jhBq0vLFKZOMn/dGAVcJ67fwHsBNyWk6hEylFR6YgRI+Ddd+Hoo+H668NJ4NZbQ1VREdlY2uUdKn0js9fc/aCsvFk5VN5B0jV9emgWeu452H57uPZa6N8f6tVLOjKRzS8b5R0qs2UW30skYwceGEpKT5kS1ha+9NLQWXzfffDjj0lHJ5Ifspn8Vdtf8sohh8BLL4XFZVq0CFf/7dqFDuO1a5OOTiRZ2Uz+InnHDLp2DTOGn3oKGjSAvn1DOenHHoN165KOUCQZlSZ/M0u3pVSFeCVvmYWqoTNmhE7idevCbOGiotBElKWuL5FqI50r/9cAzOyhSp7Xt+rhiORWrVrQuzfMng0PPhgKxh1/fFhP4MILw3DSVKodJDVVOsl/CzPrBxxcZh3fk83s5NInufvs3IUpkl21a4fmnzlz4N57w3oCQ4fCL34RJo2BagdJzVbpUE8zOxQ4CzgNeLLMw+7u5+Yotg1oqKfk0sqV4SRw/fXwzTehs/jDDzecVyBSHW1qqGecZRzPc/f7sx5ZmpT8ZXNYvjw0Ab3zDuy7L0ybBltskXRUIpnLxjj/h8zsUjMbG90uMTOVd5Aa5c03YcGCUE561izo3FkLyUjNFCf53w0cGN3fTVjP955cBCWShNTaQSUlYUH5t98OC8rMn590dCLZVSfGczu6+/4p2y+Z2cxsBySSlLK1g26+GbbdNpSHOOigMCR0v/2SjVEkW+Jc+a81s91KN8ysDaB5klJjDBiwcefulVeGkwKEvoCJEzd/XCK5ECf5XwWUmNnLZjYJeAn4bW7CEskf++0Hr78eFpPv3h2GZ7p4qUgeSbvZx91fNLPdgbaE2bxzUhdgMbNu7q7rIqmRWraEV16BU06Bc84J8wIGDgwzh0Wqo1i1fdx9lbu/6+4zy1l565YsxiWSd7bZJrT7n302XHddKBSnKqFSXcXp8K2MroGkxttiCxg2DFq1gj//OQwLHTMGGma8oKlIMlTSWSQmM7jxxlAOYuJEOOKIsJqYSHWiks4iGbrgglAm+qOPwlDQ999POiKR9GUz+X8a58lm1jiaKTzHzD4ws5wtASmSK8cdB5Mnw6pVoR7QpElJRySSnrTb/M2sNnA80Dr1de5+e3R/cvmv3KQhwPPufqqZbQHUj/l6kbzQoUNYLKZ7dzjmmDAU9Iwzko5KpGJxOnyfAlYCs4AqrX9kZo2Aw4FzANx9NbC6Ku8pkqTWreHVV6FXL+jTJwwFveoqDQWV/BUn+bd092xNbm8DLAYeMLP9genAZe6+PPVJZtYf6A/QqlWrLB1aJDeaNIEXXgjzAH73O5g7F+64I6wdIJJv4rT5P2dmx2TpuHWICsO5e3tgOXB12Se5+1B3L3L3ombNmmXp0CK5s+WWMHJkuOq/+244+WRYsSLpqEQ2Fif5vw48bmY/mNl3ZrbMzL7L8LgLgAXu/ka0PZZwMhCp9mrVCks/3nknPP10qBe0aFHSUYlsKE7y/ytwEFDf3Ru5e0N3b5TJQd39C2C+mbWNdnUFNFBOapSLLoJx48K6AO3awUNlVsHW+sCSpDjJ/2Ngtqe79FflLgFGmNm7wAHAoCy9r0je6NkzJPk1a6BfP60PLPkjTofvQuBlM3sO+KmuT+lQz7jc/R1go6XFRGqaTp1g+vQwE/iSS+CZZ0KZ6Ecf1frAkpw4yf+T6LZFdBORNP3sZzBzZpgT8PzzoV9gyBD46ivo0QO22irpCKXQxG7BBhkAAAxkSURBVCnpfEMuAxGp6WbNgh9+gPPPhxEjYMoUGD8eGjQIo4LOPBO6doU62Sy3KLIJcWb4llBO8TZ3PyqrEYnUQKnrA3fpEhL9aafBX/8KH3wAY8fCgw9Cs2Zw+unh8c6dNUlMcidOh++VhNW8rgL+ALwDTMtFUCI1Tdn1gbt0Cdtr1sB998EXX8ATT4T9//oXHHwwtGkT1g9+771kY5eayaoyeMfMJrn7EVmMZ5OKiop82jSda6Tm++670Bw0cmQoGb12bVhK8swzQ82gXXZJOkKpTsxsurtvNLgm7St/M2uactvOzI4FdshqlCJCo0bQty889xx89hn84x+w9dZw9dWhhtBhh8E994TOYghzBUpKNnwPzSGQysRp9plOaOaZBkwFfgOcl4ugRCTYfnu4+GKYOhX++1+46SZYsgR+/WvYcUc4/nj49lvo3Xv9CUBzCCQdlTb7mFlHYH40Kxcz6wecQqjff727L8l1kKBmH5FS7mHk0MiR4TZ/PtSrFx7r1QtefHHD/gUpbFVp9rmXqNyymR0O3AwMB74FhmYzSBGpnFnoAxg8GD79FF55BX75y7B/9OhQSO6pp+Ddd5OOVPJZOsm/dsrV/enAUHd/zN3/APwsd6GJSGVq1YJDDw3NPA0ahPs1a0Ip6f33D5PKhgyBxYuTjlTyTVrJ38xK5wN0BV5KeUzTUUQSljqHYPToMIO4ceNQSqJWLbj8cmjRAk46KQwnXa1lk4T0kv8oYJKZjQd+AF4BMLOfEZp+RCRB5c0hePRRaNkSpk0L/QOXXx6WmjzpJNhpp7D9zjvJxi3JSmucv5l1BnYEJpSutmVmewAN3H1GbkMM1OErUjVr1oSVxoYPD/MIVq8OTUP9+sFZZ0Hz5klHKLmwqQ7fKk3y2pyU/EWyZ8kSeOQRGDYsfHOoUycsQN+vXyg0t4VKN9YYVZ7kJSI1R9OmYa7Am2+G8hG/+U04CZxySugfuPRSmDEjDCvVJLKaSclfpMDttRfccgvMmwfPPgtHHw1Dh8KBB4YhpZ98AqeeqklkNY2afURkI0uXhpFDw4fD66+HUUN16kC3bmG28aOPhvLTkv/U5i8iGZkzJ5wE7roLli0L+5o2hUMOCXWGDj00zCconWUs+UVt/iKSkT33hGOOCcn9oovCZLJOneDDD2HAgFB+unHjsEzltdeGgnTffJN01FIZTdISkQqVXYjmlFPWb++9N7z6aliVbMqU0Ak8aFAoNbHvvuFbQelt552T/k0klZp9RKRCt94aOndTC8WVlITRQQMGbPjc5cvDCKLSk8HUqfD99+GxVq02PBnsvTf85S/pv7dkJi/b/M2sNqFE9Gfu3qOi5yr5i1Q/a9aEAnOlJ4MpU2DhwvBY48bQtm2YgTxoEFx4YZiFnPotQ6ouX5P/b4AioJGSv0jN5x6GjqaeDD74IDxWq1a4nXJKmHF88MGw7bbJxlsT5F3yN7OWhNLQNwG/UfIXKUxffRU6kseMCXWHFi2CH38Mj+2114ZNRa1ba1H7uDaV/JPs8P07MABouKknmFl/oD9Aq1atNlNYIrI5zZoFL70Ef/hDWJ7yySehfv313wweeSRMOoMw+zj1ZLDfflC7drLxV1eJJH8z6wEscvfpZnbkpp7n7kOJFowpKiqqHj3TIpK2siOJunRZv/3734fnrF0bSlCUngxeeSU8DtCwIRx00PqTQadO4cRRKk5ndaFJpNnHzG4G+gJrgC2BRsA4dy/e1GvU7CNS82SanOfN27DfYPbs0J9Qp04oS1F6MnCH/v3Xn1zKnmwKQd61+f8UQLjyv1Jt/iKSqaVLw0ih0pPBm2/CqlXhsZYtQ79Cz56Fub5xPrb5i4hkRZMmoSR19+5he9UqmD59/clgwoRQq6hePXjwwbCWwVFHQd26ycadpMSv/NOlK38RyURpU0+3bjBuXOggXrEiDCM99VQ4/XQ4/PCa23Gs2j4iUnBS2/hHjgx1h+rXhxtvDPWKHn44fANo2TKsYTB1Kqxbl3TUm4eSv4jUWOWtbzxmTFipbOTIMKdgzJgwoWzo0FCptHVruPLKsP5xNWkYyYiafUREgO++C3MMRo8Oax3/+CPstltoFjr99FCorjpOMFOzj4hIBRo1guJieOop+PJLuP/+kPxvuSUsdL/33nDDDWF9A6j+y1sq+YuIlNGkCZx7bvgGsHBhmHncvHlI/u3awQEHwEcfVe/lLdXsIyKSps8/h7FjQ8mJ114L++rUCSuavf12aDI65phkYywrbyd5pUvJX0Tyydy5obP4b39bX6Z6q61CuYkjjgjDRzt1CvuSpDZ/EZEs2mUXKCoKHcO/+U3oMzjuOFiyBK6/Powsatw4nAQGDoSJE8NiN/lCM3xFRDJQtk5Qjx7rtw84ICxvOWkSTJ4MgwfDTTetrz10xBHhdsghsM02ycSvZh8RkQzEKUq3bFmYQFZ6MnjzzfCNoVatcKIobSY67LAw8zib1UjV5i8ikidWrIDXXw8ngkmTws8rV4bH9t0X2rQJaxw88EBY2awq1UiV/EVE8tSqVeGqftKkcJs6dX3/wLbbhpITjz2WWTVSdfiKiOSpevXC+gPXXhsqkC5dGr4NdO0KX38d5hxkuwy1kr+ISJ6pWzc0Dc2cGZa3HD5849nEVaXkLyKSZ1Lb+P/0p3B/2mnZPQEo+YuI5JlNVSN9663sHUMdviIiNZg6fEVE5CdK/iIiBUjJX0SkACn5i4gUICV/EZECVG1G+5jZYmBu0nGUYzvgq6SDyJBiT4ZiT0Z1jb2qce/i7s3K7qw2yT9fmdm08oZRVQeKPRmKPRnVNfZcxa1mHxGRAqTkLyJSgJT8q25o0gFUgWJPhmJPRnWNPSdxq81fRKQA6cpfRKQAKfmLiBQgJf8MmdnOZlZiZh+Y2XtmdlnSMcVlZrXN7G0zezrpWOIws8ZmNtbM5kSf/0FJx5QOM7si+r8y28xGmdmWScdUETP7t5ktMrPZKfuamtlEM/s4um+SZIzl2UTct0X/X941s8fNrHGSMW5KebGnPHalmbmZbZeNYyn5Z24N8Ft3bwd0Bi4ys70Sjimuy4APkg4iA0OA5919T2B/qsHvYGY7AZcCRe6+D1AbOCPZqCo1DDi2zL6rgRfdfXfgxWg73wxj47gnAvu4+37AR8A1mzuoNA1j49gxs52BbsC8bB1IyT9D7r7Q3WdEPy8jJKCdko0qfWbWEjge+FfSscRhZo2Aw4H7Adx9tbt/k2xUaasDbGVmdYD6wOcJx1Mhd58MLCmzuycwPPp5ONBrswaVhvLidvcJ7r4m2nwdaLnZA0vDJj5zgL8BA4CsjdBR8s8CM2sNtAfeSDaSWP5O+M+0LulAYmoDLAYeiJqs/mVmWycdVGXc/TPgL4Qrt4XAt+4+IdmoMrK9uy+EcAEENE84nkycCzyXdBDpMrMTgc/cfWY231fJv4rMrAHwGHC5u3+XdDzpMLMewCJ3n550LBmoA3QA7nH39sBy8rPpYQNR23hPYFegBbC1mRUnG1XhMbNrCU22I5KOJR1mVh+4Frgu2++t5F8FZlaXkPhHuPu4pOOJ4RDgRDP7FHgEOMrMHk42pLQtABa4e+m3rLGEk0G+Oxr4xN0Xu/uPwDjg4IRjysSXZrYjQHS/KOF40mZm/YAewFlefSY47Ua4YJgZ/b22BGaY2Q5VfWMl/wyZmRHanT9w99uTjicOd7/G3Vu6e2tCp+NL7l4trkLd/Qtgvpm1jXZ1Bd5PMKR0zQM6m1n96P9OV6pBR3U5ngT6RT/3A8YnGEvazOxY4HfAie6+Iul40uXus9y9ubu3jv5eFwAdor+DKlHyz9whQF/CVfM70a170kEViEuAEWb2LnAAMCjheCoVfVMZC8wAZhH+9vK63ICZjQJeA9qa2QIzOw8YDHQzs48Jo08GJxljeTYR951AQ2Bi9Lf6z0SD3IRNxJ6bY1Wfbz8iIpItuvIXESlASv4iIgVIyV9EpAAp+YuIFCAlfxGRAqTkL5IhM2tdXvVFkepAyV9EpAAp+YtkgZm1iQrNdUw6FpF0KPmLVFFUauIx4Jfu/lbS8Yiko07SAYhUc80I9W1Ocff3kg5GJF268hepmm+B+YRaTyLVhq78RapmNWE1qxfM7Ht3H5l0QCLpUPIXqSJ3Xx4tkDPRzJa7e7UocyyFTVU9RUQKkNr8RUQKkJK/iEgBUvIXESlASv4iIgVIyV9EpAAp+YuIFCAlfxGRAvT/AaS6J8ERqqKtAAAAAElFTkSuQmCC\n",
"text/plain": [
"<Figure size 432x288 with 1 Axes>"
]
},
"metadata": {
"needs_background": "light"
},
"output_type": "display_data"
}
],
"source": [
"plt.plot(K, Sum_of_squared_distances, 'bx-')\n",
"plt.xlabel('k')\n",
"plt.ylabel('Sum_of_squared_distances')\n",
"plt.title('Elbow Method For Optimal k')\n",
"plt.show()"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### In this case, the elbow point is k=8, and we run the run k-means to cluster the neighborhood into 8 clusters.\n"
]
},
{
"cell_type": "code",
"execution_count": 180,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"array([1, 1, 1, 1, 2, 1, 3, 1, 3, 1, 1, 4, 0, 1, 7], dtype=int32)"
]
},
"execution_count": 180,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"obj = KMeans(n_clusters=8, random_state=0).fit(british_columbia_clustering)\n",
"\n",
"obj.labels_[0:15] "
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Now, we create a new dataframe that includes the cluster as well as the top 10 venues for each neighborhood.\n"
]
},
{
"cell_type": "code",
"execution_count": 187,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Cluster Labels</th>\n",
" <th>Neighborhood</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>1</td>\n",
" <td>Abbotsford</td>\n",
" <td>Grocery Store</td>\n",
" <td>Trail</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>1</td>\n",
" <td>Burnaby</td>\n",
" <td>Bus Stop</td>\n",
" <td>Bookstore</td>\n",
" <td>Snack Place</td>\n",
" <td>Park</td>\n",
" <td>Bus Station</td>\n",
" <td>Burger Joint</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>1</td>\n",
" <td>Comox</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Pharmacy</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Juice Bar</td>\n",
" <td>Elementary School</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>1</td>\n",
" <td>Coquitlam</td>\n",
" <td>Asian Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Golf Course</td>\n",
" <td>Gas Station</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>2</td>\n",
" <td>Cranbrook</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Cluster Labels Neighborhood 1st Most Common Venue \\\n",
"0 1 Abbotsford Grocery Store \n",
"1 1 Burnaby Bus Stop \n",
"2 1 Comox Fast Food Restaurant \n",
"3 1 Coquitlam Asian Restaurant \n",
"4 2 Cranbrook Construction & Landscaping \n",
"\n",
" 2nd Most Common Venue 3rd Most Common Venue 4th Most Common Venue \\\n",
"0 Trail Falafel Restaurant Coffee Shop \n",
"1 Bookstore Snack Place Park \n",
"2 Coffee Shop Pharmacy Sandwich Place \n",
"3 Convenience Store Golf Course Gas Station \n",
"4 Zoo Fast Food Restaurant Convenience Store \n",
"\n",
" 5th Most Common Venue 6th Most Common Venue \\\n",
"0 Construction & Landscaping Convenience Store \n",
"1 Bus Station Burger Joint \n",
"2 Juice Bar Elementary School \n",
"3 Coffee Shop Zoo \n",
"4 Dessert Shop Dim Sum Restaurant \n",
"\n",
" 7th Most Common Venue 8th Most Common Venue 9th Most Common Venue \\\n",
"0 Dessert Shop Dim Sum Restaurant Dog Run \n",
"1 Sandwich Place Coffee Shop Fast Food Restaurant \n",
"2 Construction & Landscaping Convenience Store Dessert Shop \n",
"3 Falafel Restaurant Dessert Shop Dim Sum Restaurant \n",
"4 Dog Run Elementary School Falafel Restaurant \n",
"\n",
" 10th Most Common Venue \n",
"0 Elementary School \n",
"1 Falafel Restaurant \n",
"2 Dim Sum Restaurant \n",
"3 Dog Run \n",
"4 Fish & Chips Shop "
]
},
"execution_count": 187,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"#neigh_top_venues.insert(0, 'Cluster Labels', obj.labels_)\n",
"neigh_top_venues['Cluster Labels'] = obj.labels_\n",
"neigh_top_venues.head()"
]
},
{
"cell_type": "code",
"execution_count": 188,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Province</th>\n",
" <th>Latitude</th>\n",
" <th>Longitude</th>\n",
" <th>Cluster Labels</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford</td>\n",
" <td>V3G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.0625</td>\n",
" <td>-122.3125</td>\n",
" <td>1.0</td>\n",
" <td>Grocery Store</td>\n",
" <td>Trail</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Atlin Region</td>\n",
" <td>V0W</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>59.6250</td>\n",
" <td>-133.5000</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Burnaby</td>\n",
" <td>V3N</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.2500</td>\n",
" <td>-123.0000</td>\n",
" <td>1.0</td>\n",
" <td>Bus Stop</td>\n",
" <td>Bookstore</td>\n",
" <td>Snack Place</td>\n",
" <td>Park</td>\n",
" <td>Bus Station</td>\n",
" <td>Burger Joint</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Campbell River Central</td>\n",
" <td>V9W</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.0000</td>\n",
" <td>-125.5625</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Cariboo and West Okanagan</td>\n",
" <td>V0K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>51.4375</td>\n",
" <td>-121.6250</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" <td>NaN</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place Code Country Province Latitude \\\n",
"0 Abbotsford V3G Canada British Columbia 49.0625 \n",
"1 Atlin Region V0W Canada British Columbia 59.6250 \n",
"2 Burnaby V3N Canada British Columbia 49.2500 \n",
"3 Campbell River Central V9W Canada British Columbia 50.0000 \n",
"4 Cariboo and West Okanagan V0K Canada British Columbia 51.4375 \n",
"\n",
" Longitude Cluster Labels 1st Most Common Venue 2nd Most Common Venue \\\n",
"0 -122.3125 1.0 Grocery Store Trail \n",
"1 -133.5000 NaN NaN NaN \n",
"2 -123.0000 1.0 Bus Stop Bookstore \n",
"3 -125.5625 NaN NaN NaN \n",
"4 -121.6250 NaN NaN NaN \n",
"\n",
" 3rd Most Common Venue 4th Most Common Venue 5th Most Common Venue \\\n",
"0 Falafel Restaurant Coffee Shop Construction & Landscaping \n",
"1 NaN NaN NaN \n",
"2 Snack Place Park Bus Station \n",
"3 NaN NaN NaN \n",
"4 NaN NaN NaN \n",
"\n",
" 6th Most Common Venue 7th Most Common Venue 8th Most Common Venue \\\n",
"0 Convenience Store Dessert Shop Dim Sum Restaurant \n",
"1 NaN NaN NaN \n",
"2 Burger Joint Sandwich Place Coffee Shop \n",
"3 NaN NaN NaN \n",
"4 NaN NaN NaN \n",
"\n",
" 9th Most Common Venue 10th Most Common Venue \n",
"0 Dog Run Elementary School \n",
"1 NaN NaN \n",
"2 Fast Food Restaurant Falafel Restaurant \n",
"3 NaN NaN \n",
"4 NaN NaN "
]
},
"execution_count": 188,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"clustered_df = df_new\n",
"clustered_df = clustered_df.join(neigh_top_venues.set_index('Neighborhood'), on='Place')\n",
"clustered_df.head()"
]
},
{
"cell_type": "code",
"execution_count": 189,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(72, 6)\n"
]
}
],
"source": [
"clustered_df.dropna(subset = [\"Cluster Labels\"], inplace=True)\n",
"print(df_new.shape)\n",
"clustered_df = clustered_df.astype({\"Cluster Labels\": int})"
]
},
{
"cell_type": "code",
"execution_count": 190,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>Code</th>\n",
" <th>Country</th>\n",
" <th>Province</th>\n",
" <th>Latitude</th>\n",
" <th>Longitude</th>\n",
" <th>Cluster Labels</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford</td>\n",
" <td>V3G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.06250</td>\n",
" <td>-122.3125</td>\n",
" <td>1</td>\n",
" <td>Grocery Store</td>\n",
" <td>Trail</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Burnaby</td>\n",
" <td>V3N</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.25000</td>\n",
" <td>-123.0000</td>\n",
" <td>1</td>\n",
" <td>Bus Stop</td>\n",
" <td>Bookstore</td>\n",
" <td>Snack Place</td>\n",
" <td>Park</td>\n",
" <td>Bus Station</td>\n",
" <td>Burger Joint</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Comox</td>\n",
" <td>V9M</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.68750</td>\n",
" <td>-124.9375</td>\n",
" <td>1</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Pharmacy</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Juice Bar</td>\n",
" <td>Elementary School</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Coquitlam</td>\n",
" <td>V3J</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.25000</td>\n",
" <td>-122.8750</td>\n",
" <td>1</td>\n",
" <td>Asian Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Golf Course</td>\n",
" <td>Gas Station</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Cranbrook</td>\n",
" <td>V1C</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.50000</td>\n",
" <td>-115.7500</td>\n",
" <td>2</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>5</th>\n",
" <td>Duncan</td>\n",
" <td>V9L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.78125</td>\n",
" <td>-123.6875</td>\n",
" <td>1</td>\n",
" <td>Convenience Store</td>\n",
" <td>Gas Station</td>\n",
" <td>Dog Run</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>6</th>\n",
" <td>Esquimalt</td>\n",
" <td>V9A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.43750</td>\n",
" <td>-123.4375</td>\n",
" <td>3</td>\n",
" <td>Boat or Ferry</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Zoo</td>\n",
" </tr>\n",
" <tr>\n",
" <th>7</th>\n",
" <td>Fort St. John</td>\n",
" <td>V1J</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>56.25000</td>\n",
" <td>-120.8750</td>\n",
" <td>1</td>\n",
" <td>American Restaurant</td>\n",
" <td>Gas Station</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>8</th>\n",
" <td>Highlands</td>\n",
" <td>V9B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.46875</td>\n",
" <td>-123.5000</td>\n",
" <td>3</td>\n",
" <td>Zoo</td>\n",
" <td>Theme Park</td>\n",
" <td>Boat or Ferry</td>\n",
" <td>Wine Shop</td>\n",
" <td>Auto Workshop</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>9</th>\n",
" <td>Kelowna Central</td>\n",
" <td>V1Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.90625</td>\n",
" <td>-119.4375</td>\n",
" <td>1</td>\n",
" <td>Park</td>\n",
" <td>Mountain</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>10</th>\n",
" <td>Kimberley</td>\n",
" <td>V1A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.68750</td>\n",
" <td>-116.0000</td>\n",
" <td>1</td>\n",
" <td>American Restaurant</td>\n",
" <td>Ski Lodge</td>\n",
" <td>Hotel</td>\n",
" <td>Ski Area</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>11</th>\n",
" <td>Kitimat</td>\n",
" <td>V8C</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>54.06250</td>\n",
" <td>-128.6250</td>\n",
" <td>4</td>\n",
" <td>Business Service</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>12</th>\n",
" <td>Langley City</td>\n",
" <td>V3A</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.09375</td>\n",
" <td>-122.5625</td>\n",
" <td>0</td>\n",
" <td>Baseball Field</td>\n",
" <td>Zoo</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>13</th>\n",
" <td>Nanaimo Central</td>\n",
" <td>V9S</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.18750</td>\n",
" <td>-124.0000</td>\n",
" <td>1</td>\n",
" <td>Tourist Information Center</td>\n",
" <td>Brewery</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>14</th>\n",
" <td>Nelson</td>\n",
" <td>V1L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.50000</td>\n",
" <td>-117.3125</td>\n",
" <td>7</td>\n",
" <td>Trail</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>15</th>\n",
" <td>New Westminster Northeast</td>\n",
" <td>V3L</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.18750</td>\n",
" <td>-122.8750</td>\n",
" <td>1</td>\n",
" <td>Hot Dog Joint</td>\n",
" <td>Garden</td>\n",
" <td>Playground</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>16</th>\n",
" <td>Oak Bay</td>\n",
" <td>V8R</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.43750</td>\n",
" <td>-123.3125</td>\n",
" <td>1</td>\n",
" <td>Gym</td>\n",
" <td>Bookstore</td>\n",
" <td>Gift Shop</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Men's Store</td>\n",
" <td>Breakfast Spot</td>\n",
" <td>Café</td>\n",
" <td>Bakery</td>\n",
" <td>Toy / Game Store</td>\n",
" <td>Bank</td>\n",
" </tr>\n",
" <tr>\n",
" <th>17</th>\n",
" <td>Parksville</td>\n",
" <td>V9P</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.31250</td>\n",
" <td>-124.3125</td>\n",
" <td>1</td>\n",
" <td>Bookstore</td>\n",
" <td>Home Service</td>\n",
" <td>Zoo</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>18</th>\n",
" <td>Pitt Meadows</td>\n",
" <td>V3Y</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.21875</td>\n",
" <td>-122.6875</td>\n",
" <td>1</td>\n",
" <td>Gym / Fitness Center</td>\n",
" <td>Plaza</td>\n",
" <td>Elementary School</td>\n",
" <td>Pub</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>19</th>\n",
" <td>Qualicum Beach</td>\n",
" <td>V9K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.34375</td>\n",
" <td>-124.4375</td>\n",
" <td>1</td>\n",
" <td>American Restaurant</td>\n",
" <td>Restaurant</td>\n",
" <td>Pharmacy</td>\n",
" <td>Grocery Store</td>\n",
" <td>Gastropub</td>\n",
" <td>Gas Station</td>\n",
" <td>Garden</td>\n",
" <td>Fried Chicken Joint</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>20</th>\n",
" <td>Richmond</td>\n",
" <td>V7B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.15625</td>\n",
" <td>-123.1250</td>\n",
" <td>1</td>\n",
" <td>Gym</td>\n",
" <td>Grocery Store</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Sushi Restaurant</td>\n",
" <td>Pizza Place</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Pub</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Indian Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>21</th>\n",
" <td>Saanich Central</td>\n",
" <td>V8Z</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.50000</td>\n",
" <td>-123.3750</td>\n",
" <td>6</td>\n",
" <td>Bank</td>\n",
" <td>Zoo</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>22</th>\n",
" <td>Salmon Arm</td>\n",
" <td>V1E</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.68750</td>\n",
" <td>-119.2500</td>\n",
" <td>2</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>23</th>\n",
" <td>Sooke</td>\n",
" <td>V9Z</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.37500</td>\n",
" <td>-123.7500</td>\n",
" <td>2</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>24</th>\n",
" <td>South Okanagan</td>\n",
" <td>V0H</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.40625</td>\n",
" <td>-119.0000</td>\n",
" <td>2</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>25</th>\n",
" <td>Surrey</td>\n",
" <td>V3Z</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.12500</td>\n",
" <td>-122.8125</td>\n",
" <td>1</td>\n",
" <td>Recreation Center</td>\n",
" <td>Auto Workshop</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>26</th>\n",
" <td>Terrace</td>\n",
" <td>V8G</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>54.53125</td>\n",
" <td>-128.6250</td>\n",
" <td>2</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>27</th>\n",
" <td>Trail</td>\n",
" <td>V1R</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.09375</td>\n",
" <td>-117.6875</td>\n",
" <td>5</td>\n",
" <td>Pub</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Zoo</td>\n",
" </tr>\n",
" <tr>\n",
" <th>28</th>\n",
" <td>Vancouver</td>\n",
" <td>V5K</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.25000</td>\n",
" <td>-123.1250</td>\n",
" <td>1</td>\n",
" <td>Bank</td>\n",
" <td>Sushi Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Park</td>\n",
" <td>Gym</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Greek Restaurant</td>\n",
" <td>Grocery Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Liquor Store</td>\n",
" </tr>\n",
" <tr>\n",
" <th>29</th>\n",
" <td>Victoria Central British Columbia Provincial G...</td>\n",
" <td>V8W</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>48.43750</td>\n",
" <td>-123.3750</td>\n",
" <td>1</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Brewery</td>\n",
" <td>Restaurant</td>\n",
" <td>Motorcycle Shop</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Gym</td>\n",
" <td>Gastropub</td>\n",
" <td>Fried Chicken Joint</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>30</th>\n",
" <td>Whistler</td>\n",
" <td>V8E</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>50.12500</td>\n",
" <td>-122.9375</td>\n",
" <td>1</td>\n",
" <td>Hotel</td>\n",
" <td>Vacation Rental</td>\n",
" <td>Beach</td>\n",
" <td>Lake</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>31</th>\n",
" <td>White Rock</td>\n",
" <td>V4B</td>\n",
" <td>Canada</td>\n",
" <td>British Columbia</td>\n",
" <td>49.03125</td>\n",
" <td>-122.8125</td>\n",
" <td>1</td>\n",
" <td>Park</td>\n",
" <td>Gym / Fitness Center</td>\n",
" <td>Athletics &amp; Sports</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place Code Country \\\n",
"0 Abbotsford V3G Canada \n",
"1 Burnaby V3N Canada \n",
"2 Comox V9M Canada \n",
"3 Coquitlam V3J Canada \n",
"4 Cranbrook V1C Canada \n",
"5 Duncan V9L Canada \n",
"6 Esquimalt V9A Canada \n",
"7 Fort St. John V1J Canada \n",
"8 Highlands V9B Canada \n",
"9 Kelowna Central V1Y Canada \n",
"10 Kimberley V1A Canada \n",
"11 Kitimat V8C Canada \n",
"12 Langley City V3A Canada \n",
"13 Nanaimo Central V9S Canada \n",
"14 Nelson V1L Canada \n",
"15 New Westminster Northeast V3L Canada \n",
"16 Oak Bay V8R Canada \n",
"17 Parksville V9P Canada \n",
"18 Pitt Meadows V3Y Canada \n",
"19 Qualicum Beach V9K Canada \n",
"20 Richmond V7B Canada \n",
"21 Saanich Central V8Z Canada \n",
"22 Salmon Arm V1E Canada \n",
"23 Sooke V9Z Canada \n",
"24 South Okanagan V0H Canada \n",
"25 Surrey V3Z Canada \n",
"26 Terrace V8G Canada \n",
"27 Trail V1R Canada \n",
"28 Vancouver V5K Canada \n",
"29 Victoria Central British Columbia Provincial G... V8W Canada \n",
"30 Whistler V8E Canada \n",
"31 White Rock V4B Canada \n",
"\n",
" Province Latitude Longitude Cluster Labels \\\n",
"0 British Columbia 49.06250 -122.3125 1 \n",
"1 British Columbia 49.25000 -123.0000 1 \n",
"2 British Columbia 49.68750 -124.9375 1 \n",
"3 British Columbia 49.25000 -122.8750 1 \n",
"4 British Columbia 49.50000 -115.7500 2 \n",
"5 British Columbia 48.78125 -123.6875 1 \n",
"6 British Columbia 48.43750 -123.4375 3 \n",
"7 British Columbia 56.25000 -120.8750 1 \n",
"8 British Columbia 48.46875 -123.5000 3 \n",
"9 British Columbia 49.90625 -119.4375 1 \n",
"10 British Columbia 49.68750 -116.0000 1 \n",
"11 British Columbia 54.06250 -128.6250 4 \n",
"12 British Columbia 49.09375 -122.5625 0 \n",
"13 British Columbia 49.18750 -124.0000 1 \n",
"14 British Columbia 49.50000 -117.3125 7 \n",
"15 British Columbia 49.18750 -122.8750 1 \n",
"16 British Columbia 48.43750 -123.3125 1 \n",
"17 British Columbia 49.31250 -124.3125 1 \n",
"18 British Columbia 49.21875 -122.6875 1 \n",
"19 British Columbia 49.34375 -124.4375 1 \n",
"20 British Columbia 49.15625 -123.1250 1 \n",
"21 British Columbia 48.50000 -123.3750 6 \n",
"22 British Columbia 50.68750 -119.2500 2 \n",
"23 British Columbia 48.37500 -123.7500 2 \n",
"24 British Columbia 49.40625 -119.0000 2 \n",
"25 British Columbia 49.12500 -122.8125 1 \n",
"26 British Columbia 54.53125 -128.6250 2 \n",
"27 British Columbia 49.09375 -117.6875 5 \n",
"28 British Columbia 49.25000 -123.1250 1 \n",
"29 British Columbia 48.43750 -123.3750 1 \n",
"30 British Columbia 50.12500 -122.9375 1 \n",
"31 British Columbia 49.03125 -122.8125 1 \n",
"\n",
" 1st Most Common Venue 2nd Most Common Venue 3rd Most Common Venue \\\n",
"0 Grocery Store Trail Falafel Restaurant \n",
"1 Bus Stop Bookstore Snack Place \n",
"2 Fast Food Restaurant Coffee Shop Pharmacy \n",
"3 Asian Restaurant Convenience Store Golf Course \n",
"4 Construction & Landscaping Zoo Fast Food Restaurant \n",
"5 Convenience Store Gas Station Dog Run \n",
"6 Boat or Ferry Fish & Chips Shop Convenience Store \n",
"7 American Restaurant Gas Station Fast Food Restaurant \n",
"8 Zoo Theme Park Boat or Ferry \n",
"9 Park Mountain Zoo \n",
"10 American Restaurant Ski Lodge Hotel \n",
"11 Business Service Zoo Fast Food Restaurant \n",
"12 Baseball Field Zoo Fish & Chips Shop \n",
"13 Tourist Information Center Brewery Zoo \n",
"14 Trail Zoo Fast Food Restaurant \n",
"15 Hot Dog Joint Garden Playground \n",
"16 Gym Bookstore Gift Shop \n",
"17 Bookstore Home Service Zoo \n",
"18 Gym / Fitness Center Plaza Elementary School \n",
"19 American Restaurant Restaurant Pharmacy \n",
"20 Gym Grocery Store Dim Sum Restaurant \n",
"21 Bank Zoo Fish & Chips Shop \n",
"22 Construction & Landscaping Zoo Fast Food Restaurant \n",
"23 Construction & Landscaping Zoo Fast Food Restaurant \n",
"24 Construction & Landscaping Zoo Fast Food Restaurant \n",
"25 Recreation Center Auto Workshop Zoo \n",
"26 Construction & Landscaping Zoo Fast Food Restaurant \n",
"27 Pub Falafel Restaurant Coffee Shop \n",
"28 Bank Sushi Restaurant Coffee Shop \n",
"29 Coffee Shop Brewery Restaurant \n",
"30 Hotel Vacation Rental Beach \n",
"31 Park Gym / Fitness Center Athletics & Sports \n",
"\n",
" 4th Most Common Venue 5th Most Common Venue \\\n",
"0 Coffee Shop Construction & Landscaping \n",
"1 Park Bus Station \n",
"2 Sandwich Place Juice Bar \n",
"3 Gas Station Coffee Shop \n",
"4 Convenience Store Dessert Shop \n",
"5 Zoo Fast Food Restaurant \n",
"6 Dessert Shop Dim Sum Restaurant \n",
"7 Construction & Landscaping Convenience Store \n",
"8 Wine Shop Auto Workshop \n",
"9 Falafel Restaurant Convenience Store \n",
"10 Ski Area Construction & Landscaping \n",
"11 Convenience Store Dessert Shop \n",
"12 Convenience Store Dessert Shop \n",
"13 Falafel Restaurant Construction & Landscaping \n",
"14 Construction & Landscaping Convenience Store \n",
"15 Zoo Falafel Restaurant \n",
"16 Fish & Chips Shop Men's Store \n",
"17 Convenience Store Dessert Shop \n",
"18 Pub Coffee Shop \n",
"19 Grocery Store Gastropub \n",
"20 Sushi Restaurant Pizza Place \n",
"21 Convenience Store Dessert Shop \n",
"22 Convenience Store Dessert Shop \n",
"23 Convenience Store Dessert Shop \n",
"24 Convenience Store Dessert Shop \n",
"25 Falafel Restaurant Construction & Landscaping \n",
"26 Convenience Store Dessert Shop \n",
"27 Construction & Landscaping Convenience Store \n",
"28 Park Gym \n",
"29 Motorcycle Shop Sandwich Place \n",
"30 Lake Zoo \n",
"31 Zoo Fast Food Restaurant \n",
"\n",
" 6th Most Common Venue 7th Most Common Venue \\\n",
"0 Convenience Store Dessert Shop \n",
"1 Burger Joint Sandwich Place \n",
"2 Elementary School Construction & Landscaping \n",
"3 Zoo Falafel Restaurant \n",
"4 Dim Sum Restaurant Dog Run \n",
"5 Construction & Landscaping Dessert Shop \n",
"6 Dog Run Elementary School \n",
"7 Dessert Shop Dim Sum Restaurant \n",
"8 Fish & Chips Shop Dessert Shop \n",
"9 Dessert Shop Dim Sum Restaurant \n",
"10 Convenience Store Dessert Shop \n",
"11 Dim Sum Restaurant Dog Run \n",
"12 Dim Sum Restaurant Dog Run \n",
"13 Convenience Store Dessert Shop \n",
"14 Dessert Shop Dim Sum Restaurant \n",
"15 Construction & Landscaping Convenience Store \n",
"16 Breakfast Spot Café \n",
"17 Dim Sum Restaurant Dog Run \n",
"18 Construction & Landscaping Convenience Store \n",
"19 Gas Station Garden \n",
"20 Sandwich Place Pub \n",
"21 Dim Sum Restaurant Dog Run \n",
"22 Dim Sum Restaurant Dog Run \n",
"23 Dim Sum Restaurant Dog Run \n",
"24 Dim Sum Restaurant Dog Run \n",
"25 Convenience Store Dessert Shop \n",
"26 Dim Sum Restaurant Dog Run \n",
"27 Dessert Shop Dim Sum Restaurant \n",
"28 Sandwich Place Greek Restaurant \n",
"29 Gym Gastropub \n",
"30 Fast Food Restaurant Convenience Store \n",
"31 Convenience Store Dessert Shop \n",
"\n",
" 8th Most Common Venue 9th Most Common Venue 10th Most Common Venue \n",
"0 Dim Sum Restaurant Dog Run Elementary School \n",
"1 Coffee Shop Fast Food Restaurant Falafel Restaurant \n",
"2 Convenience Store Dessert Shop Dim Sum Restaurant \n",
"3 Dessert Shop Dim Sum Restaurant Dog Run \n",
"4 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"5 Dim Sum Restaurant Elementary School Falafel Restaurant \n",
"6 Falafel Restaurant Fast Food Restaurant Zoo \n",
"7 Dog Run Elementary School Falafel Restaurant \n",
"8 Dim Sum Restaurant Dog Run Elementary School \n",
"9 Dog Run Elementary School Fast Food Restaurant \n",
"10 Dim Sum Restaurant Dog Run Elementary School \n",
"11 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"12 Elementary School Falafel Restaurant Fast Food Restaurant \n",
"13 Dim Sum Restaurant Dog Run Elementary School \n",
"14 Dog Run Elementary School Falafel Restaurant \n",
"15 Dessert Shop Dim Sum Restaurant Dog Run \n",
"16 Bakery Toy / Game Store Bank \n",
"17 Elementary School Falafel Restaurant Fast Food Restaurant \n",
"18 Dessert Shop Dim Sum Restaurant Dog Run \n",
"19 Fried Chicken Joint Fish & Chips Shop Fast Food Restaurant \n",
"20 Fast Food Restaurant Falafel Restaurant Indian Restaurant \n",
"21 Elementary School Falafel Restaurant Fast Food Restaurant \n",
"22 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"23 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"24 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"25 Dim Sum Restaurant Dog Run Elementary School \n",
"26 Elementary School Falafel Restaurant Fish & Chips Shop \n",
"27 Dog Run Elementary School Zoo \n",
"28 Grocery Store Dessert Shop Liquor Store \n",
"29 Fried Chicken Joint Fish & Chips Shop Fast Food Restaurant \n",
"30 Dessert Shop Dim Sum Restaurant Dog Run \n",
"31 Dim Sum Restaurant Dog Run Elementary School "
]
},
"execution_count": 190,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"clustered_df.reset_index(inplace = True, drop = True)\n",
"clustered_df"
]
},
{
"cell_type": "code",
"execution_count": 191,
"metadata": {},
"outputs": [
{
"data": {
"text/plain": [
"1 20\n",
"2 5\n",
"3 2\n",
"7 1\n",
"6 1\n",
"5 1\n",
"4 1\n",
"0 1\n",
"Name: Cluster Labels, dtype: int64"
]
},
"execution_count": 191,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"clustered_df['Cluster Labels'].value_counts()"
]
},
{
"cell_type": "code",
"execution_count": 192,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"The clustered neighborhoods of British Columbia are: 55.001251 , -125.002441\n"
]
}
],
"source": [
"print(\"The clustered neighborhoods of British Columbia are: {} , {}\".format(lat,long))"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Finally, visualizing the resulting cluster onto the British Columbia map using Folium.\n"
]
},
{
"cell_type": "code",
"execution_count": 204,
"metadata": {},
"outputs": [
{
"data": {
"text/html": [
"<div style=\"width:100%;\"><div style=\"position:relative;width:100%;height:0;padding-bottom:60%;\"><span style=\"color:#565656\">Make this Notebook Trusted to load map: File -> Trust Notebook</span><iframe src=\"about:blank\" style=\"position:absolute;width:100%;height:100%;left:0;top:0;border:none !important;\" data-html=<!DOCTYPE html>
<head>    
    <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
    <script>L_PREFER_CANVAS = false; L_NO_TOUCH = false; L_DISABLE_3D = false;</script>
    <script src="https://cdn.jsdelivr.net/npm/leaflet@1.2.0/dist/leaflet.js"></script>
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js"></script>
    <script src="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/js/bootstrap.min.js"></script>
    <script src="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.js"></script>
    <link rel="stylesheet" href="https://cdn.jsdelivr.net/npm/leaflet@1.2.0/dist/leaflet.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap.min.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/bootstrap/3.2.0/css/bootstrap-theme.min.css"/>
    <link rel="stylesheet" href="https://maxcdn.bootstrapcdn.com/font-awesome/4.6.3/css/font-awesome.min.css"/>
    <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/Leaflet.awesome-markers/2.0.2/leaflet.awesome-markers.css"/>
    <link rel="stylesheet" href="https://rawgit.com/python-visualization/folium/master/folium/templates/leaflet.awesome.rotate.css"/>
    <style>html, body {width: 100%;height: 100%;margin: 0;padding: 0;}</style>
    <style>#map {position:absolute;top:0;bottom:0;right:0;left:0;}</style>
    
            <style> #map_2eeeeb4f0fce4267b5491e4e2088dbb6 {
                position : relative;
                width : 100.0%;
                height: 100.0%;
                left: 0.0%;
                top: 0.0%;
                }
            </style>
        
</head>
<body>    
    
            <div class="folium-map" id="map_2eeeeb4f0fce4267b5491e4e2088dbb6" ></div>
        
</body>
<script>    
    

            
                var bounds = null;
            

            var map_2eeeeb4f0fce4267b5491e4e2088dbb6 = L.map(
                                  'map_2eeeeb4f0fce4267b5491e4e2088dbb6',
                                  {center: [55.001251,-125.002441],
                                  zoom: 5,
                                  maxBounds: bounds,
                                  layers: [],
                                  worldCopyJump: false,
                                  crs: L.CRS.EPSG3857
                                 });
            
        
    
            var tile_layer_000f3c31c7ae4ed38be6bcf7ca081d38 = L.tileLayer(
                'https://{s}.tile.openstreetmap.org/{z}/{x}/{y}.png',
                {
  "attribution": null,
  "detectRetina": false,
  "maxZoom": 18,
  "minZoom": 1,
  "noWrap": false,
  "subdomains": "abc"
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
        
    
            var circle_marker_68b08b8fb3a1406aab64146eca995e0e = L.circleMarker(
                [49.0625,-122.3125],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_a94a6f878ea64ca7ae94035aaf4396cc = L.popup({maxWidth: '300'});

            
                var html_c699df25e49947d896b1cf110f7c6349 = $('<div id="html_c699df25e49947d896b1cf110f7c6349" style="width: 100.0%; height: 100.0%;">Abbotsford Cluster 1</div>')[0];
                popup_a94a6f878ea64ca7ae94035aaf4396cc.setContent(html_c699df25e49947d896b1cf110f7c6349);
            

            circle_marker_68b08b8fb3a1406aab64146eca995e0e.bindPopup(popup_a94a6f878ea64ca7ae94035aaf4396cc);

            
        
    
            var circle_marker_03d58ab3e8594734bf2b9a02ee476c25 = L.circleMarker(
                [49.25,-123.0],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_20b1286e16a540b6932111d1be530f38 = L.popup({maxWidth: '300'});

            
                var html_d14ecb8a39504a0193b6f798642c314e = $('<div id="html_d14ecb8a39504a0193b6f798642c314e" style="width: 100.0%; height: 100.0%;">Burnaby Cluster 1</div>')[0];
                popup_20b1286e16a540b6932111d1be530f38.setContent(html_d14ecb8a39504a0193b6f798642c314e);
            

            circle_marker_03d58ab3e8594734bf2b9a02ee476c25.bindPopup(popup_20b1286e16a540b6932111d1be530f38);

            
        
    
            var circle_marker_f5a22c930e9041078732263a2dd3250f = L.circleMarker(
                [49.6875,-124.9375],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_778ea2e5691e4c6298f65e8716142a50 = L.popup({maxWidth: '300'});

            
                var html_10636b1c15424979b1d353200cde7a13 = $('<div id="html_10636b1c15424979b1d353200cde7a13" style="width: 100.0%; height: 100.0%;">Comox Cluster 1</div>')[0];
                popup_778ea2e5691e4c6298f65e8716142a50.setContent(html_10636b1c15424979b1d353200cde7a13);
            

            circle_marker_f5a22c930e9041078732263a2dd3250f.bindPopup(popup_778ea2e5691e4c6298f65e8716142a50);

            
        
    
            var circle_marker_899ff360b7aa42c3a06a574b553f00e9 = L.circleMarker(
                [49.25,-122.875],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_5e1b34c0520049348816a929ccef20bd = L.popup({maxWidth: '300'});

            
                var html_07a3b2ff80d643939990d4ee1dd85691 = $('<div id="html_07a3b2ff80d643939990d4ee1dd85691" style="width: 100.0%; height: 100.0%;">Coquitlam Cluster 1</div>')[0];
                popup_5e1b34c0520049348816a929ccef20bd.setContent(html_07a3b2ff80d643939990d4ee1dd85691);
            

            circle_marker_899ff360b7aa42c3a06a574b553f00e9.bindPopup(popup_5e1b34c0520049348816a929ccef20bd);

            
        
    
            var circle_marker_8b234dd572f14fd384d59aff679ed40a = L.circleMarker(
                [49.5,-115.75],
                {
  "bubblingMouseEvents": true,
  "color": "#386df9",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#386df9",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_86a7f4c6f9bf4729a2ca9dfea09c5bf6 = L.popup({maxWidth: '300'});

            
                var html_d5849db2f81d4419997e9ead8d4f6881 = $('<div id="html_d5849db2f81d4419997e9ead8d4f6881" style="width: 100.0%; height: 100.0%;">Cranbrook Cluster 2</div>')[0];
                popup_86a7f4c6f9bf4729a2ca9dfea09c5bf6.setContent(html_d5849db2f81d4419997e9ead8d4f6881);
            

            circle_marker_8b234dd572f14fd384d59aff679ed40a.bindPopup(popup_86a7f4c6f9bf4729a2ca9dfea09c5bf6);

            
        
    
            var circle_marker_8bcaddf97c914b5d97b3c734b1cb0da7 = L.circleMarker(
                [48.78125,-123.6875],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_db3cc83d04694ceab399542b5a90843a = L.popup({maxWidth: '300'});

            
                var html_5b01da2b535549008c379ff612bd1504 = $('<div id="html_5b01da2b535549008c379ff612bd1504" style="width: 100.0%; height: 100.0%;">Duncan Cluster 1</div>')[0];
                popup_db3cc83d04694ceab399542b5a90843a.setContent(html_5b01da2b535549008c379ff612bd1504);
            

            circle_marker_8bcaddf97c914b5d97b3c734b1cb0da7.bindPopup(popup_db3cc83d04694ceab399542b5a90843a);

            
        
    
            var circle_marker_4cc974dcb6514a08bfcb2aa069f3f896 = L.circleMarker(
                [48.4375,-123.4375],
                {
  "bubblingMouseEvents": true,
  "color": "#12c8e6",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#12c8e6",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_62dd5749df094090860cd1e73e887983 = L.popup({maxWidth: '300'});

            
                var html_3877b81722944e22896a962c4273b2f9 = $('<div id="html_3877b81722944e22896a962c4273b2f9" style="width: 100.0%; height: 100.0%;">Esquimalt Cluster 3</div>')[0];
                popup_62dd5749df094090860cd1e73e887983.setContent(html_3877b81722944e22896a962c4273b2f9);
            

            circle_marker_4cc974dcb6514a08bfcb2aa069f3f896.bindPopup(popup_62dd5749df094090860cd1e73e887983);

            
        
    
            var circle_marker_88eac0db52f3493494dff12cb37a20a3 = L.circleMarker(
                [56.25,-120.875],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_dca758ca791e499db296cbf3610cb0af = L.popup({maxWidth: '300'});

            
                var html_10f7af9e751045029e8bc7db526ff580 = $('<div id="html_10f7af9e751045029e8bc7db526ff580" style="width: 100.0%; height: 100.0%;">Fort St. John Cluster 1</div>')[0];
                popup_dca758ca791e499db296cbf3610cb0af.setContent(html_10f7af9e751045029e8bc7db526ff580);
            

            circle_marker_88eac0db52f3493494dff12cb37a20a3.bindPopup(popup_dca758ca791e499db296cbf3610cb0af);

            
        
    
            var circle_marker_c0bcdfba68754afabd8fcac173ba6cc8 = L.circleMarker(
                [48.46875,-123.5],
                {
  "bubblingMouseEvents": true,
  "color": "#12c8e6",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#12c8e6",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_552a52a04e234df9aa8efb90a7f75e39 = L.popup({maxWidth: '300'});

            
                var html_45abad7c0f76481c96c8fb2b0cd520df = $('<div id="html_45abad7c0f76481c96c8fb2b0cd520df" style="width: 100.0%; height: 100.0%;">Highlands Cluster 3</div>')[0];
                popup_552a52a04e234df9aa8efb90a7f75e39.setContent(html_45abad7c0f76481c96c8fb2b0cd520df);
            

            circle_marker_c0bcdfba68754afabd8fcac173ba6cc8.bindPopup(popup_552a52a04e234df9aa8efb90a7f75e39);

            
        
    
            var circle_marker_1daf2ef678b24b538550a2c383ecf85c = L.circleMarker(
                [49.90625,-119.4375],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_425552b13c084f9cab10e155eabd3460 = L.popup({maxWidth: '300'});

            
                var html_25117222f1ed40158905443e807f7df4 = $('<div id="html_25117222f1ed40158905443e807f7df4" style="width: 100.0%; height: 100.0%;">Kelowna Central Cluster 1</div>')[0];
                popup_425552b13c084f9cab10e155eabd3460.setContent(html_25117222f1ed40158905443e807f7df4);
            

            circle_marker_1daf2ef678b24b538550a2c383ecf85c.bindPopup(popup_425552b13c084f9cab10e155eabd3460);

            
        
    
            var circle_marker_5d7858711f74466383b7d2c942e3ac3a = L.circleMarker(
                [49.6875,-116.0],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_b24f92f2a9e04cbc93beb982bd00852d = L.popup({maxWidth: '300'});

            
                var html_f4382ab71a41442a9ac4aeff7f6ffbcf = $('<div id="html_f4382ab71a41442a9ac4aeff7f6ffbcf" style="width: 100.0%; height: 100.0%;">Kimberley Cluster 1</div>')[0];
                popup_b24f92f2a9e04cbc93beb982bd00852d.setContent(html_f4382ab71a41442a9ac4aeff7f6ffbcf);
            

            circle_marker_5d7858711f74466383b7d2c942e3ac3a.bindPopup(popup_b24f92f2a9e04cbc93beb982bd00852d);

            
        
    
            var circle_marker_77a48a6e863e474daa93f332ea8e9ee1 = L.circleMarker(
                [54.0625,-128.625],
                {
  "bubblingMouseEvents": true,
  "color": "#5af8c8",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#5af8c8",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_d48727157e4d401d84bd7ebf868e4c7b = L.popup({maxWidth: '300'});

            
                var html_026ce0599f8b44c0ab8feb8fdae80d23 = $('<div id="html_026ce0599f8b44c0ab8feb8fdae80d23" style="width: 100.0%; height: 100.0%;">Kitimat Cluster 4</div>')[0];
                popup_d48727157e4d401d84bd7ebf868e4c7b.setContent(html_026ce0599f8b44c0ab8feb8fdae80d23);
            

            circle_marker_77a48a6e863e474daa93f332ea8e9ee1.bindPopup(popup_d48727157e4d401d84bd7ebf868e4c7b);

            
        
    
            var circle_marker_7db01923e7834e27af7652ab4b694686 = L.circleMarker(
                [49.09375,-122.5625],
                {
  "bubblingMouseEvents": true,
  "color": "#ff0000",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#ff0000",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_dcc3ffcbce6f46b7b7d38a39d70f1aef = L.popup({maxWidth: '300'});

            
                var html_69df2e495b334107859cd86b48097513 = $('<div id="html_69df2e495b334107859cd86b48097513" style="width: 100.0%; height: 100.0%;">Langley City Cluster 0</div>')[0];
                popup_dcc3ffcbce6f46b7b7d38a39d70f1aef.setContent(html_69df2e495b334107859cd86b48097513);
            

            circle_marker_7db01923e7834e27af7652ab4b694686.bindPopup(popup_dcc3ffcbce6f46b7b7d38a39d70f1aef);

            
        
    
            var circle_marker_59eb0930df0b4a82b9c8404a4c0ba14e = L.circleMarker(
                [49.1875,-124.0],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_fc3617ba155b4b99a5303ffbcf3b1545 = L.popup({maxWidth: '300'});

            
                var html_61de1d5fadc740e2bc80628662c5e6e7 = $('<div id="html_61de1d5fadc740e2bc80628662c5e6e7" style="width: 100.0%; height: 100.0%;">Nanaimo Central Cluster 1</div>')[0];
                popup_fc3617ba155b4b99a5303ffbcf3b1545.setContent(html_61de1d5fadc740e2bc80628662c5e6e7);
            

            circle_marker_59eb0930df0b4a82b9c8404a4c0ba14e.bindPopup(popup_fc3617ba155b4b99a5303ffbcf3b1545);

            
        
    
            var circle_marker_cd8976c8f8bc4984bf951d53fc9d463c = L.circleMarker(
                [49.5,-117.3125],
                {
  "bubblingMouseEvents": true,
  "color": "#ff6d38",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#ff6d38",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_aa082452f61a45b6ae3f2bb377f0f622 = L.popup({maxWidth: '300'});

            
                var html_a991d34dc598478b9eaaa6c209d38dd7 = $('<div id="html_a991d34dc598478b9eaaa6c209d38dd7" style="width: 100.0%; height: 100.0%;">Nelson Cluster 7</div>')[0];
                popup_aa082452f61a45b6ae3f2bb377f0f622.setContent(html_a991d34dc598478b9eaaa6c209d38dd7);
            

            circle_marker_cd8976c8f8bc4984bf951d53fc9d463c.bindPopup(popup_aa082452f61a45b6ae3f2bb377f0f622);

            
        
    
            var circle_marker_a884d384a5be431bb7d7f6a08946ebbc = L.circleMarker(
                [49.1875,-122.875],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_fdce4e46058b4bdca0ca4e1e23d4ae4f = L.popup({maxWidth: '300'});

            
                var html_1e6a03b4f5a34f58978d59c020e2cd7a = $('<div id="html_1e6a03b4f5a34f58978d59c020e2cd7a" style="width: 100.0%; height: 100.0%;">New Westminster Northeast Cluster 1</div>')[0];
                popup_fdce4e46058b4bdca0ca4e1e23d4ae4f.setContent(html_1e6a03b4f5a34f58978d59c020e2cd7a);
            

            circle_marker_a884d384a5be431bb7d7f6a08946ebbc.bindPopup(popup_fdce4e46058b4bdca0ca4e1e23d4ae4f);

            
        
    
            var circle_marker_51b036304e794e769d818c2c74100438 = L.circleMarker(
                [48.4375,-123.3125],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_5730a1602f9e454c87f1429151c71750 = L.popup({maxWidth: '300'});

            
                var html_a6d79a5d34864340b95e560d9dfc418f = $('<div id="html_a6d79a5d34864340b95e560d9dfc418f" style="width: 100.0%; height: 100.0%;">Oak Bay Cluster 1</div>')[0];
                popup_5730a1602f9e454c87f1429151c71750.setContent(html_a6d79a5d34864340b95e560d9dfc418f);
            

            circle_marker_51b036304e794e769d818c2c74100438.bindPopup(popup_5730a1602f9e454c87f1429151c71750);

            
        
    
            var circle_marker_666b716b9286428aa9b4b5799d988cf3 = L.circleMarker(
                [49.3125,-124.3125],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_84112ba9f874432193a5185b32f7a17a = L.popup({maxWidth: '300'});

            
                var html_af469ed90bce4f209f76ecf792d80a87 = $('<div id="html_af469ed90bce4f209f76ecf792d80a87" style="width: 100.0%; height: 100.0%;">Parksville Cluster 1</div>')[0];
                popup_84112ba9f874432193a5185b32f7a17a.setContent(html_af469ed90bce4f209f76ecf792d80a87);
            

            circle_marker_666b716b9286428aa9b4b5799d988cf3.bindPopup(popup_84112ba9f874432193a5185b32f7a17a);

            
        
    
            var circle_marker_bf0c971bf411429d81bb2ade17f5fd45 = L.circleMarker(
                [49.21875,-122.6875],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_7152587b945e47f084f15d09d25e8c51 = L.popup({maxWidth: '300'});

            
                var html_06eb6628353c42359692d730ec900b9d = $('<div id="html_06eb6628353c42359692d730ec900b9d" style="width: 100.0%; height: 100.0%;">Pitt Meadows Cluster 1</div>')[0];
                popup_7152587b945e47f084f15d09d25e8c51.setContent(html_06eb6628353c42359692d730ec900b9d);
            

            circle_marker_bf0c971bf411429d81bb2ade17f5fd45.bindPopup(popup_7152587b945e47f084f15d09d25e8c51);

            
        
    
            var circle_marker_34fd9270b1ab463d80158cf1836bb8ea = L.circleMarker(
                [49.34375,-124.4375],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_ae72d8c4ff7b4db78a1114cb4b6d266d = L.popup({maxWidth: '300'});

            
                var html_0a9b7edb8b794ae2860d5028471398a2 = $('<div id="html_0a9b7edb8b794ae2860d5028471398a2" style="width: 100.0%; height: 100.0%;">Qualicum Beach Cluster 1</div>')[0];
                popup_ae72d8c4ff7b4db78a1114cb4b6d266d.setContent(html_0a9b7edb8b794ae2860d5028471398a2);
            

            circle_marker_34fd9270b1ab463d80158cf1836bb8ea.bindPopup(popup_ae72d8c4ff7b4db78a1114cb4b6d266d);

            
        
    
            var circle_marker_29c9a1c308604dc5b26a20ac90c37272 = L.circleMarker(
                [49.15625,-123.125],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_4594c5cb55e243b7af7f8b39eec634b1 = L.popup({maxWidth: '300'});

            
                var html_082893922bae4125b4849a164923dcdf = $('<div id="html_082893922bae4125b4849a164923dcdf" style="width: 100.0%; height: 100.0%;">Richmond Cluster 1</div>')[0];
                popup_4594c5cb55e243b7af7f8b39eec634b1.setContent(html_082893922bae4125b4849a164923dcdf);
            

            circle_marker_29c9a1c308604dc5b26a20ac90c37272.bindPopup(popup_4594c5cb55e243b7af7f8b39eec634b1);

            
        
    
            var circle_marker_d5c56f0bb4f84d62b5aa93b47a947310 = L.circleMarker(
                [48.5,-123.375],
                {
  "bubblingMouseEvents": true,
  "color": "#ecc86f",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#ecc86f",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_d56a54f3af28424789d5db619597a1c9 = L.popup({maxWidth: '300'});

            
                var html_992366fd85384b1090520e44206cfe9f = $('<div id="html_992366fd85384b1090520e44206cfe9f" style="width: 100.0%; height: 100.0%;">Saanich Central Cluster 6</div>')[0];
                popup_d56a54f3af28424789d5db619597a1c9.setContent(html_992366fd85384b1090520e44206cfe9f);
            

            circle_marker_d5c56f0bb4f84d62b5aa93b47a947310.bindPopup(popup_d56a54f3af28424789d5db619597a1c9);

            
        
    
            var circle_marker_5ba1536bf8f44d499803c03ab9800216 = L.circleMarker(
                [50.6875,-119.25],
                {
  "bubblingMouseEvents": true,
  "color": "#386df9",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#386df9",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_f77ce2d1eec543debb96690895f06382 = L.popup({maxWidth: '300'});

            
                var html_4f6e43e3972f4197ae1c4547ffdc465a = $('<div id="html_4f6e43e3972f4197ae1c4547ffdc465a" style="width: 100.0%; height: 100.0%;">Salmon Arm Cluster 2</div>')[0];
                popup_f77ce2d1eec543debb96690895f06382.setContent(html_4f6e43e3972f4197ae1c4547ffdc465a);
            

            circle_marker_5ba1536bf8f44d499803c03ab9800216.bindPopup(popup_f77ce2d1eec543debb96690895f06382);

            
        
    
            var circle_marker_77cabc2a9c574311acb5d98a2d13f892 = L.circleMarker(
                [48.375,-123.75],
                {
  "bubblingMouseEvents": true,
  "color": "#386df9",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#386df9",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_91f10b384306423f8e0d708d4e30d020 = L.popup({maxWidth: '300'});

            
                var html_555e1b28965b4af58686e6be03641b48 = $('<div id="html_555e1b28965b4af58686e6be03641b48" style="width: 100.0%; height: 100.0%;">Sooke Cluster 2</div>')[0];
                popup_91f10b384306423f8e0d708d4e30d020.setContent(html_555e1b28965b4af58686e6be03641b48);
            

            circle_marker_77cabc2a9c574311acb5d98a2d13f892.bindPopup(popup_91f10b384306423f8e0d708d4e30d020);

            
        
    
            var circle_marker_fae3fb1b5a694217a30f178c7d3a5683 = L.circleMarker(
                [49.40625,-119.0],
                {
  "bubblingMouseEvents": true,
  "color": "#386df9",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#386df9",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_7c3306796e8349208b75e1dd7868f49c = L.popup({maxWidth: '300'});

            
                var html_3c0042ff29e84788a52351e105437539 = $('<div id="html_3c0042ff29e84788a52351e105437539" style="width: 100.0%; height: 100.0%;">South Okanagan Cluster 2</div>')[0];
                popup_7c3306796e8349208b75e1dd7868f49c.setContent(html_3c0042ff29e84788a52351e105437539);
            

            circle_marker_fae3fb1b5a694217a30f178c7d3a5683.bindPopup(popup_7c3306796e8349208b75e1dd7868f49c);

            
        
    
            var circle_marker_64bfe076308148b39131715f2fc04890 = L.circleMarker(
                [49.125,-122.8125],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_b1b4103de98f480684968cd11b472066 = L.popup({maxWidth: '300'});

            
                var html_7014c5859d72472fb3b55c56901b364d = $('<div id="html_7014c5859d72472fb3b55c56901b364d" style="width: 100.0%; height: 100.0%;">Surrey Cluster 1</div>')[0];
                popup_b1b4103de98f480684968cd11b472066.setContent(html_7014c5859d72472fb3b55c56901b364d);
            

            circle_marker_64bfe076308148b39131715f2fc04890.bindPopup(popup_b1b4103de98f480684968cd11b472066);

            
        
    
            var circle_marker_7780f3c8d4b9486186bcad51734fac65 = L.circleMarker(
                [54.53125,-128.625],
                {
  "bubblingMouseEvents": true,
  "color": "#386df9",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#386df9",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_234b5fc65ea2490d907cc00e855d6484 = L.popup({maxWidth: '300'});

            
                var html_b77f475ae7a64f2c85eb3e9a4e7ea23f = $('<div id="html_b77f475ae7a64f2c85eb3e9a4e7ea23f" style="width: 100.0%; height: 100.0%;">Terrace Cluster 2</div>')[0];
                popup_234b5fc65ea2490d907cc00e855d6484.setContent(html_b77f475ae7a64f2c85eb3e9a4e7ea23f);
            

            circle_marker_7780f3c8d4b9486186bcad51734fac65.bindPopup(popup_234b5fc65ea2490d907cc00e855d6484);

            
        
    
            var circle_marker_58b470a988944e569de8a2d80e102e6a = L.circleMarker(
                [49.09375,-117.6875],
                {
  "bubblingMouseEvents": true,
  "color": "#a4f89f",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#a4f89f",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_bac2b99282264f11af09d53699e54a4e = L.popup({maxWidth: '300'});

            
                var html_3288ecc6acf14a65883162b4fdfac92b = $('<div id="html_3288ecc6acf14a65883162b4fdfac92b" style="width: 100.0%; height: 100.0%;">Trail Cluster 5</div>')[0];
                popup_bac2b99282264f11af09d53699e54a4e.setContent(html_3288ecc6acf14a65883162b4fdfac92b);
            

            circle_marker_58b470a988944e569de8a2d80e102e6a.bindPopup(popup_bac2b99282264f11af09d53699e54a4e);

            
        
    
            var circle_marker_7d6e38b6876442179b65230e959e8302 = L.circleMarker(
                [49.25,-123.125],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_474714818cd9409e95d9a37184a9b53d = L.popup({maxWidth: '300'});

            
                var html_1296352c36c64173819eabff89aca2d6 = $('<div id="html_1296352c36c64173819eabff89aca2d6" style="width: 100.0%; height: 100.0%;">Vancouver Cluster 1</div>')[0];
                popup_474714818cd9409e95d9a37184a9b53d.setContent(html_1296352c36c64173819eabff89aca2d6);
            

            circle_marker_7d6e38b6876442179b65230e959e8302.bindPopup(popup_474714818cd9409e95d9a37184a9b53d);

            
        
    
            var circle_marker_05f109003cdc48aa8f06f6b372d8459e = L.circleMarker(
                [48.4375,-123.375],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_cbbe78953dc8413d8ebcdd6a682e1497 = L.popup({maxWidth: '300'});

            
                var html_64731ec8b9e44cfdb70af040d1eebdff = $('<div id="html_64731ec8b9e44cfdb70af040d1eebdff" style="width: 100.0%; height: 100.0%;">Victoria Central British Columbia Provincial Government Cluster 1</div>')[0];
                popup_cbbe78953dc8413d8ebcdd6a682e1497.setContent(html_64731ec8b9e44cfdb70af040d1eebdff);
            

            circle_marker_05f109003cdc48aa8f06f6b372d8459e.bindPopup(popup_cbbe78953dc8413d8ebcdd6a682e1497);

            
        
    
            var circle_marker_c2ed726e0296412392e1662a64060f43 = L.circleMarker(
                [50.125,-122.9375],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_68f2c3a2622c4d97b9d2fda09ed845ff = L.popup({maxWidth: '300'});

            
                var html_e858ffa0bd7046c6947525be17773b51 = $('<div id="html_e858ffa0bd7046c6947525be17773b51" style="width: 100.0%; height: 100.0%;">Whistler Cluster 1</div>')[0];
                popup_68f2c3a2622c4d97b9d2fda09ed845ff.setContent(html_e858ffa0bd7046c6947525be17773b51);
            

            circle_marker_c2ed726e0296412392e1662a64060f43.bindPopup(popup_68f2c3a2622c4d97b9d2fda09ed845ff);

            
        
    
            var circle_marker_642b52939498482f9250d8128eea0933 = L.circleMarker(
                [49.03125,-122.8125],
                {
  "bubblingMouseEvents": true,
  "color": "#8000ff",
  "dashArray": null,
  "dashOffset": null,
  "fill": true,
  "fillColor": "#8000ff",
  "fillOpacity": 0.7,
  "fillRule": "evenodd",
  "lineCap": "round",
  "lineJoin": "round",
  "opacity": 1.0,
  "radius": 5,
  "stroke": true,
  "weight": 3
}
                ).addTo(map_2eeeeb4f0fce4267b5491e4e2088dbb6);
            
    
            var popup_9841960316db409b8a8f43a91f0a3a87 = L.popup({maxWidth: '300'});

            
                var html_dd298fd9c8284b1c9932eeaf80c9eeec = $('<div id="html_dd298fd9c8284b1c9932eeaf80c9eeec" style="width: 100.0%; height: 100.0%;">White Rock Cluster 1</div>')[0];
                popup_9841960316db409b8a8f43a91f0a3a87.setContent(html_dd298fd9c8284b1c9932eeaf80c9eeec);
            

            circle_marker_642b52939498482f9250d8128eea0933.bindPopup(popup_9841960316db409b8a8f43a91f0a3a87);

            
        
</script> onload=\"this.contentDocument.open();this.contentDocument.write(atob(this.getAttribute('data-html')));this.contentDocument.close();\" allowfullscreen webkitallowfullscreen mozallowfullscreen></iframe></div></div>"
],
"text/plain": [
"<folium.folium.Map at 0x7fef7c7ece48>"
]
},
"execution_count": 204,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"map_bc_neigh = folium.Map(location=[lat,long], zoom_start=5)\n",
"map_bc_neigh\n",
"\n",
"x = np.arange(8)\n",
"ys = [i + x + (i*x)**2 for i in range(8)]\n",
"colors_array = cm.rainbow(np.linspace(0, 1, len(ys)))\n",
"rainbow = [colors.rgb2hex(i) for i in colors_array]\n",
"\n",
"for lati, lon, neigh, cluster in zip(clustered_df['Latitude'], clustered_df['Longitude'], clustered_df['Place'], clustered_df['Cluster Labels']):\n",
" label = folium.Popup(str(neigh) + ' Cluster ' + str(cluster), parse_html=True)\n",
" folium.CircleMarker(\n",
" [lati, lon],\n",
" radius=5,\n",
" popup=label,\n",
" color=rainbow[cluster-1],\n",
" fill=True,\n",
" fill_color=rainbow[cluster-1],\n",
" fill_opacity=0.7).add_to(map_bc_neigh)\n",
" \n",
"map_bc_neigh"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"\n",
"## Results and Conclusion <a name=\"results\"></a>"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Based on the similarity of neighborhoods based on their nearby venues, we cluster the neighborhoods into 8 different clusters. We examine each cluster and determine the discriminating venue categories that distinguish each cluster.\n"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Cluster 1"
]
},
{
"cell_type": "code",
"execution_count": 205,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(1, 11)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Langley City</td>\n",
" <td>Baseball Field</td>\n",
" <td>Zoo</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place 1st Most Common Venue 2nd Most Common Venue \\\n",
"0 Langley City Baseball Field Zoo \n",
"\n",
" 3rd Most Common Venue 4th Most Common Venue 5th Most Common Venue \\\n",
"0 Fish & Chips Shop Convenience Store Dessert Shop \n",
"\n",
" 6th Most Common Venue 7th Most Common Venue 8th Most Common Venue \\\n",
"0 Dim Sum Restaurant Dog Run Elementary School \n",
"\n",
" 9th Most Common Venue 10th Most Common Venue \n",
"0 Falafel Restaurant Fast Food Restaurant "
]
},
"execution_count": 205,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"label0 = clustered_df.loc[clustered_df['Cluster Labels'] == 0,\n",
" clustered_df.columns[[0] + list(range(7, clustered_df.shape[1]))]]\n",
"print(label0.shape)\n",
"label0.head().reset_index(drop=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Cluster 2"
]
},
{
"cell_type": "code",
"execution_count": 206,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(20, 11)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Abbotsford</td>\n",
" <td>Grocery Store</td>\n",
" <td>Trail</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Burnaby</td>\n",
" <td>Bus Stop</td>\n",
" <td>Bookstore</td>\n",
" <td>Snack Place</td>\n",
" <td>Park</td>\n",
" <td>Bus Station</td>\n",
" <td>Burger Joint</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Comox</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Pharmacy</td>\n",
" <td>Sandwich Place</td>\n",
" <td>Juice Bar</td>\n",
" <td>Elementary School</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>Coquitlam</td>\n",
" <td>Asian Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Golf Course</td>\n",
" <td>Gas Station</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Zoo</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Duncan</td>\n",
" <td>Convenience Store</td>\n",
" <td>Gas Station</td>\n",
" <td>Dog Run</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place 1st Most Common Venue 2nd Most Common Venue \\\n",
"0 Abbotsford Grocery Store Trail \n",
"1 Burnaby Bus Stop Bookstore \n",
"2 Comox Fast Food Restaurant Coffee Shop \n",
"3 Coquitlam Asian Restaurant Convenience Store \n",
"4 Duncan Convenience Store Gas Station \n",
"\n",
" 3rd Most Common Venue 4th Most Common Venue 5th Most Common Venue \\\n",
"0 Falafel Restaurant Coffee Shop Construction & Landscaping \n",
"1 Snack Place Park Bus Station \n",
"2 Pharmacy Sandwich Place Juice Bar \n",
"3 Golf Course Gas Station Coffee Shop \n",
"4 Dog Run Zoo Fast Food Restaurant \n",
"\n",
" 6th Most Common Venue 7th Most Common Venue \\\n",
"0 Convenience Store Dessert Shop \n",
"1 Burger Joint Sandwich Place \n",
"2 Elementary School Construction & Landscaping \n",
"3 Zoo Falafel Restaurant \n",
"4 Construction & Landscaping Dessert Shop \n",
"\n",
" 8th Most Common Venue 9th Most Common Venue 10th Most Common Venue \n",
"0 Dim Sum Restaurant Dog Run Elementary School \n",
"1 Coffee Shop Fast Food Restaurant Falafel Restaurant \n",
"2 Convenience Store Dessert Shop Dim Sum Restaurant \n",
"3 Dessert Shop Dim Sum Restaurant Dog Run \n",
"4 Dim Sum Restaurant Elementary School Falafel Restaurant "
]
},
"execution_count": 206,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"label1 = clustered_df.loc[clustered_df['Cluster Labels'] == 1,\n",
" clustered_df.columns[[0] + list(range(7, clustered_df.shape[1]))]]\n",
"print(label1.shape)\n",
"label1.head().reset_index(drop=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Cluster 3"
]
},
{
"cell_type": "code",
"execution_count": 207,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(5, 11)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Cranbrook</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Salmon Arm</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>2</th>\n",
" <td>Sooke</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>3</th>\n",
" <td>South Okanagan</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" <tr>\n",
" <th>4</th>\n",
" <td>Terrace</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place 1st Most Common Venue 2nd Most Common Venue \\\n",
"0 Cranbrook Construction & Landscaping Zoo \n",
"1 Salmon Arm Construction & Landscaping Zoo \n",
"2 Sooke Construction & Landscaping Zoo \n",
"3 South Okanagan Construction & Landscaping Zoo \n",
"4 Terrace Construction & Landscaping Zoo \n",
"\n",
" 3rd Most Common Venue 4th Most Common Venue 5th Most Common Venue \\\n",
"0 Fast Food Restaurant Convenience Store Dessert Shop \n",
"1 Fast Food Restaurant Convenience Store Dessert Shop \n",
"2 Fast Food Restaurant Convenience Store Dessert Shop \n",
"3 Fast Food Restaurant Convenience Store Dessert Shop \n",
"4 Fast Food Restaurant Convenience Store Dessert Shop \n",
"\n",
" 6th Most Common Venue 7th Most Common Venue 8th Most Common Venue \\\n",
"0 Dim Sum Restaurant Dog Run Elementary School \n",
"1 Dim Sum Restaurant Dog Run Elementary School \n",
"2 Dim Sum Restaurant Dog Run Elementary School \n",
"3 Dim Sum Restaurant Dog Run Elementary School \n",
"4 Dim Sum Restaurant Dog Run Elementary School \n",
"\n",
" 9th Most Common Venue 10th Most Common Venue \n",
"0 Falafel Restaurant Fish & Chips Shop \n",
"1 Falafel Restaurant Fish & Chips Shop \n",
"2 Falafel Restaurant Fish & Chips Shop \n",
"3 Falafel Restaurant Fish & Chips Shop \n",
"4 Falafel Restaurant Fish & Chips Shop "
]
},
"execution_count": 207,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"label2 = clustered_df.loc[clustered_df['Cluster Labels'] == 2,\n",
" clustered_df.columns[[0] + list(range(7, clustered_df.shape[1]))]]\n",
"print(label2.shape)\n",
"label2.head().reset_index(drop=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Cluster 4"
]
},
{
"cell_type": "code",
"execution_count": 208,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(2, 11)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Esquimalt</td>\n",
" <td>Boat or Ferry</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Zoo</td>\n",
" </tr>\n",
" <tr>\n",
" <th>1</th>\n",
" <td>Highlands</td>\n",
" <td>Zoo</td>\n",
" <td>Theme Park</td>\n",
" <td>Boat or Ferry</td>\n",
" <td>Wine Shop</td>\n",
" <td>Auto Workshop</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place 1st Most Common Venue 2nd Most Common Venue \\\n",
"0 Esquimalt Boat or Ferry Fish & Chips Shop \n",
"1 Highlands Zoo Theme Park \n",
"\n",
" 3rd Most Common Venue 4th Most Common Venue 5th Most Common Venue \\\n",
"0 Convenience Store Dessert Shop Dim Sum Restaurant \n",
"1 Boat or Ferry Wine Shop Auto Workshop \n",
"\n",
" 6th Most Common Venue 7th Most Common Venue 8th Most Common Venue \\\n",
"0 Dog Run Elementary School Falafel Restaurant \n",
"1 Fish & Chips Shop Dessert Shop Dim Sum Restaurant \n",
"\n",
" 9th Most Common Venue 10th Most Common Venue \n",
"0 Fast Food Restaurant Zoo \n",
"1 Dog Run Elementary School "
]
},
"execution_count": 208,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"label3 = clustered_df.loc[clustered_df['Cluster Labels'] == 3,\n",
" clustered_df.columns[[0] + list(range(7, clustered_df.shape[1]))]]\n",
"print(label3.shape)\n",
"label3.head().reset_index(drop=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Cluster 5"
]
},
{
"cell_type": "code",
"execution_count": 209,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(1, 11)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Kitimat</td>\n",
" <td>Business Service</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place 1st Most Common Venue 2nd Most Common Venue 3rd Most Common Venue \\\n",
"0 Kitimat Business Service Zoo Fast Food Restaurant \n",
"\n",
" 4th Most Common Venue 5th Most Common Venue 6th Most Common Venue \\\n",
"0 Convenience Store Dessert Shop Dim Sum Restaurant \n",
"\n",
" 7th Most Common Venue 8th Most Common Venue 9th Most Common Venue \\\n",
"0 Dog Run Elementary School Falafel Restaurant \n",
"\n",
" 10th Most Common Venue \n",
"0 Fish & Chips Shop "
]
},
"execution_count": 209,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"label4 = clustered_df.loc[clustered_df['Cluster Labels'] == 4,\n",
" clustered_df.columns[[0] + list(range(7, clustered_df.shape[1]))]]\n",
"print(label4.shape)\n",
"label4.head().reset_index(drop=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Cluster 6"
]
},
{
"cell_type": "code",
"execution_count": 210,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(1, 11)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Trail</td>\n",
" <td>Pub</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Coffee Shop</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Zoo</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place 1st Most Common Venue 2nd Most Common Venue 3rd Most Common Venue \\\n",
"0 Trail Pub Falafel Restaurant Coffee Shop \n",
"\n",
" 4th Most Common Venue 5th Most Common Venue 6th Most Common Venue \\\n",
"0 Construction & Landscaping Convenience Store Dessert Shop \n",
"\n",
" 7th Most Common Venue 8th Most Common Venue 9th Most Common Venue \\\n",
"0 Dim Sum Restaurant Dog Run Elementary School \n",
"\n",
" 10th Most Common Venue \n",
"0 Zoo "
]
},
"execution_count": 210,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"label5 = clustered_df.loc[clustered_df['Cluster Labels'] == 5,\n",
" clustered_df.columns[[0] + list(range(7, clustered_df.shape[1]))]]\n",
"print(label5.shape)\n",
"label5.head().reset_index(drop=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Cluster 7"
]
},
{
"cell_type": "code",
"execution_count": 211,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(1, 11)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Saanich Central</td>\n",
" <td>Bank</td>\n",
" <td>Zoo</td>\n",
" <td>Fish &amp; Chips Shop</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" <td>Fast Food Restaurant</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place 1st Most Common Venue 2nd Most Common Venue \\\n",
"0 Saanich Central Bank Zoo \n",
"\n",
" 3rd Most Common Venue 4th Most Common Venue 5th Most Common Venue \\\n",
"0 Fish & Chips Shop Convenience Store Dessert Shop \n",
"\n",
" 6th Most Common Venue 7th Most Common Venue 8th Most Common Venue \\\n",
"0 Dim Sum Restaurant Dog Run Elementary School \n",
"\n",
" 9th Most Common Venue 10th Most Common Venue \n",
"0 Falafel Restaurant Fast Food Restaurant "
]
},
"execution_count": 211,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"label6 = clustered_df.loc[clustered_df['Cluster Labels'] == 6,\n",
" clustered_df.columns[[0] + list(range(7, clustered_df.shape[1]))]]\n",
"print(label6.shape)\n",
"label6.head().reset_index(drop=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"\n",
"#### Cluster 8"
]
},
{
"cell_type": "code",
"execution_count": 212,
"metadata": {},
"outputs": [
{
"name": "stdout",
"output_type": "stream",
"text": [
"(1, 11)\n"
]
},
{
"data": {
"text/html": [
"<div>\n",
"<style scoped>\n",
" .dataframe tbody tr th:only-of-type {\n",
" vertical-align: middle;\n",
" }\n",
"\n",
" .dataframe tbody tr th {\n",
" vertical-align: top;\n",
" }\n",
"\n",
" .dataframe thead th {\n",
" text-align: right;\n",
" }\n",
"</style>\n",
"<table border=\"1\" class=\"dataframe\">\n",
" <thead>\n",
" <tr style=\"text-align: right;\">\n",
" <th></th>\n",
" <th>Place</th>\n",
" <th>1st Most Common Venue</th>\n",
" <th>2nd Most Common Venue</th>\n",
" <th>3rd Most Common Venue</th>\n",
" <th>4th Most Common Venue</th>\n",
" <th>5th Most Common Venue</th>\n",
" <th>6th Most Common Venue</th>\n",
" <th>7th Most Common Venue</th>\n",
" <th>8th Most Common Venue</th>\n",
" <th>9th Most Common Venue</th>\n",
" <th>10th Most Common Venue</th>\n",
" </tr>\n",
" </thead>\n",
" <tbody>\n",
" <tr>\n",
" <th>0</th>\n",
" <td>Nelson</td>\n",
" <td>Trail</td>\n",
" <td>Zoo</td>\n",
" <td>Fast Food Restaurant</td>\n",
" <td>Construction &amp; Landscaping</td>\n",
" <td>Convenience Store</td>\n",
" <td>Dessert Shop</td>\n",
" <td>Dim Sum Restaurant</td>\n",
" <td>Dog Run</td>\n",
" <td>Elementary School</td>\n",
" <td>Falafel Restaurant</td>\n",
" </tr>\n",
" </tbody>\n",
"</table>\n",
"</div>"
],
"text/plain": [
" Place 1st Most Common Venue 2nd Most Common Venue 3rd Most Common Venue \\\n",
"0 Nelson Trail Zoo Fast Food Restaurant \n",
"\n",
" 4th Most Common Venue 5th Most Common Venue 6th Most Common Venue \\\n",
"0 Construction & Landscaping Convenience Store Dessert Shop \n",
"\n",
" 7th Most Common Venue 8th Most Common Venue 9th Most Common Venue \\\n",
"0 Dim Sum Restaurant Dog Run Elementary School \n",
"\n",
" 10th Most Common Venue \n",
"0 Falafel Restaurant "
]
},
"execution_count": 212,
"metadata": {},
"output_type": "execute_result"
}
],
"source": [
"label7 = clustered_df.loc[clustered_df['Cluster Labels'] == 7,\n",
" clustered_df.columns[[0] + list(range(7, clustered_df.shape[1]))]]\n",
"print(label7.shape)\n",
"label7.head().reset_index(drop=True)"
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"#### Thus, these clusters define the type of locality and can be used by different people to choose their preferably area of interest accordingly. For example, the first cluster involves a locality that has baseball fields, zoos in their most popular nearby venues and hence would be ore suitable for a younger generation, preferably kids in their middle schools. On the contrary, the second cluster involves a locality that has grocery shops, fast food shops and convenience stores as their popular nearby locations, and hence these areas would be more suitable for college students, who would need all of these at an almost daily basis."
]
},
{
"cell_type": "markdown",
"metadata": {},
"source": [
"### This marks the end of the project. Thank you for your time!"
]
},
{
"cell_type": "code",
"execution_count": null,
"metadata": {},
"outputs": [],
"source": []
}
],
"metadata": {
"kernelspec": {
"display_name": "Python",
"language": "python",
"name": "conda-env-python-py"
},
"language_info": {
"codemirror_mode": {
"name": "ipython",
"version": 3
},
"file_extension": ".py",
"mimetype": "text/x-python",
"name": "python",
"nbconvert_exporter": "python",
"pygments_lexer": "ipython3",
"version": "3.6.10"
}
},
"nbformat": 4,
"nbformat_minor": 4
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment