The OS module in Python provides the ability to interact with the operating system.

OS belongs to Python’s standard utility module. This module provides a portable way to use operating system-specific functionality.

The OS and OS.path modules contain many functions that interact with the file system.

Here are some features in the OS module:

1. OS. Name:

This function gives the name of the imported operating system dependent module.

Currently the following names are registered: “POSIX”, “NT”, “OS2”, “CE”, “Java” and “Riscos”

import os
print(os.name)
Copy the code

Output:

posix
Copy the code

Note: When running the code here, it may provide different output on different interpreters, such as “POSIX”.

2. OS. Getcwd () :

The function os.getcwd() returns the current working directory (CWD) of the file used to execute the code

import os
print(os.getcwd())
# To print absolute path on your system
# os.path.abspath('.') 

# To print files and directories in the current directory
# on your system
# os.listdir('.')
Copy the code

Output:

C:\Users\GFG\Desktop\ModuleOS
Copy the code

Note: For the GFG interpreter, the directory used is \root.

3. OS. Error:

All functions in this module raise OSError on invalid or inaccessible file names and paths, or other parameters with the correct type that are not accepted by the operating system.

import os
try:
    # If the file does not exist,
    # then it would throw an IOError
    filename = 'GFG.txt'
    f = open(filename, 'rU')
    text = f.read()
    f.close()

# Control jumps directly to here if 
#any of the above lines throws IOError.    
except IOError:

    # print(os.error) will <class 'OSError'>
    print('Problem reading: ' + filename)

# In any case, the code then continues with 
# the line after the try/except
Copy the code

Output:

Problem reading: GFG.txt
Copy the code

File object operation

4. OS. Popen () :

This method opens a pipeline of commands. Depending on whether the mode is’ R ‘or’ W ‘, the return value can be read or written.

Grammar:

 os.popen(command[, mode[, bufsize]])
Copy the code

Parameter mode &bufsize is not required, if not provided, r is the mode by default.

import os fd = "GFG.txt" # popen() is similar to open() file = open(fd, 'w') file.write("Hello") file.close() file = open(fd, 'r') text = file.read() print(text) # popen() provides a pipe/gateway and accesses the file directly file = os.popen(fd,  'w') file.write("Hello") # File not closed, shown in next function.Copy the code

Output:

Hello
Copy the code

Note: Popen () output is not displayed and will change the file directly.

5. OS. Lose () :

Close the file descriptor FD. Files opened with open() can only be closed by CLOSE().

But files opened through os.popen() can be closed with CLOSE() or os.lose().

If we try to close a file opened with open(), using os.lose(), Python will throw TypeError.

import os
fd = "GFG.txt"
file = open(fd, 'r')
text = file.read()
print(text)
os.close(file)
Copy the code

Output:

Traceback (most recent call last):
  File "C:\Users\GFG\Desktop\GeeksForGeeksOSFile.py", line 6, in 
    os.close(file)
TypeError: an integer is required (got type _io.TextIOWrapper)
Copy the code

Note: The same error may not be raised because there are no file or permission privileges.

6. OS. Rename () :

You can rename the file old.txt to new.txt using the function os.rename().

The name of a file changes only if the file exists and the user has sufficient permissions to change it.

import os
fd = "GFG.txt"
os.rename(fd,'New.txt')
os.rename(fd,'New.txt')
Copy the code

Output:

Traceback (most recent call last):
  File "C:\Users\GFG\Desktop\ModuleOS\GeeksForGeeksOSFile.py", line 3, in 
    os.rename(fd,'New.txt')
FileNotFoundError: [WinError 2] The system cannot find the
file specified: 'GFG.txt' -> 'New.txt'
Copy the code

Understand the output:

The file name “gfg.txt” exists, so the file will be renamed the first time os.rename() is used.

When os.rename() is called the second time, the file “new.txt” exists instead of “gfg.txt”

Therefore, Python raises FileNotFoundError.