Last active
November 30, 2021 18:42
-
-
Save fijiaaron/9234200013f9ae9801a590039572bf64 to your computer and use it in GitHub Desktop.
Get latest cryptocurrency prices from CoinMarketCap
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
pip install selenium | |
pip install pandas | |
pip install openpyxl | |
pip install sqlalchemy | |
pip install mysql-connector-python | |
pip install beautifulsoup4 | |
pip install requests |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
# get prices using requests | |
import requests | |
response = requests.get("https://coinmarketcap.com/") | |
# parse data using Beauitful Soup | |
from bs4 import BeautifulSoup | |
soup = BeautifulSoup(response.content, "html.parser") | |
table_soup = soup.find("table") | |
headings = [th.text.strip() for th in table_soup.find_all("th")] | |
rows = [] | |
for tr in table_soup.find_all('tr', limit=11): | |
row = [] | |
for td in tr.find_all('td'): | |
row.append(td.text.strip()) | |
rows.append(row) | |
# save data using CSV | |
import csv | |
with open("data.csv", mode="w") as csvfile: | |
writer = csv.writer(csvfile) | |
writer.writerow(headings) | |
writer.writerows(rows) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
from selenium import webdriver | |
url = "https://coinmarketcap.com/" | |
table_locator = "xpath", "//table" | |
driver = webdriver.Chrome() | |
driver.get(url) | |
table_webelement = driver.find_element(*table_locator) | |
table_html = table_webelement.get_attribute("outerHTML") | |
# load the HTML table to Pandas DataFrame | |
import pandas | |
dataframes = pandas.read_html(table_html) | |
table_dataframe = dataframes[0] # get the first and only table on the page | |
# export data to Excel | |
table_dataframe.to_excel("data.xlsx") | |
# export data to MySQL (or MariaDB) | |
import sqlalchemy | |
from mysql import connector | |
conn = sqlalchemy.create_engine("mysql+mysqlconnector://username:password@localhost/test") | |
table_dataframe.to_sql(con=conn, name="prices", if_exists='append', index=False) |
Sign up for free
to join this conversation on GitHub.
Already have an account?
Sign in to comment