Skip to main content

Open , Read and Close , Print , Split , Form an orderly queue , Repeat , Just Use a Loop!

 


Reading From a File 


Once we've got data into a file, wouldn't it be just splendid to load it back into our program to use again?
Yes. Yes is the answer you're looking for.


Open 

πŸ‘‰ The code to load from a file is pretty similar to that for writing. The command is open instead of read, and the permissions are slightly different.


f = open("filenames.list", "r") 

 

Read and Close

πŸ‘‰ In this example, the permission 'r' means 'read only'. Now we load the contents of the file into a variable using the read function. Next, close the file to free up the RAM used to store it.


f = open("filenames.list", "r")
contents = f.read()
f.close()

Print

πŸ‘‰ Finally output the contents of the 'contents' variable to test that it worked.

f = open("filenames.list", "r")
contents = f.read()
f.close()
print(contents)

Split


Bringing everything in in one go is fine, but it would be much more useful to have it as separate items so we can examine it more easily.

πŸ‘‰ To do this, use the .split() function in the second to last line. This splits the string into a list of individual elements.

f = open("filenames.list", "r")
contents = f.read()
f.close()
contents = contents.split() #added split here
print(contents) 
One At A Time

Form an orderly queue

Reading all the data at once is fine, reading one item at a time works slightly differently.

It uses the .readline() function.

πŸ‘‰ The code below reads one line from the file.

f = open("filenames.list","r")
contents = f.readline()
print(contents)
f.close()
 
Repeat

To read more than one line, we repeat the command.

πŸ‘‰ The strip() function removes the default new line from each print, which would cause an empty line between each line from the file.

f = open("filenames.list","r")
contents = f.readline().strip()
print(contents)
contents = f.readline().strip()
print(contents)
contents = f.readline().strip()
print(contents)
contents = f.readline().strip()
print(contents)
f.close()


Just Use a Loop!

πŸ‘‰ If you're screaming 'LOOP! USE A FREAKING LOOP, MAN!' at the screen right about now.

Your wish is my command.

f = open("filenames.list","r")
while True:
  contents = f.readline().strip()
  
  if contents == "":
    break
  #The last line in the file will be a blank
  #We break the loop if the line read is a blank
  print(contents)
  # Moved the print after the break so it won't output the final blank line.
f.close()






Comments

Popular posts from this blog

HTTP & Sessions

 HTTP & Sessions One of the main protocols (rules that govern how computers communicate) on the web is called HTTP. HTTP is what is known as a stateless protocol. This means that it doesn't 'remember' things. It's a bit like having a conversation with a goldfish. You can ask a question and get a reply, but when you ask a follow up question, the original has already been forgotten, as has who you are and what you were talking about. So if HTTP is stateless, how come my news site remembers to give me the weather for my home town, my preferred South American river based online store tells me when it's time to order more multivitamins, and I'm justifiably proud of my #100days success streak? The answer is......... Sessions Sessions are a way of storing files on your computer that allows a website to keep a record of previous 'conversations' and 'questions' you've asked. By using sessions, we can store this info about the user to access later....

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...

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...