Top 100 Python Interview Questions _removed
Top 100 Python Interview Questions _removed
Preparati…
If you have other doubts regarding Python, feel free to post them in our QnA Forum. Our expert team will get back to you at the
earliest.
LIST TUPLES
Lists are mutable i.e they can be edited. Tuples are immutable (tuples are lists which can’t be edited).
Lists are slower than tuples. Tuples are faster than list.
Syntax: list_1 = [10, ‘Chelsea’, 20] Syntax: tup_1 = (10, ‘Chelsea’ , 20)
LIST vs TUPLES
Q5.What is pep 8?
Ans: PEP stands for Python Enhancement Proposal. It is a set of rules that specify how to format Python code for maximum
readability.
1. Memory management in python is managed by Python private heap space. All Python objects and data structures are
located in a private heap. The programmer does not have access to this private heap. The python interpreter takes care of
this instead.
2. The allocation of heap space for Python objects is done by Python’s memory manager. The core API gives access to some
tools for the programmer to code.
3. Python also has an inbuilt garbage collector, which recycles all the unused memory and so that it can be made available to
the heap space.
Q9. What are python modules? Name some commonly used built-in modules in Python?
Ans: Python modules are les containing Python code. This code can either be functions classes or variables. A Python module is
a .py le containing executable code.
os
sys
math
random
data time
JSON
Variables declared outside a function or in global space are called global variables. These variables can be accessed by any
function in the program.
Local Variables:
Any variable declared inside a function is known as a local variable. This variable is present in the local space and not in the
global space.
Example:
a=2
def add():
b=3
c=a+b
print(c)
add()
Output: 5
When you try to access the local variable outside the function add(), it will throw an error.
list() – This function is used to convert any data type to a list type.
dict() – This function is used to convert a tuple of order (key,value) into a dictionary.
str() – Used to convert integer into a string.
complex(real,imag) – This functionconverts real numbers to complex(real,imag) number.
Example:
Output:
Example:
def Newfunc():
print("Hi, Welcome to Edureka")
Newfunc(); #calling the function
Q17.What is __init__?
Ans: __init__ is a method or constructor in Python. This method is automatically called to allocate memory when a new object/
instance of a class is created. All classes have the __init__ method.
class Employee:
def __init__(self, name, age,salary):
self.name = name
self.age = age
self.salary = 20000
E1 = Employee("XYZ", 23, 20000)
# E1 is the instance of class Employee.
#__init__ allocates memory for E1.
print(E1.name)
print(E1.age)
print(E1.salary)
Output:
XYZ
23
20000
Example:
Output: 11
The self variable in the init method refers to the newly created object while in other methods, it refers to the object whose
method was called.
Allows loop termination when some condition is met and the control is transferred
Break
to the next statement.
Allows skipping some part of a loop when some speci c condition is met and the
Continue
control is transferred to the beginning of the loop
Used when you need some block of code syntactically, but you want to skip its
Pass
execution. This is basically a null operation. Nothing happens when this is executed.
[::-1] reprints a reversed copy of ordered data structures such as an array or a list. the original array or list remains unchanged.
Q22. How can you randomize the items of a list in place in Python?
Ans: Consider the example shown below:
import random
random.random
The statement random.random() method return the oating point number that is in the range of [0, 1). The function generates
random oat numbers. The methods that are used with the random class are the bound methods of the hidden instances. The
instances of the Random can be done to show the multi-threading programs that creates a di erent instance of individual
threads. The other random generators that are used in this are:
1. randrange(a, b): it chooses an integer and de ne the range in-between [a, b). It returns the elements by selecting it
randomly from the range that is speci ed. It doesn’t build a range object.
2. uniform(a, b): it chooses a oating point number that is de ned in the range of [a,b).Iyt returns the oating point number
3. normalvariate(mean, sdev): it is used for the normal distribution where the mu is a mean and the sdev is a sigma that is
used for standard deviation.
4. The Random class that is used and instantiated creates an independent multiple random number generators.
This means that xrange doesn’t actually generate a static list at run-time like range does. It creates the values as you need them
with a special technique called yielding. This technique is used with a type of object known as generators. That means that if you
have a really gigantic range you’d like to generate a list for, say one billion, xrange is the function to use.
This is especially true if you have a really memory sensitive system such as a cell phone that you are working with, as range will
use as much memory as it can to create your array of integers, which can result in a Memory Error and crash your program. It’s a
memory hungry beast.
Example:
Example:
stg='ABCD'
print(stg.lower())
Output: abcd
Example:
"""
Using docstring as a comment.
This code divides 2 numbers
"""
x=8
y=4
z=x/y
print(z)
Output: 2.0
is: returns true when 2 operands are true (Example: “a” is ‘a’)
1. Help() function: The help() function is used to display the documentation string and also facilitates you to see the help
related to modules, keywords, attributes, etc.
2. Dir() function: The dir() function is used to display the de ned symbols.
Q35. Whenever Python exits, why isn’t all the memory de-allocated?
Ans:
1. Whenever Python exits, especially those Python modules which are having circular references to other objects or the
objects that are referenced from the global namespaces are not always de-allocated or freed.
2. It is impossible to de-allocate those portions of memory that are reserved by the C library.
3. On exit, because of having its own e cient clean up mechanism, Python would try to de-allocate/destroy every other
object.
The following example contains some keys. Country, Capital & PM. Their corresponding values are India, Delhi and Modi
respectively.
dict={'Country':'India','Capital':'Delhi','PM':'Modi'}
print dict[Country]
India
print dict[Capital]
Delhi
print dict[PM]
Modi
Example:
The expression gets evaluated like if x<y else y, in this case if x<y is true then the value is returned as big=x and if it is incorrect
then big=y will be sent as a result.
Q38. What does this mean: *args, **kwargs? And why would we use it?
Ans: We use *args when we aren’t sure how many arguments are going to be passed to a function, or if we want to pass a stored
list or tuple of arguments to a function. **kwargs is used when we don’t know how many keyword arguments will be passed to a
function, or it can be used to pass the values of a dictionary as keyword arguments. The identi ers args and kwargs are a
convention, you could also use *bob and **billy but that would not be wise.
Example:
stg='ABCD'
len(stg)
Q41. What are negative indexes and why are they used?
Ans: The sequences in Python are indexed and it consists of the positive as well as negative numbers. The numbers that are
positive uses ‘0’ that is uses as rst index and ‘1’ as the second index and the process goes on like that.
The index for the negative number starts from ‘-1’ that represents the last index in the sequence and ‘-2’ as the penultimate index
and the sequence carries forward like the positive number.
The negative index is used to remove any new-line spaces from the string and allow the string to except the last character that is
given as S[:-1]. The negative index is also used to show the index to represent the string in correct order.
Example:
import os
os.remove("xyz.txt")
Integers
Floating-point
Complex numbers
Strings
Boolean
Built-in functions
Example:
Output:
Example:
Output:
4.6
3.1
Deep copy is used to store the values that are already copied. Deep copy doesn’t copy the reference pointers to the objects. It
makes the reference to an object and the new object that is pointed by some other object gets stored. The changes made in the
original copy won’t a ect any other copy that uses the object. Deep copy makes execution of the program slower due to making
certain copies for each object that is been called.
Q50. How is Multithreading achieved in Python?
Ans:
1. Python has a multi-threading package but if you want to multi-thread to speed your code up, then it’s usually not a good
idea to use it.
2. Python has a construct called the Global Interpreter Lock (GIL). The GIL makes sure that only one of your ‘threads’ can
execute at any one time. A thread acquires the GIL, does a little work, then passes the GIL onto the next thread.
3. This happens very quickly so to the human eye it may seem like your threads are executing in parallel, but they are really
just taking turns using the same CPU core.
4. All this GIL passing adds overhead to execution. This means that if you want to make your code run faster then using the
threading package often isn’t a good idea.
1. Create a le with any name and in any language that is supported by the compiler of your system. For example le.c or
le.cpp
2. Place this le in the Modules/ directory of the distribution which is getting used.
3. Add a line in the le Setup.local that is present in the Modules/ directory.
4. Run the le using spam le.o
5. After a successful run of this rebuild the interpreter by using the make command on the top-level directory.
6. If the le is changed then run rebuildMake le by using the command as ‘make Make le’.
Example:
a="edureka python"
print(a.split())
Modules can be imported using the import keyword. You can import modules in three ways-
Example:
1. Single Inheritance – where a derived class acquires the members of a single super class.
2. Multi-level inheritance – a derived class d1 in inherited from base class base1, and d2 are inherited from base2.
3. Hierarchical inheritance – from one base class you can inherit any number of child classes
4. Multiple inheritance – a derived class is inherited from more than one base class.
Example:
class Employee:
def __init__(self, name):
self.name = name
E1=Employee("abc")
print(E1.name)
Output: abc
# m.py
class MyClass:
def f(self):
print "f()"
import m
def monkey_f(self):
print "monkey_f()"
m.MyClass.f = monkey_f
obj = m.MyClass()
obj.f()
monkey_f()
As we can see, we did make some changes in the behavior of f() in MyClass using the function we de ned, monkey_f(), outside of
the module m.
Output:
Name = xyz
Ans: It returns a featureless object that is a base for all classes. Also, it does not take any parameters.
Basic Python Programs
Q65. Write a program in Python to execute the Bubble sort algorithm.
def bs(a): # a = name of list
b=len(a)-1 # minus 1 because we always compare 2 adjacent values
for x in range(b):
for y in range(b-x):
if a[y]>a[y+1]:
a[y],a[y+1]=a[y+1],a[y]
return a
a=[32,5,3,6,7,54,87]
bs(a)
def pyfunc(r):
for x in range(r):
print(' '*(r-x-1)+'*'*(2*x+1))
pyfunc(9)
Output:
*
***
*****
*******
*********
***********
*************
***************
*****************
# Enter number of terms needed
#0,1,1,2,3,5....
a=int(input("Enter the terms"))
f=0
#first element of series
s=1
#second element of series
if a<=0:
print("The requested series is
",f)
else:
print(f,s,end=" ")
for x in range(2,a):
next=f+s
print(next,end=" ")
f=s
s=next</pre>
Output:
enter number 3
Prime
Output:
Q70. Write a one-liner that will count the number of capital letters in a le. Your code should work even if the le is too
big to t in memory.
Ans: Let us rst write a multiple line solution and then convert it to one-liner code.
Q72. Looking at the below code, write down the nal values of A0, A1, …An.
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 = {i:i*i for i in A1}
A6 = [[i,i*i] for i in A1]
print(A0,A1,A2,A3,A4,A5,A6)
A session basically allows you to remember information from one request to another. In a ask, a session uses a signed cookie
so the user can look at the session contents and modify. The user can modify the session if only it has the secret key
Flask.secret_key.
Flask is much simpler compared to Django but, Flask does not do a lot for you meaning you will need to specify the details,
whereas Django does a lot for you wherein you would not need to do much work. Django consists of prewritten code, which the
user will need to analyze whereas Flask gives the users to create their own code, therefore, making it simpler to understand the
code. Technically both are equally good and both contain their own pros and cons.
Flask is a “microframework” primarily build for a small application with simpler requirements. In ask, you have to use
external libraries. Flask is ready to use.
Pyramid is built for larger applications. It provides exibility and lets the developer use the right tools for their project. The
developer can choose the database, URL structure, templating style and more. Pyramid is heavy con gurable.
Django can also be used for larger applications just like Pyramid. It includes an ORM.
Figure: Python Interview Questions – Django Architecture
The developer provides the Model, the view and the template then just maps it to a URL and Django does the magic to serve it to
the user.
Django uses SQLite by default; it is easy for Django users as such it won’t require any other type of installation. In the case your
database choice is di erent that you have to the following keys in the DATABASE ‘default’ item to match your database
connection settings.
Django uses SQLite as a default database, it stores data as a single le in the lesystem. If you do have a database server—
PostgreSQL, MySQL, Oracle, MSSQL—and want to use it rather than SQLite, then use your database’s administration tools to
create a new database for your Django project. Either way, with your (empty) database in place, all that remains is to tell Django
how to use it. This is where your project’s settings.py le comes in.
DATABASES = {
'default': {
'ENGINE' : 'django.db.backends.sqlite3',
'NAME' : os.path.join(BASE_DIR, 'db.sqlite3'),
}
}
def Current_datetime(request):
now = datetime.datetime.now()
html = "<html><body>It is now %s</body></html> % now
return HttpResponse(html)
Figure: Python Interview Questions – Django Template
Q80. Explain the use of session in Django framework?
Ans: Django provides a session that lets you store and retrieve data on a per-site-visitor basis. Django abstracts the process of
sending and receiving cookies, by placing a session ID cookie on the client side, and storing all the related data on the server side.
So the data itself is not stored client side. This is nice from a security perspective.
1. Abstract Base Classes: This style is used when you only want parent’s class to hold information that you don’t want to type
out for each child model.
2. Multi-table Inheritance: This style is used If you are sub-classing an existing model and need each model to have its own
database table.
3. Proxy models: You can use this model, If you only want to modify the Python level behavior of the model, without changing
the model’s elds.
import urllib.request
urllib.request.urlretrieve("URL", "local-filename.jpg")
Q83. How can you Get the Google cache age of any URL or web page?
Ans: Use the following URL format:
http://webcache.googleusercontent.com/search?q=cache:URLGOESHERE
Be sure to replace “URLGOESHERE” with the proper web address of the page or site whose cache you want to retrieve and see
the time for. For example, to check the Google Webcache age of edureka.co you’d use the following URL:
http://webcache.googleusercontent.com/search?q=cache:edureka.co
Q84. You are required to scrap data from IMDb top 250 movies page. It should only have elds movie name, year, and
rating.
Ans: We will use the following lines of code:
from bs4 import BeautifulSoup
import requests
import sys
url = 'http://www.imdb.com/chart/top'
response = requests.get(url)
soup = BeautifulSoup(response.text)
tr = soup.findChildren("tr")
tr = iter(tr)
next(tr)
print(row)
The above code will help scrap data from IMDb’s top 250 list
1. Less Memory
2. Fast
3. Convenient
For more information on these parameters, you can refer to this section – Numpy Vs List.
import numpy as np
arr = np.array([1, 3, 2, 4, 5])
print(arr.argsort()[-3:][::-1])
Output
[ 4 3 1 ]
import numpy as np
a = np.array([1,2,3,4,5])
p = np.percentile(a, 50) #Returns 50th percentile, e.g. median
print(p)
Output
1. In an ideal world, NumPy would contain nothing but the array data type and the most basic operations: indexing, sorting,
reshaping, basic elementwise functions, et cetera.
2. All numerical code would reside in SciPy. However, one of NumPy’s important goals is compatibility, so NumPy tries to
retain all features supported by either of its predecessors.
3. Thus NumPy contains some linear algebra functions, even though these more properly belong in SciPy. In any case, SciPy
contains more fully-featured versions of the linear algebra modules, as well as many other numerical algorithms.
4. If you are doing scienti c computing with python, you should probably install both NumPy and SciPy. Most new features
belong in SciPy rather than NumPy.
Ans: Like 2D plotting, 3D graphics is beyond the scope of NumPy and SciPy, but just as in the 2D case, packages exist that
integrate with NumPy. Matplotlib provides basic 3D plotting in the mplot3d subpackage, whereas Mayavi provides a wide range
of high-quality 3D visualization features, utilizing the powerful VTK engine.
When both of the operands are integer then python chops out the fraction part and gives you the round o value, to get the
accurate answer use oor division. For ex, 5/2 = 2.5 but both of the operands are integer so answer of this expression in python
is 2. To get the 2.5 as the answer, use oor division using //. So, 5//2 = 2.5
Q94. Why are local variable names beginning with an underscore discouraged?
a) they are used to indicate a private variables of a class
b) they confuse the interpreter
c) they are used to indicate global variables
d) they slow down execution
Answer: a) they are used to indicate a private variable of a class
As Python has no concept of private variables, leading underscores are used to indicate variables that must not be accessed from
outside the class.
try:
if '1' != 1:
raise "someError"
else:
print("someError has not occured")
except "someError":
print ("someError has occured")
A new exception class must inherit from a BaseException. There is no such inheritance here.
Q97. Suppose list1 is [2, 33, 222, 14, 25], What is list1[-1] ?
a) Error
b) None
c) 25
d) 2
Answer: c) 25
print f.closed
a) True
b) False
c) None
d) Error
Answer: a) True
The WITH statement when used with open le guarantees that the le object is closed when the with block exits.
I hope this set of Python Interview Questions will help you in preparing for your interviews. All the best!
Got a question for us? Please mention it in the comments section and we will get back to you at the earliest.
If you wish to learn Python and gain expertise in quantitative analysis, data mining, and the presentation of data to see beyond
the numbers by transforming your career into Data Scientist role, check out our interactive, live-online Python Certi cation
Training. You will use libraries like Pandas, Numpy, Matplotlib, Scipy, Scikit, Pyspark and master the concepts like Python
machine learning, scripts, sequence, web scraping and big data analytics leveraging Apache Spark. The training comes with 24*7
support to guide you throughout your learning period.