Skip to main content

File Writing , Temporary Memory , Creating A New File , Close , Preventing Overwrite , New Lines

 


File Writing 

Our repls don't need to be just one file that contains all of the code and data. We can write data to other files for longer term storage, then access it when we need it. 

To do this we're going to use the Files tab in the left hand toolbar. It looks like this 

 


Temporary Memory

When we use variables, lists, dictionaries and other data structures in our code, the data inside them are stored in the computer's RAM.
RAM is temporary storage (usually called memory). It's used to hold data and instructions for programs that your computer currently has open.
The problem is, that when a program finishes, or is closed, its data and instructions are removed from the RAM to free up space.
This is why you had to re-input all of your test data for your dynamic list & dictionary programs every time you ran them. The contents of those lists/dictionaries were removed from RAM when the program finished executing.



Creating A New File

To avoid this incredibly annoying data re-entry task, we are going to get the program to save data into a file. The file will exist in secondary storage (the hard drives on Replit's servers in this case).
πŸ‘‰ Here's how to open a file. This one line of code has three important features: 


 
f = open("savedFile.txt", "w") 

The variable (f): This is needed to allow your program to communicate to the file. Normally this would have a lovely meaningful name. However, you will need to type this variable name lots, and lots, and lots. So short is good. 'f' is short for 'file'.


The file name (the first item in brackets, "savedFile.txt"): You MUST code this to match the filename EXACTLY and include the file extension.


The 'w' (second item in brackets): This sets the permissions for the file. 'w' means 'write'. This means that if the file doesn't already exist, the program will create a new blank file with that file name. However, if it does already exist it will be overwritten with a blank file.

Save Me! Writing Data To The File 


πŸ‘‰ The .write() command will write the piece of data in brackets into the file. You can use as many of these as you want.


 
f = open("savedFile.txt", "w")
f.write("Hello there")

Close


πŸ‘‰ However, this data IS STILL IN THE RAM. Nothing gets saved until we close the file using the .close() command.


f = open("savedFile.txt", "w")
f.write("Hello there")
f.close()



When you run this code, nothing will appear in the console, but check the files tab on the left.
Gasp! A file has been created. 



Click on it to view the contents! 





 

Saving to Files

πŸ‘‰ Now let's get some input, store it in a variable, and write it to the file.


f = open("savedFile.txt", "w")
whatText = input("> ")
f.write(whatText)
f.close()

Preventing Overwrite


We're going to change the file permissions from 'w' to 'a+'.
'a' means append - add to the end of the file.
However, if the file doen't exist, then it will crash.
'a+' means 'add to the end of the file, or create a new one if it doesn't exist'.
πŸ‘‰ Here's the amended code with the change on line 1:

f = open("savedFile.txt", "a+")
whatText = input("> ")
f.write(whatText)
f.close()

The problem with this is that it just glues the second input straight on to the first. Like this: 

New Lines

πŸ‘‰ We can use our old friend, the fString, to format a new line. I've used the \n new line character.

f = open("savedFile.txt", "a+")
whatText = input("> ")
f.write(f"{whatText}\n")
f.close()


 

f = open("savedFile.txt", "a+")
whatText = input("> ")
f.write(f"{whatText}\n")
f.close()


Comments

Popular posts from this blog

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

It's Called Hashing,Hashing, Printing the Hash , Salty, Second User ,

 It's Called Hashing One of the big issues with storing usernames and passwords in a database is what happens if we're hacked? If those passwords are stored as text, our users' security is compromised. Probably across multiple sites because they ignored our advice and used the same password for everything!!!!! Hashing  In reality, organizations don't store your actual password. They store a hash of your password. A hash is produced by turning your password into a sequence of numbers, then passing it though a hashing algorithm (some mathematical process that is very difficult to reverse engineer). The data spit out of this hashing algorithm is what's stored instead of your actual password. πŸ‘‰ So let's do it. I'm using the built-in hash function to create a numerical hash of the password  password = "baldy1" password = hash(password) print(password) # This will output a really long number  πŸ‘‰ Now let's store that hashed version in our database in...

Client/Server Logins

 Client/Server Logins Waaay back when we learned about repl.db, we mentioned the idea of a client/server model for storing data in one place and dishing it out to multiple users. This model is the way we overcome the issue with repl.db of each user getting their own copy of the database. Well, now we can use Flask as a webserver. We can build this client server model to persistently store data in the repl (the server) and have it be accessed by multiple users who access the website via the URL (the clients). Get Started Previously, we have built login systems using Flask & HTML. We're going to start with one of those systems and adapt it to use a dictionary instead. πŸ‘‰ First, let's remind ourselves of the way the system works. Here's the Flask code. Read the comments for explanations of what it does: from flask import Flask, request, redirect # imports request and redirect as well as flask app = Flask(__name__, static_url_path='/static') # path to the static fil...