Python File Handling & Exception Handling

 Python File Handling

Till now, we were taking the input from the console and writing it back to the console to interact with the user.
Sometimes, it is not enough to only display the data on the console. The data to be displayed may be very large, and only a limited amount of data can be displayed on the console, and since the memory is volatile, it is impossible to recover the programmatically generated data again and again.
However, if we need to do so, we may store it onto the local file system which is volatile and can be accessed every time. Here, comes the need of file handling.
In this section of the tutorial, we will learn all about file handling in python including, creating a file, opening a file, closing a file, writing and appending the file, etc.

Opening a file

Python provides the open() function which accepts two arguments, file name and access mode in which the file is accessed. The function returns a file object which can be used to perform various operations like reading, writing, etc.
The syntax to use the open() function is given below.

  1. file object = open(<file-name>, <access-mode>, <buffering>)     
The files can be accessed using various modes like read, write, or append. The following are the details about the access mode to open a file.

SNAccess modeDescription
1r
It opens the file to read-only. The file pointer exists at the beginning. The file is by default open in this mode if no access mode is passed.
2rb
It opens the file to read only in binary format. The file pointer exists at the beginning of the file.
3r+
It opens the file to read and write both. The file pointer exists at the beginning of the file.
4rb+
It opens the file to read and write both in binary format. The file pointer exists at the beginning of the file.
5w
It opens the file to write only. It overwrites the file if previously exists or creates a new one if no file exists with the same name. The file pointer exists at the beginning of the file.
6wb
It opens the file to write only in binary format. It overwrites the file if it exists previously or creates a new one if no file exists with the same name. The file pointer exists at the beginning of the file.
7w+
It opens the file to write and read both. It is different from r+ in the sense that it overwrites the previous file if one exists whereas r+ doesn't overwrite the previously written file. It creates a new file if no file exists. The file pointer exists at the beginning of the file.
8wb+
It opens the file to write and read both in binary format. The file pointer exists at the beginning of the file.
9a
It opens the file in the append mode. The file pointer exists at the end of the previously written file if exists any. It creates a new file if no file exists with the same name.
10ab
It opens the file in the append mode in binary format. The pointer exists at the end of the previously written file. It creates a new file in binary format if no file exists with the same name.
11a+
It opens a file to append and read both. The file pointer remains at the end of the file if a file exists. It creates a new file if no file exists with the same name.
12ab+
It opens a file to append and read both in binary format. The file pointer remains at the end of the file.

Let's look at the simple example to open a file named "file.txt" (stored in the same directory) in read mode and printing its content on the console.

Example

  1. #opens the file file.txt in read mode  
  2. fileptr = open("file.txt","r")  
  3.   
  4. if fileptr:  
  5.     print("file is opened successfully")  
Output:
<class '_io.TextIOWrapper'>
file is opened successfully

The close() method

Once all the operations are done on the file, we must close it through our python script using the close() method. Any unwritten information gets destroyed once the close() method is called on a file object.
We can perform any operation on the file externally in the file system is the file is opened in python, hence it is good practice to close the file once all the operations are done.
The syntax to use the close() method is given below.

  1. fileobject.close()  

Consider the following example.

Example

  1. # opens the file file.txt in read mode  
  2. fileptr = open("file.txt","r")  
  3.   
  4. if fileptr:  
  5.     print("file is opened successfully")  
  6.   
  7. #closes the opened file  
  8. fileptr.close()  

Reading the file

To read a file using the python script, the python provides us the read() method. The read() method reads a string from the file. It can read the data in the text as well as binary format.
The syntax of the read() method is given below.

  1. fileobj.read(<count>)  

Here, the count is the number of bytes to be read from the file starting from the beginning of the file. If the count is not specified, then it may read the content of the file until the end.
Consider the following example.

Example

  1. #open the file.txt in read mode. causes error if no such file exists.  
  2. fileptr = open("file.txt","r");   
  3.   
  4. #stores all the data of the file into the variable content  
  5. content = fileptr.read(9);   
  6.   
  7. # prints the type of the data stored in the file  
  8. print(type(content))   
  9.   
  10. #prints the content of the file  
  11. print(content)   
  12.   
  13. #closes the opened file  
  14. fileptr.close()  

Output:

<class 'str'>
Hi, I am 

Read Lines of the file

Python facilitates us to read the file line by line by using a function readline(). The readline() method reads the lines of the file from the beginning, i.e., if we use the readline() method two times, then we can get the first two lines of the file.
Consider the following example which contains a function readline() that reads the first line of our file "file.txt" containing three lines.

Example

  1. #open the file.txt in read mode. causes error if no such file exists.  
  2. fileptr = open("file.txt","r");   
  3.   
  4. #stores all the data of the file into the variable content  
  5. content = fileptr.readline();   
  6.   
  7. # prints the type of the data stored in the file  
  8. print(type(content))   
  9.   
  10. #prints the content of the file  
  11. print(content)   
  12.   
  13. #closes the opened file  
  14. fileptr.close()  

Output:

<class 'str'>
Hi, I am the file and being used as 

Looping through the file

By looping through the lines of the file, we can read the whole file.

Example

  1. #open the file.txt in read mode. causes an error if no such file exists.  
  2.   
  3.   
  4. fileptr = open("file.txt","r");   
  5.   
  6. #running a for loop   
  7. for i in fileptr:  
  8.     print(i) # i contains each line of the file   

Output:

Hi, I am the file and being used as 
an example to read a 
file in python. 

Writing the file

To write some text to a file, we need to open the file using the open method with one of the following access modes.
a: It will append the existing file. The file pointer is at the end of the file. It creates a new file if no file exists.
w: It will overwrite the file if any file exists. The file pointer is at the beginning of the file.
Consider the following example.

Example 1

  1. #open the file.txt in append mode. Creates a new file if no such file exists.  
  2. fileptr = open("file.txt","a");   
  3.   
  4. #appending the content to the file  
  5. fileptr.write("Python is the modern day language. It makes things so simple.")  
  6.   
  7.   
  8. #closing the opened file   
  9. fileptr.close();  

Now, we can see that the content of the file is modified.

File.txt:
  1. Hi, I am the file and being used as   
  2. an example to read a   
  3. file in python.   
  4. Python is the modern day language. It makes things so simple.  

Creating a new file

The new file can be created by using one of the following access modes with the function open(). x: it creates a new file with the specified name. It causes an error a file exists with the same name.
a: It creates a new file with the specified name if no such file exists. It appends the content to the file if the file already exists with the specified name.
w: It creates a new file with the specified name if no such file exists. It overwrites the existing file.
Consider the following example.

Example


  1. #open the file.txt in read mode. causes error if no such file exists.  
  2. fileptr = open("file2.txt","x");   
  3.   
  4. print(fileptr)  
  5.   
  6. if fileptr:  
  7.     print("File created successfully");  

Output:

File created successfully

Removing the file

The os module provides us the remove() method which is used to remove the specified file. The syntax to use the remove() method is given below.

  1. remove(?file-name?)  

Example

  1. import os;  
  2.   
  3. #deleting the file named file3.txt   
  4. os.remove("file3.txt")  

Creating the new directory

The mkdir() method is used to create the directories in the current working directory. The syntax to create the new directory is given below.

  1. mkdir(?directory name?)  

Example

  1. import os;  
  2.   
  3. #creating a new directory with the name new  
  4. os.mkdir("new")  

Writing python output to the files

In python, there are the requirements to write the output of a python script to a file.
The check_call() method of module subprocess is used to execute a python script and write the output of that script to a file.
The following example contains two python scripts. The script file1.py executes the script file.py and writes its output to the text file output.txt

file.py:

  1. temperatures=[10,-20,-289,100]  
  2. def c_to_f(c):  
  3.     if c< -273.15:  
  4.         return "That temperature doesn't make sense!"  
  5.     else:  
  6.         f=c*9/5+32  
  7.         return f  
  8. for t in temperatures:  
  9.     print(c_to_f(t))  

file.py:

  1. import subprocess  
  2.   
  3. with open("output.txt""wb") as f:  
  4.     subprocess.check_call(["python""file.py"], stdout=f)  

Output:

50
-4
That temperature doesn't make sense!
212

The file related methods

The file object provides the following methods to manipulate the files on various operating systems.

SNMethodDescription
1file.close()
It closes the opened file. The file once closed, it can't be read or write any more.
2File.fush()It flushes the internal buffer.
3File.fileno()
It returns the file descriptor used by the underlying implementation to request I/O from the OS.
4File.isatty()
It returns true if the file is connected to a TTY device, otherwise returns false.
5File.next()It returns the next line from the file.
6File.read([size])It reads the file for the specified size.
7File.readline([size])
It reads one line from the file and places the file pointer to the beginning of the new line.
8File.readlines([sizehint])
It returns a list containing all the lines of the file. It reads the file until the EOF occurs using readline() function.
9File.seek(offset[,from)
It modifies the position of the file pointer to a specified offset with the specified reference.
10File.tell()It returns the current position of the file pointer within the file.
11File.truncate([size])It truncates the file to the optional specified size.
12File.write(str)It writes the specified string to a file
13File.writelines(seq)It writes a sequence of the strings to a file.


Python Exceptions

An exception can be defined as an abnormal condition in a program resulting in the disruption in the flow of the program.
Whenever an exception occurs, the program halts the execution, and thus the further code is not executed. Therefore, an exception is the error which python script is unable to tackle with.
Python provides us with the way to handle the Exception so that the other part of the code can be executed without any disruption. However, if we do not handle the exception, the interpreter doesn't execute all the code that exists after the that.

Common Exceptions

A list of common exceptions that can be thrown from a normal python program is given below.
  1. ZeroDivisionError: Occurs when a number is divided by zero.
  2. NameError: It occurs when a name is not found. It may be local or global.
  3. IndentationError: If incorrect indentation is given.
  4. IOError: It occurs when Input Output operation fails.
  5. EOFError: It occurs when the end of the file is reached, and yet operations are being performed.

Problem without handling exceptions

As we have already discussed, the exception is an abnormal condition that halts the execution of the program. Consider the following example.

Example

  1. a = int(input("Enter a:"))  
  2. b = int(input("Enter b:"))  
  3. c = a/b;  
  4. print("a/b = %d"%c)  
  5.   
  6. #other code:  
  7. print("Hi I am other part of the program")  

Output:

Enter a:10
Enter b:0
Traceback (most recent call last):
  File "exception-test.py", line 3, in <module>
    c = a/b;
ZeroDivisionError: division by zero

Exception handling in python

If the python program contains suspicious code that may throw the exception, we must place that code in the try block. The try block must be followed with the except statement which contains a block of code that will be executed if there is some exception in the try block.
Python Exception handling

Syntax

  1. try:  
  2.     #block of code   
  3.   
  4. except Exception1:  
  5.     #block of code  
  6.   
  7. except Exception2:  
  8.     #block of code  
  9.   
  10. #other code  

Declaring multiple exceptions

The python allows us to declare the multiple exceptions with the except clause. Declaring multiple exceptions is useful in the cases where a try block throws multiple exceptions.

Syntax

  1. try:  
  2.     #block of code   
  3.   
  4. except (<Exception 1>,<Exception 2>,<Exception 3>,...<Exception n>)  
  5.     #block of code   
  6.   
  7. else:  
  8.     #block of code  

Example

  1. try:    
  2.     a=10/0;    
  3. except ArithmeticError,StandardError:    
  4.     print "Arithmetic Exception"    
  5. else:    
  6.     print "Successfully Done"    

Output:

Arithmetic Exception 

Comments

Popular posts from this blog

Introduction to Python & its Data types

Python List, Tuple and Dictionary