Python and Interview Questions

Python Interview Questions (Frequently Asked)

Posted in Python, Interview Questions
Python Interview Questions (Frequently Asked)

Irrespective of the source you pick a list of best programming languages to learn in 2019 from, one name that will always find its place there is Python.

So, the answer is yes, if you are asking whether a lucrative career is possible by dedicating yourself to the interpreted, high-level, general-purpose programming language i.e. learning Python.

Python Interview Questions

Once you’ve had enough understanding of the various concepts of Python, it’s time to give a shot at some interviews. To increase your chances of clearing them, here is a list of 20 Python interview questions that you must know answers to:

Question: Describe how multithreading is achieved in Python.
Answer: Even though Python comes with a multi-threading package, if the motive behind multithreading is to speed the code then using the package is not the go-to option.

The package has something called the GIL or Global Interpreter Lock, which is a construct. It ensures that one and only one of the threads execute at any given time. A thread acquires the GIL and then do some work before passing it to the next thread.

This happens so fast that to a user it seems that threads are executing in parallel. Obviously, this is not the case as they are just taking turns while using the same CPU core. Moreover, GIL passing adds to the overall overhead to the execution.

Hence, if you intend to use the threading package for speeding up the execution, using the package is not recommended.

Question: Draw a comparison between the range and xrange in Python.
Answer: In terms of functionality, both range and xrange are identical. Both allow for generating a list of integers. The main difference between the two is that while range returns a Python list object, xrange returns an xrange object.

Xrange is not able to generate a static list at runtime the way range does. On the contrary, it creates values along with the requirements via a special technique called yielding. It is used with a type of object known as generators.

If you have a very enormous range for which you need to generate a list, then xrange is the function to opt for. This is especially relevant for scenarios dealing with a memory-sensitive system, such as a smartphone.

The range is a memory beast. Using it requires much more memory, especially if the requirement is gigantic. Hence, in creating an array of integers to suit the needs, it can result in a Memory Error and ultimately lead to crashing the program.

Question: Explain Inheritance and its various types in Python?
Answer: Inheritance enables a class to acquire all the members of another class. These members can be attributes, methods, or both. By providing reusability, inheritance makes it easier to create as well as maintain an application.

The class which acquires is known as the child class or the derived class. The one that it acquires from is known as the superclass or base class or the parent class. There are 4 forms of inheritance supported by Python:

  • Single Inheritance – A single derived class acquires from on single superclass.
  • Multi-Level Inheritance – At least 2 different derived classes acquire from two distinct base classes.
  • Hierarchical Inheritance – A number of child classes acquire from one superclass
  • Multiple Inheritance – A derived class acquires from several superclasses.

Question: Explain how is it possible to Get the Google cache age of any URL or webpage using Python.
Answer: In order to Get the Google cache age of any URL or webpage using Python, following URL format is used:

Simply replace URLGOESHERE with the web address of the website or webpage whose cache you need to retrieve and see in Python.

Question: Give a detailed explanation about setting up the database in Django.
Answer: The process of setting up a database is initiated by using the command edit mysite/ This is a normal Python module with a module-level representation of Django settings. Django relies on SQLite by default, which is easy to be used as it doesn’t require any other installation.

SQLite stores data as a single file in the filesystem. Now, you need to tell Django how to use the database. For this, the project’s file needs to be used. Following code must be added to the file for making the database workable with the Django project:

 'default': {
 'ENGINE' : 'django.db.backends.sqlite3',
 'NAME' : os.path.join(BASE_DIR, 'db.sqlite3'),

If you need to use a database server other than the SQLite, such as MS SQL, MySQL, and PostgreSQL, then you need to use the database’s administration tools to create a brand new database for your Django project.

You have to modify the following keys in the DATABASE ‘default’ item to make the new database work with the Django project:

  • ENGINE – For example, when working with a MySQL database replace ‘django.db.backends.sqlite3’ with ‘django.db.backends.mysql’
  • NAME – Whether using SQLite or some other database management system, the database is typically a file on the system. The NAME should contain the full path to the file, including the name of that particular file.

NOTE: - Settings like Host, Password, and User needs to be added when not choosing SQLite as the database.

Check out the advantages and disadvantages of Django.

Question: How will you differentiate between deep copy and shallow copy?
Answer: We use shallow copy when a new instance type gets created. It keeps the values that are copied in the new instance. Just like it copies the values, the shallow copy also copies the reference pointers.

Reference points copied in the shallow copy reference to the original objects. Any changes made in any member of the class affects the original copy of the same. Shallow copy enables faster execution of the program.

Deep copy is used for storing values that are already copied. Unlike shallow copy, it doesn’t copy the reference pointers to the objects. Deep copy makes the reference to an object in addition to storing the new object that is pointed by some other object.

Changes made to the original copy will not affect any other copy that makes use of the referenced or stored object. Contrary to the shallow copy, deep copy makes execution of a program slower. This is due to the fact that it makes some copies for each object that is called.

Question: How will you distinguish between NumPy and SciPy?
Answer: Typically, NumPy contains nothing but the array data type and the most basic operations, such as basic element-wise functions, indexing, reshaping, and sorting. All the numerical code resides in SciPy.

As one of NumPy’s most important goals is compatibility, the library tries to retain all features supported by either of its predecessors. Hence, NumPy contains a few linear algebra functions despite the fact that these more appropriately belong to the SciPy library.

SciPy contains fully-featured versions of the linear algebra modules available to NumPy in addition to several other numerical algorithms.

People Also Read:

Question: Observe the following code:

A0 = dict(zip(('a','b','c','d','e'),(1,2,3,4,5)))
A1 = range(10)A2 = sorted([i for i in A1 if i in A0])
A3 = sorted([A0[s] for s in A0])
A4 = [i for i in A1 if i in A3]
A5 = 
A6 = [[i,i*i] for i in A1]

Write down the output of the code.

A0 = {'a': 1, 'c': 3, 'b': 2, 'e': 5, 'd': 4} # the order may vary
A1 = range(0, 10)
A2 = []
A3 = [1, 2, 3, 4, 5]
A4 = [1, 2, 3, 4, 5]
A5 =
A6 = [[0, 0], [1, 1], [2, 4], [3, 9], [4, 16], [5, 25], [6, 36], [7, 49], [8, 64], [9, 81]]

Question: Python has something called the dictionary. Explain using an example.
Answer: A dictionary in Python programming language is an unordered collection of data values such as a map. Dictionary holds key:value pair. It helps in defining a one-to-one relationship between keys and values. Indexed by keys, a typical dictionary contains a pair of keys and corresponding values.

Let us take an example with three keys, namely Website, Language, and Offering. Their corresponding values are, Python, and Tutorials. The code for the example will be:

print dict[Website] #Prints
print dict[Language] #Prints Python
print dict[Offering] #Prints Tutorials

Question: Python supports negative indexes. What are they and why are they used?
Answer: The sequences in Python are indexed. It consists of the positive and negative numbers. Positive numbers use 0 as the first index, 1 as the second index, and so on. Hence, any index for a positive number n is n-1.

Unlike positive numbers, index numbering for the negative numbers start from -1 and it represents the last index in the sequence. Likewise, -2 represents the penultimate index. These are known as negative indexes. Negative indexes are used for:

  • Removing any new-line spaces from the string, thus allowing the string to except the last character, represented as S[:-1]
  • Showing the index to representing the string in the correct order

Question: Suppose you need to collect and print data from IMDb top 250 Movies page. Write a program in Python for doing so. (NOTE: - You can limit the displayed information for 3 fields; namely movie name, release year, and rating.)

from bs4 import BeautifulSoup
import requests
import sys
url = ''
response = requests.get(url)
soup = BeautifulSoup(response.text)
tr = soup.findChildren("tr")
tr = iter(tr)
for movie in tr:
title = movie.find('td', {'class': 'titleColumn'} ).find('a').contents[0]
year = movie.find('td', {'class': 'titleColumn'} ).find('span', {'class': 'secondaryInfo'}).contents[0]
rating = movie.find('td', {'class': 'ratingColumn imdbRating'} ).find('strong').contents[0]
row = title + ' - ' + year + ' ' + ' ' + rating 
Question: Take a look at the following code:
 if '1' != 1:
 raise "someError"
 print("someError has not occured")
except "someError":
 print ("someError has occured")

What will be the output?
Answer: The output of the program will be “invalid code.” This is because a new exception class must inherit from a BaseException.

Question: What do you understand by monkey patching in Python?
Answer: The dynamic modifications made to a class or module at runtime are termed as monkey patching in Python. Consider the following code snippet:

class MyClass:
def f(self):
print "f()"

We can monkey-patch the program something like this:

import m
def monkey_f(self):
print "monkey_f()"
m.MyClass.f = monkey_f
obj = m.MyClass()

Output for the program will be monkey_f().

The examples demonstrate changes made in the behavior of f() in MyClass using the function we defined i.e. monkey_f() outside of the module m.

Question: What do you understand by the process of compilation and linking in Python?
Answer: In order to compile new extensions without any error, compiling and linking is used in Python. Linking initiates only and only when the compilation is complete.

In the case of dynamic loading, the process of compilation and linking depends on the style that is provided with the concerned system. In order to provide dynamic loading of the configuration setup files and rebuilding the interpreter, the Python interpreter is used.

Question: What is Flask and what are the benefits of using it?
Answer: Flask is a web microframework for Python with Jinja2 and Werkzeug as its dependencies. As such, it has some notable advantages:

  • Flask has little to no dependencies on external libraries
  • Because there is a little external dependency to update and fewer security bugs, the web microframework is lightweight to use.
  • Features an inbuilt development server and a fast debugger.

Question: What is the map() function used for in Python?
Answer: The map() function applies a given function to each item of an iterable. It then returns a list of the results. The value returned from the map() function can then be passed on to functions to the likes of the list() and set().

Typically, the given function is the first argument and the iterable is available as the second argument to a map() function. Several tables are given if the function takes in more than one arguments.

Question: What is Pickling and Unpickling in Python?
Answer: The Pickle module in Python allows accepting any object and then converting it into a string representation. It then dumps the same into a file by means of the dump function. This process is known as pickling.

The reverse process of pickling is known as unpickling i.e. retrieving original Python objects from a stored string representation.

Question: Whenever Python exits, all the memory isn’t deallocated. Why is it so?
Answer: Upon exiting, Python’s built-in effective cleanup mechanism comes into play and try to deallocate or destroy every other object.

However, Python modules that are having circular references to other objects or the objects that are referenced from the global namespaces aren’t always deallocated or destroyed.

This is because it is not possible to deallocate those portions of the memory that are reserved by the C library.

Question: Write a program in Python for getting indices of N maximum values in a NumPy array.

import numpy as np
arr = np.array([1, 3, 2, 4, 5])
[4 3 1]

Question: Write code to show randomizing the items of a list in place in Python along with the output.

from random import shuffle
x = ['', 'Is', 'The', 'Best', 'For', 'Learning', 'Python']
['For', 'Python', 'Learning', 'Is', 'Best', 'The', '']

That’s All!

So, that sums up the list of 20 Python interview questions. Learning never gets easier, you need to get better. So, here are some top choices for Python books to double-check you Python preparation.

All the best for your interview!

Other Trending Interview Questions:

Vijay Singh

Vijay Singh

My name is Vijay Singh Khatri, and I enjoy meeting new people and finding ways to help them have an uplifting experience. I have had a variety of customer service opportunities, through which I was able to have fewer returned products and increased repeat customers, when compared with co-workers. Currently working with View all posts by the Author

Leave a comment

Your email will not be published
Kourtney Omalley
Kourtney Omalley

What are the built in modules in Python?

Howard Wilson
Howard Wilson

There are several hundreds of built-in modules in Python. Unlike other modules, they are automatically loaded as soon as the interpreter starts. asynchat, IPython, selectors, shlex, and warnings are some of the various inbuilt Python modules. You can use the following command in Python console to get a list of all available inbuilt Python modules:
>>> help(‘modules’)

Libby Blue
Libby Blue

What is Python API?

Clove Duke
Clove Duke

An API (Application Programming Interface) is a collection of programming instructions and standards for accessing web-based software applications. A Python API is a type of plan that you can use for building Python-based applications. There are several Python APIs available to choose from

Siobhan Briones
Siobhan Briones

What is difference between framework and library?

Sebastian Matthias
Sebastian Matthias

Although conceptually, there is no difference between a Python package and Python library, we can still differentiate the two. A Python package is a collection of various Python modules, where each module is a collection of some functions and global variables. The library is a collection of various Python packages

Benny Swordsmith
Benny Swordsmith

A Python library is a set of classes or functions, also termed as modules, which have certain functionalities. A Python framework is simply a collection of several Python libraries that directs the code flow of a Python program

Audry Prosser
Audry Prosser

What is the difference between package and library?

Sebastian Matthias
Sebastian Matthias

Although conceptually, there is no difference between a Python package and Python library, we can still differentiate the two. A Python package is a collection of various Python modules, where each module is a collection of some functions and global variables. The library is a collection of various Python packages

Steffanie Lira
Steffanie Lira

What is the difference between module and package in Python?

Tom Atlas
Tom Atlas

A module is a single file or multiple files that are imported under on import and then used. A Python file can be considered a module. Its name is the file’s base name minus the .py extension. A package in Python is a collection of several Python modules

Britni London
Britni London

What is negative index?

Ronny Myers
Ronny Myers

In Python, the negative index is used for starting indexing from the last element of a list, tuple, or any other container class that provides support for indexing. A -1 index refers to the last element, -2 to the second-to-last element, and so on

Isidro Oshea
Isidro Oshea

What are generators?

John Marrow
John Marrow

In Python, generators are used for creating iterators. A generator is a simple function that returns an iterable set of items, one at a given time and in a special way. A generator function can generate as many values as required

Ruthann Thigpen
Ruthann Thigpen

How is Python interpreted?

Randy MacFarlane
Randy MacFarlane

A programming language that isn’t in machine code form before runtime is an interpreted programming language. Unlike compiled languages, translation of an interpreted language occurs during the same time as that of the program execution. As a Python program runs directly from the source code, it is a bytecode interpreted programming language.

Jasmin Carrion
Jasmin Carrion

How do I run a Python script in Windows?

Sanjay Sharma
Sanjay Sharma

To run a Python script in Windows, simply:
• Open command prompt (cmd)
• Enter C:\python27\python.exe Z:\code\hw\
• Press the enter key is the script that you wish to run. Another way is to simply drag and drop the Python script to the cmd and hitting the enter key

Cinthia Burrow
Cinthia Burrow

Why lambda forms does not have statements in Python?

Jake Freeman
Jake Freeman

It is not possible for lambda forms in Python to have statements because Python’s syntactic framework isn’t able to handle statements nested inside expressions. However, lambda forms in Python, unlike other programming languages, are merely a shorthand notation in Python