Python Trivia
How to remove values to a python array?
Array elements can be removed using pop() or remove() method. The difference between these two functions is that the former returns the deleted value whereas the latter does not.
How are classes created in Python?
Class in Python is created using the class keyword.
The format() method allows you to format selected parts of a string. Sometimes there are parts of a text that you do not control, maybe they come from a database, or user input?
price = 49 txt = "The price is {} dollars" print(txt.format(price))
What are the built-in types of python?
Built-in types in Python are as follows - Integers Floating-point Complex numbers Strings Boolean Built-in functions
What are the generators in python?
Functions that return an iterable set of items are called generators.
What does len() do?
It is used to determine the length of a string, a list, an array, etc.
What are python iterators?
Iterators are objects which can be traversed though or iterated upon.
Data type in Python
Text Type:str Numeric Types:int, float, complex Sequence Types:list, tuple, range Mapping Type:dict Set Types:set, frozenset Boolean Type:bool Binary Types:bytes, bytearray, memoryview
How will you convert a string to all lowercase?
To convert a string to lowercase, lower() function can be used.
Is python case sensitive?
Yes. Python is a case sensitive language.
Python an interpreted language. Explain.
An interpreted language is any programming language which is not in machine-level code before runtime. Therefore, Python is an interpreted language.
What is namespace in Python?
A namespace is a naming system used to make sure that names are unique to avoid naming conflicts.
What is a package
A package contains all the files you need for a module. Modules are Python code libraries you can include in your project.
What is the difference between Python Arrays and lists?
Arrays and lists, in Python, have the same way of storing data. But, arrays can hold only a single data type elements whereas lists can hold any data type elements.
How does break, continue and pass work?
Break: Allows loop termination when some condition is met and the control is transferred to the next statement. Continue: Allows skipping some part of a loop when some specific condition is met and the control is transferred to the beginning of the loop Pass: Used when you need some block of code syntactically, but you want to skip its execution. This is basically a null operation. Nothing happens when this is executed.
How do you do data abstraction in Python?
Data Abstraction is providing only the required details and hiding the implementation from the world. It can be achieved in Python by using interfaces and abstract classes.
Define encapsulation in Python?
Encapsulation means binding the code and the data together. A Python class in an example of encapsulation.
Explain Inheritance in Python with an example.
Inheritance allows One class to gain all the members(say attributes and methods) of another class. Inheritance provides code reusability, makes it easier to create and maintain an application. The class from which we are inheriting is called super-class and the class that is inherited is called a derived / child class. They are different types of inheritance supported by Python: Single Inheritance - where a derived class acquires the members of a single super class. Multi-level inheritance - a derived class d1 in inherited from base class base1, and d2 are inherited from base Hierarchical inheritance - from one base class you can inherit any number of child classes Multiple inheritance - a derived class is inherited from more than one base class.
Is indentation required in python?
Indentation is necessary for Python. It specifies a block of code. All code within loops, classes, functions, etc is specified within an indented block. It is usually done using four space characters. If your code is not indented necessarily, it will not execute accurately and will throw errors as well.
What is PYTHONPATH?
It is an environment variable which is used when a module is imported. Whenever a module is imported, PYTHONPATH is also looked up to check for the presence of the imported modules in various directories. The interpreter uses it to determine which module to load.
How will you capitalize the first letter of string?
In Python, the capitalize() method capitalizes the first letter of a string. If the string already consists of a capital letter at the beginning, then, it returns the original string.
How is Multithreading achieved in Python?
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. 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. 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. 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.
What are python modules? Name some commonly used built-in modules in Python?
Python modules are files containing Python code. This code can either be functions classes or variables. A Python module is a .py file containing executable code. Some of the commonly used built-in modules are: os sys math random data time JSON
What are Python packages?
Python packages are namespaces containing multiple modules.
How to import modules in python?
Modules can be imported using the import keyword. You can import modules in three ways- import array #importing using the original module name import array as arr # importing using an alias name from array import * #imports everything present in the array module
What is the purpose of is, not and in operators?
Operators are special functions. They take one or more values and produce a corresponding result. is: returns true when 2 operands are true (Example: "a" is 'a') not: returns the inverse of the boolean value in: checks if some element is present in some sequence
What is self in Python?
Self is an instance or an object of a class. In Python, this is explicitly included as the first parameter. However, this is not the case in Java where it's optional. It helps to differentiate between the methods and attributes of a class with local variables. 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.
How can the ternary operators be used in python?
The Ternary operator is the operator that is used to show the conditional statements. This consists of the true or false values with a statement that has to be evaluated for it.
What are negative indexes and why are they used?
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 first 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.
What is split used for?
The split() method is used to separate a given string in Python.
Explain split(), sub(), subn() methods of "re" module in Python.
To modify the strings, Python's "re" module is providing 3 methods. They are: split() - uses a regex pattern to "split" a given string into a list. sub() - finds all substrings where the regex pattern matches and then replace them with a different string subn() - it is similar to sub() and also returns the new string along with the no. of replacements.
What is type conversion in Python?
Type conversion refers to the conversion of one data type iinto another. int() - converts any data type into integer type float() - converts any data type into float type ord() - converts characters into integer hex() - converts integers to hexadecimal oct() - converts integer to octal tuple() - This function is used to convert to a tuple. set() - This function returns the type after converting to set. 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.
What are local variables and global variables in Python?
Variables declared outside a function or in global space are called global variables. These variables can be accessed by any function in the program. 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.
What does this mean: *args, **kwargs? And why would we use it?
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 identifiers args and kwargs are a convention, you could also use *bob and **billy but that would not be wise.
What does [::-1} do?
[::-1] is used to reverse the order of an array or a sequence. [::-1] reprints a reversed copy of ordered data structures such as an array or a list. the original array or list remains unchanged.
What is __init__?
__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.
You can assign a multiline string to a variable by using three single or double quotes
a = """Lorem ipsum dolor sit amet,consectetur adipiscing elit,sed do eiusmod tempor incididuntut labore et dolore magna aliqua.""" print(a)
lower, upper, strip, replace, split
a = "Hello, World!" print(a.upper()) print(a.lower()) print(a.strip()) # returns "Hello, World!" print(a.replace("H", "J")) print(a.split(",")) # returns ['Hello', ' World!']
String slice. String starts at index 0
b = "Hello, World!" print(b[2:5]) #position 2 to position 5 (not included) print(b[:5]) #the start to position 5 (not included) print(b[2:5]) #from position 2, and all the way to the end print(b[-5:-2]) #From: "o" in "World!" (position -5) To, but not included: "d" in "World!" (position -2):
To check if a certain phrase or character is present in a string, we can use the keyword in. To check if a certain phrase or character is NOT present in a string, we can use the keyword not in.
txt = "The best things in life are free!" if "free" in txt: print("Yes, 'free' is present.")
You can get the data type of a variable with the type() function
x = 5 y = "John" print(type(x)) print(type(y))
A lambda function is a small anonymous function. A lambda function can take any number of arguments, but can only have one expression. Use lambda functions when an anonymous function is required for a short period of time.
x = lambda a, b : a * b print(x(5, 6))
List comprehension offers a shorter syntax when you want to create a new list based on the values of an existing list. Shortest form for looping through a list
fruits = ["apple", "banana", "cherry", "kiwi", "mango"] newlist = [x for x in fruits if "a" in x] newlist = [x for x in fruits if x != "apple"] onlu put words in new list that is not apple newlist = [x.upper() for x in fruits] Set the values in the new list to upper case
If you have a collection of values in a list, tuple etc. Python allows you extract the values into variables. This is called unpacking.
fruits = ["apple", "banana", "cherry"] x, y, z = fruits print(x) print(y) print(z)
pass statement
if statements cannot be empty, but if you for some reason have an if statement with no content, put in the pass statement to avoid getting an error.
Python List
testList = [] a collection of items eahc with value, editable and duplicates allowed (like a vector) testList[2:] if "apple" in testList (to search for items) insert() to insert by not replace testList[2] = "new val" append() to add to end of list extend() to append el from another list to cur list. .remove(el) to remove from list .pop() to remove last el on list clear() empty the list sort() or sort(reverse = True) .reverse() reverse the order of the list .copy() or list(testList) to copy a list
Tuple: Tuples are used to store multiple items in a single variable. Tuple is one of 4 built-in data types in Python used to store collections of data, the other 3 are List, Set, and Dictionary, all with different qualities and usage. A tuple is a collection which is ordered and unchangeable.
thistuple = ("apple", "banana", "cherry") print(thistuple[1]) print(thistuple[-1]) # Print the last item of the tuple print(thistuple[2:5]) print(thistuple[:4]) print(thistuple[2:]) if "apple" in thistuple: print("Yes, 'apple' is in the fruits tuple")
How can you randomize the items of a list in place in Python?
shuffle(x), where x is a list
Try, except, raise, finally
Try is try except is catch raise is throw finally is finally
Lists, tuples, dictionaries, and sets are all iterable objects. They are iterable containers which you can get an iterator from. All these objects have a iter() method which is used to get an iterator. We can also use a for loop to iterate through an iterable object. The for loop actually creates an iterator object and executes the next() method for each loop.
mytuple = ("apple", "banana", "cherry") myit = iter(mytuple) print(next(myit)) print(next(myit)) print(next(myit))
user input, ask from user
username = input("Enter username:") print("Username is: " + username)
How to create an empty class in Python?
An empty class is a class that does not have any code defined within its block. It can be created using the pass keyword. However, you can create objects of this class outside the class itself. IN PYTHON THE PASS command does nothing when its executed. it's a null statement
What is Polymorphism in Python?
Polymorphism means the ability to take multiple forms. So, for instance, if the parent class has a method named ABC then the child class also can have a method with the same name ABC having its own parameters and variables. Python allows polymorphism.
How do you write comments in python?
Comments in Python start with a # character. However, alternatively at times, commenting is done using docstrings(strings enclosed within triple quotes).
Does python support multiple inheritance?
Multiple inheritance means that a class can be derived from more than one parent classes. Python does support multiple inheritance, unlike Java.
how can you generate random numbers in Python?
Random module is the standard module that is used to generate a random number. The method is defined as: import random random.random The statement random.random() method return the floating point number that is in the range of [0, 1). The function generates random float 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 different instance of individual threads. The other random generators that are used in this are: randrange(a, b): it chooses an integer and define the range in-between [a, b). It returns the elements by selecting it randomly from the range that is specified. It doesn't build a range object. uniform(a, b): it chooses a floating point number that is defined in the range of [a,b).Iyt returns the floating point number 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. The Random class that is used and instantiated creates independent multiple random number generators.
What is a dictionary in Python?
The built-in datatypes in Python is called dictionary. It defines one-to-one relationship between keys and values. Dictionaries contain pair of keys and their corresponding values. Dictionaries are indexed by keys. Let's take an example: The following example contains some keys. Country, Capital & PM. Their corresponding values are India, Delhi and Modi respectively.
What are functions in Python?
A function is a block of code which is executed only when it is called. To define a Python function, the def keyword is used.
What is a lambda function?
An anonymous function is known as a lambda function. This function can have any number of parameters but, can have just one statement.
What type of language is python? Programming or scripting?
Ans: Python is capable of scripting, but in general sense, it is considered as a general-purpose programming language. To know more about Scripting, you can refer to the Python Scripting Tutorial.
What are docstrings in Python?
Docstrings are not actually comments, but, they are documentation strings. These docstrings are within triple quotes. They are not assigned to any variable and therefore, at times, serve the purpose of comments as well.
How to add values to a python array?
Elements can be added to an array using the append(), extend() and the insert (i,x) functions.
What is the difference between range & xrange?
For the most part, xrange and range are the exact same in terms of functionality. They both provide a way to generate a list of integers for you to use, however you please. The only difference is that range returns a Python list object and x range returns an xrange object. 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.
What is the usage of help() and dir() function in Python?
Help() and dir() both functions are accessible from the Python interpreter and used for viewing a consolidated dump of built-in functions. 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. Dir() function: The dir() function is used to display the defined symbols.
How to install Python on Windows and set path variable?
Install python from this link: https://www.python.org/downloads/ After this, install it on your PC. Look for the location where PYTHON has been installed on your PC using the following command on your command prompt: cmd python. Then go to advanced system settings and add a new variable and name it as PYTHON_NAME and paste the copied path. Look for the path variable, select its value and select 'edit'. Add a semicolon towards the end of the value if it's not present and then type %PYTHON_HOME%
What is the difference between list and tuples in Python?
LISTTUPLESLists 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)
How is memory managed in Python?
Memory is managed in Python in the following ways: 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. 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. 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.
The global Keyword
Normally, when you create a variable inside a function, that variable is local, and can only be used inside that function. To create a global variable inside a function, you can use the global keyword. Also, use the global keyword if you want to change a global variable inside a function.
What is pep 8?
PEP stands for Python Enhancement Proposal. It is a set of rules that specify how to format Python code for maximum readability.
PIP
PIP is a package manager. A package manager is a programming language's tool to create project environments and easily import external dependencies.
What is pickling and unpickling?
Pickle module accepts any Python object and converts it into a string representation and dumps it into a file by using dump function, this process is called pickling. While the process of retrieving original Python objects from the stored string representation is called unpickling.
Does python make use of access specifiers?
Python does not deprive access to an instance variable or function. Python lays down the concept of prefixing the name of the variable, function or method with a single or double underscore to imitate the behavior of protected and private access specifiers.
What are Python libraries? Name a few of them.
Python libraries are a collection of Python packages. Some of the majorly used python libraries are - Numpy, Pandas, Matplotlib, Scikit-learn and many more.
What are the key features of Python?
Python is an interpreted language. That means that, unlike languages like C and its variants, Python does not need to be compiled before it is run. Other interpreted languages include PHP and Ruby. Python is dynamically typed, this means that you don't need to state the types of variables when you declare them or anything like that. You can do things like x=111 and then x="I'm a string" without error Python is well suited to object orientated programming in that it allows the definition of classes along with composition and inheritance. Python does not have access specifiers (like C++'s public, private). In Python, functions are first-class objects. This means that they can be assigned to variables, returned from other functions and passed into functions. Classes are also first class objects Writing Python code is quick but running it is often slower than compiled languages. Fortunately,Python allows the inclusion of C-based extensions so bottlenecks can be optimized away and often are. The numpy package is a good example of this, it's really quite quick because a lot of the number-crunching it does isn't actually done by Python Python finds use in many spheres - web applications, automation, scientific modeling, big data applications and many more. It's also often used as "glue" code to get other languages and components to play nice.
Does Python have OOps concepts?
Python is an object-oriented programming language. This means that any program can be solved in python by creating an object model. However, Python can be treated as procedural as well as structural language.
What advantages do NumPy arrays offer over (nested) Python lists?
Python's lists are efficient general-purpose containers. They support (fairly) efficient insertion, deletion, appending, and concatenation, and Python's list comprehensions make them easy to construct and manipulate. They have certain limitations: they don't support "vectorized" operations like elementwise addition and multiplication, and the fact that they can contain objects of differing types mean that Python must store type information for every element, and must execute type dispatching code when operating on each element. NumPy is not just more efficient; it is also more convenient. You get a lot of vector and matrix operations for free, which sometimes allow one to avoid unnecessary work. And they are also efficiently implemented. NumPy array is faster and You get a lot built in with NumPy, FFTs, convolutions, fast searching, basic statistics, linear algebra, histograms, etc.
What is the difference between deep and shallow copy?
Shallow copy is used when a new instance type gets created and it keeps the values that are copied in the new instance. Shallow copy is used to copy the reference pointers just like it copies the values. These references point to the original objects and the changes made in any member of the class will also affect the original copy of it. Shallow copy allows faster execution of the program and it depends on the size of the data that is used. 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 affect 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.
What is the process of compilation and linking in python?
The compiling and linking allows the new extensions to be compiled properly without any error and the linking can be done only when it passes the compiled procedure. If the dynamic loading is used then it depends on the style that is being provided with the system. The python interpreter can be used to provide the dynamic loading of the configuration setup files and will rebuild the interpreter. The steps that are required in this as: Create a file with any name and in any language that is supported by the compiler of your system. For example file.c or file.cpp Place this file in the Modules/ directory of the distribution which is getting used. Add a line in the file Setup.local that is present in the Modules/ directory. Run the file using spam file.o After a successful run of this rebuild the interpreter by using the make command on the top-level directory. If the file is changed then run rebuildMakefile by using the command as 'make Makefile'.
How can files be deleted in Python?
To delete a file in Python, you need to import the OS Module. After that, you need to use the os.remove() function.
fruits = ("apple", "banana", "cherry", "strawberry", "raspberry") (green, yellow, *red) = fruitsprint(green) print(yellow) print(red)
Unpackign a tuple: If the number of variables is less than the number of values, you can add an * to the variable name and the values will be assigned to the variable as a list.
Whenever Python exits, why isn't all the memory de-allocated?
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. It is impossible to de-allocate those portions of memory that are reserved by the C library. On exit, because of having its own efficient clean up mechanism, Python would try to de-allocate/destroy every other object.