Skip to main content

Posts

Automate! Automate!

 Making this customizable 👉So how about making our search user customizable? In the code below, I have: Asked the user to input an artist (line 14) Tidied up their input (line 15) formatted the search URL as an fString that includes the artist (line 19) Here's tAutomate! Automate! We are so close. I can taste it, folks! Massive kudos on getting this far! Today's lesson, however, will work best if you have one of Replit's paid for features (hacker plan or cycles). Free plan Repls 'fall asleep' after a while. Automation kinda relies on the Repl being always on. If you have hacker plan or you've bought some cycles, then you can enable always on in the drop down menu that appears when you click your Repl name (top left).he code: This is important because when our repl is always running, it can keep track of time and schedule events. 👉 I've set up a simple schedule that prints out a clock emoji every couple of seconds. It works like this: Import schedule librar...
Recent posts

Web Scraping

 Web Scraping Some websites don't have lovely APIs for us to interface with. If we want data from these pages, we have to use a tecnique called scraping. This means downloading the whole webpage and poking at it until we can find the information we want. You're going to use scraping to get the top ten restaurants near you. Get started 👉 Go to a website like Yelp and search for the top 10 reastaurants in your location. Copy the URL.   url = "https://www.yelp.co.uk/search?find_desc=Restaurants&find_loc=San+Francisco%2C+CA%2C+United+States"   Import libraries 👉 Import your libraries. Beautiful soup is a specialist library for extracting the contents of HTML and helping us parse them. Run the Repl once your imports are sorted because we want the Beautiful Soup library to be installed (it'll run quicker this way). import requests from bs4 import BeautifulSoup url = "https://www.yelp.co.uk/search?find_desc=Restaurants&find_loc=San+Francisco%2C+CA%2C+Unite...

API Smash Battle

 API Smash Battle That's right folks. Everyone loves a good mashup. So, today we're going to learn how to combine data from more than one API. NewsAPI 👉 Let's get signed up for our APIs. First up is News API. Hit 'Get API Key' Create an account Copy the API key Add it as a secret to your repl called newsapi Go to the get started guide Choose the Get current top articles option and grab the full URL for the GET request     Put it in your code as an fString. Replace the last bit with a {newsKey} variable (that will store the API key). We'll break it down further in a bit. url = f"https://newsapi.org/v2/top-headlines?country=us&apiKey={newsKey}" Import os Now import the os library and add the API key in using the code in the secrets menu.   import os newsKey = os.environ['newsapi'] url = f"https://newsapi.org/v2/top-headlines?country=us&apiKey={newsKey}"  Request time 👉 Now it's request time. I'm going to replace the ha...

API? Spotify? Verify!

API? Spotify? Verify! The APIs we've been using so far are pretty unusual in that they provide their service for free. Normally, you have to pay to use an APIs data services (at least if you're doing so commercially). This means that you will need to verify your status as an approved user before you can get your grubby hands on all of that sweet, sweet data! Today, we're learning how to write a program that tells an API that we've got an account before accessing its info. Don't worry, you won't have to bust out the credit card. We're using a Spotify API that won't charge provided we keep our usage under a certain level. Get started 👉 Click here to go to the Spotify developer page and log in/create an account. 👉 Next, hit create app and give it a name and description. 👉 Copy the client ID and insert it as a secret in your REPL. Make sure to call it CLIENT_ID. Client Secret 👉 Back to Spotify and click show client secret (use your own, not the one in th...

Funny, eh? Funny, how?

 Funny, eh? Funny, how? Dad Jokes The API we're using today is the awesome icanhazdadjoke. Go and check out their API documentation before continuing. Look at the endpoint to see the URL to access and the format of the data we'll get back. 👉 Here's the code to get a random dad joke and output it. NOTE - The second argument (headers=) in requests.get() is really important. It tells the code that we don't want the website back, we want JSON data in a specific format. Sometimes you need to do that. import requests, json result = requests.get("https://icanhazdadjoke.com/", headers={"Accept":"application/json"}) # get a random dad joke from the site endpoint and assign to a variable. The second argument (the header request) tells the script to return the json data as a string. joke = result.json() print(json.dumps(joke, indent=2)) 👉 I can change the print statement to just output the joke instead of the whole dictionary. print(joke["joke...

JSON

 JSON It's day 90, and today we're going to start learning how to use JSON (java script object notation - pronounced Jason) to get data from other websites. It's the first step on our journey to web scraping. JSON is a text based way of describing how a 2D dictionary might look. This is important when sending messages to other websites and getting a message back and decoding it. Most of the time, the message we get back will be in JSON format, and we need to interpret it in Python as a 2D dictionary to make sense of it. Go Get The Data 👉 Let's do a simple data grab from a free to use website - randomuser.me that generates some data about a fictional user. import requests # import the required library result = requests.get("https://randomuser.me/api/") # ask the site for data and store it in a variable print(result.json()) # interpret the data in the variable as json and print it. Run it. You'll get lots of data. Tidy it up 👉 Next, let's try to tidy t...

Authentication Finesse

 Authentication Finesse So far, we've used Replit authentication as a bit of a bully. It's forced users to authenticate on every page. For a blog engine, this will probably put users off. We want them to be able to read your online literary genius without being turned off by having to create an account and login. Today is all about finessing the Replit authenticator so that it works in a more subtle way. Custom Buttons To start, I've turned on the authenticator from the files panel and then select or use a prebuilt login page. Make sure you do this before you write any code! 👉 This time though, I've clicked the use your own custom button link.  Now I've got some lovely code snippets to steal work with. Add an HTML template 👉 Next I add in a HTML template page where the button will appear. The page is called page.html and can be found in your file tree. Here's the code: <html>   <head>     <title>My Website</title>   </head> ...