Python Pandas interview questions

Python Pandas interview questions

A list of top frequently asked Python Pandas Interview Questions and answers are given below.

1) Define the Pandas/Python pandas?

Pandas is defined as an open-source library that provides high-performance data manipulation in Python. The name of Pandas is derived from the word Panel Data, which means an Econometrics from Multidimensional data. It can be used for data analysis in Python and developed by Wes McKinney in 2008. It can perform five significant steps that are required for processing and analysis of data irrespective of the origin of the data, i.e., load, manipulate, prepare, model, and analyze.


2) Mention the different types of Data Structures in Pandas?

Pandas provide two data structures, which are supported by the pandas library, Series, and DataFrames. Both of these data structures are built on top of the NumPy.

  • A Series is a one-dimensional labeled array capable of holding any data type.
  • A Dataframe is a two-dimensional labeled data structure with columns that can be of different types (numeric, string, boolean, etc.).
  • An Index is an immutable array used for axis labels in both Series and DataFrame.
  • A Panel is a three-dimensional data structure. However, Panels have been deprecated in recent versions of Pandas.

3) Define Series in Pandas?

A Series is defined as a one-dimensional array that is capable of storing various data types. The row labels of series are called the index. By using a 'series' method, we can easily convert the list, tuple, and dictionary into series. A Series cannot contain multiple columns.


4) How can we calculate the standard deviation from the Series?

The Pandas std() is defined as a function for calculating the standard deviation of the given set of numbers, DataFrame, column, and rows.

Series.std(axis=None, skipna=None, level=None, ddof=1, numeric_only=None, **kwargs)


5) Define DataFrame in Pandas?

A DataFrame is a widely used data structure of pandas and works with a two-dimensional array with labeled axes (rows and columns) DataFrame is defined as a standard way to store data and has two different indexes, i.e., row index and column index. It consists of the following properties:

  • The columns can be heterogeneous types like int and bool.
  • It can be seen as a dictionary of Series structure where both the rows and columns are indexed. It is denoted as "columns" in the case of columns and "index" in case of rows.

6) What are the significant features of the pandas Library?

The key features of the panda's library are as follows:

  • Memory Efficient: Pandas is designed for memory efficiency and optimized for performance, making it suitable for working with large datasets.
  • Data Alignment: Automatic and explicit data alignment is a crucial feature. Objects can be explicitly aligned to a set of labels or automatically aligned based on labels or integer indices.
  • Reshaping: Reshaping in the context of Pandas refers to reorganizing or transforming the structure of your data.
  • Merge and join: Pandas supports merging and joining of datasets, similar to SQL databases. This is useful for combining data from different sources.
  • Time Series: Pandas has robust support for working with time series data, including date range generation, frequency conversion, and resampling.

7) Explain Reindexing in pandas?

Reindexing is used to conform DataFrame to a new index with optional filling logic. It places NA/NaN in that location where the values are not present in the previous index. It returns a new object unless the new index is produced as equivalent to the current one, and the value of copy becomes False. It is used to change the index of the rows and columns of the DataFrame.


8) What is the name of Pandas library tools used to create a scatter plot matrix?

Scatter_matrix

A Scatter matrix, otherwise called a scatterplot grid or matches plot, is a graphical portrayal of the connections between various factors in a dataset. It comprises of a lattice of scatterplots, where each scatterplot shows the connection between two factors. In the event that there are "n" factors in the dataset, the Scatter matrix will be an "n x n" lattice.

In a Scatter matrix, every cell in the matrix addresses the scatterplot of two explicit factors. The inclining cells typically show histograms or part thickness plots for every individual variable, showing the dissemination of values along that variable.


9) Define the different ways a DataFrame can be created in pandas?

We can create a DataFrame using following ways:

  • Lists
  • Dict of ndarrays

Example-1: Create a DataFrame using List:

Output:

	0
0   Python
1   Pandas

Example-2: Create a DataFrame from dict of ndarrays:

Output:

       ID      Department
0      101        B.Sc
1      102        B.Tech
2      103        M.Tech

10) Explain Categorical data in Pandas?

A Categorical data is defined as a Pandas data type that corresponds to a categorical variable in statistics. A categorical variable is generally used to take a limited and usually fixed number of possible values. Examples: gender, country affiliation, blood type, social class, observation time, or rating via Likert scales. All values of categorical data are either in categories or np.nan.

This data type is useful in the following cases:

  • It is useful for a string variable that consists of only a few different values. If we want to save some memory, we can convert a string variable to a categorical variable.
  • It is useful for the lexical order of a variable that is not the same as the logical order (?one?, ?two?, ?three?) By converting into a categorical and specify an order on the categories, sorting and min/max is responsible for using the logical order instead of the lexical order.
  • It is useful as a signal to other Python libraries because this column should be treated as a categorical variable.

11) How will you create a series from dict in Pandas?

A Series is defined as a one-dimensional array that is capable of storing various data types.

We can create a Pandas Series from Dictionary:

Create a Series from dict:

We can also create a Series from dict. If the dictionary object is being passed as an input and the index is not specified, then the dictionary keys are taken in a sorted order to construct the index.

If index is passed, then values correspond to a particular label in the index will be extracted from the dictionary.

Output:

x     0.0
y     1.0
z     2.0
dtype: float64

12) How can we create a copy of the series in Pandas?

We can create the copy of series by using the following syntax:

pandas.Series.copy
Series.copy(deep=True)

The above statements make a deep copy that includes a copy of the data and the indices. If we set the value of deep to False, it will neither copy the indices nor the data.

Note: If we set deep=True, the data will be copied, and the actual python objects will not be copied recursively, only the reference to the object will be copied.


13) How will you create an empty DataFrame in Pandas?

A DataFrame is a widely used data structure of pandas and works with a two-dimensional array with labeled axes (rows and columns) It is defined as a standard way to store data and has two different indexes, i.e., row index and column index.

Create an empty DataFrame:

The below code shows how to create an empty DataFrame in Pandas:

Output:

Empty DataFrame
Columns: []
Index: []

14) How will you add a column to a pandas DataFrame?

We can add any new column to an existing DataFrame. The below code demonstrates how to add any new column to an existing DataFrame:

Output:

Add new column by passing series
      one     two      three
a     1.0      1        20.0
b     2.0      2        40.0
c     3.0      3        60.0
d     4.0      4        NaN
e     5.0      5        NaN
f     NaN      6        NaN

Add new column using existing DataFrame columns
       one      two       three      four
a      1.0       1         20.0      21.0
b      2.0       2         40.0      42.0
c      3.0       3         60.0      63.0
d      4.0       4         NaN      NaN
e      5.0       5         NaN      NaN
f      NaN       6        NaN      NaN

15) How to add an Index, row, or column to a Pandas DataFrame?

Adding an Index to a DataFrame

Pandas allow adding the inputs to the index argument if you create a DataFrame. It will make sure that you have the desired index. If you don?t specify inputs, the DataFrame contains, by default, a numerically valued index that starts with 0 and ends on the last row of the DataFrame.

Adding Rows to a DataFrame

We can use .loc, iloc, and ix to insert the rows in the DataFrame.

  • The loc basically works for the labels of our index. It can be understood as if we insert in loc[4], which means we are looking for that values of DataFrame that have an index labeled 4.
  • The iloc basically works for the positions in the index. It can be understood as if we insert in iloc[4], which means we are looking for the values of DataFrame that are present at index '4`.
  • The ix is a complex case because if the index is integer-based, we pass a label to ix. The ix[4] means that we are looking in the DataFrame for those values that have an index labeled 4. However, if the index is not only integer-based, ix will deal with the positions as iloc.

Adding Columns to a DataFrame

If we want to add the column to the DataFrame, we can easily follow the same procedure as adding an index to the DataFrame by using loc or iloc.


16) How to Delete Indices, Rows or Columns From a Pandas Data Frame?

Deleting an Index from Your DataFrame

If you want to remove the index from the DataFrame, you should have to do the following:

Reset the index of DataFrame.

Executing del df.index.name to remove the index name.

Remove duplicate index values by resetting the index and drop the duplicate values from the index column.

Remove an index with a row.

Deleting a Column from Your DataFrame

You can use the drop() method for deleting a column from the DataFrame.

The axis argument that is passed to the drop() method is either 0 if it indicates the rows and 1 if it drops the columns.

You can pass the argument inplace and set it to True to delete the column without reassign the DataFrame.

You can also delete the duplicate values from the column by using the drop_duplicates() method.

Removing a Row from Your DataFrame

By using df.drop_duplicates(), we can remove duplicate rows from the DataFrame.

You can use the drop() method to specify the index of the rows that we want to remove from the DataFrame.


17) How to Rename the Index or Columns of a Pandas DataFrame?

To rename the list or segments of a Pandas DataFrame, you can utilize the rename() strategy. For renaming the list, give a word reference planning old record values to new ones utilizing the file boundary. For renaming sections, utilize the segments boundary with a comparable word reference. The strategy returns another DataFrame with changes, and for set up adjustment, utilize the inplace=True boundary or relegate the outcome back to the first DataFrame.


18) How to iterate over a Pandas DataFrame?

Iterating over a Pandas DataFrame can be achieved utilizing strategies, for example, iterrows() for line wise cycle, iteritems() for section wise emphasis, or itertuples() for emphasizing over columns as namedtuples. It's fundamental to pick the proper strategy in light of the particular assignment.


19) How to get the items of series A not present in series B?

We can remove items present in p2 from p1 using isin() method.

Solution

0    2
1    4
2    6
dtype: int64

Explanation:

This code bit uses the pandas library to make two Series, 'p1' and 'p2', and afterward separates components in 'p1' that are absent in 'p2'. The subsequent Series, got through boolean ordering, contains components from 'p1' that don't cover with 'p2'.


20) How to get the items not common to both series A and series B?

We get all the items of p1 and p2 not common to both using below example:

Output:

0     2
1     4
2     6
5    12
6    14
7    16
dtype: int64

Explanation:

This code bit utilizes pandas and numpy to track down the novel components between two pandas Series, 'p1' and 'p2'. It first channels components elite to 'p1' utilizing boolean ordering. Then, it computes the association and convergence of 'p1' and 'p2' utilizing numpy. The eventual outcome addresses the selective association of extraordinary components somewhere in the range of 'p1' and 'p2'.


21) How to get the minimum, 25th percentile, median, 75th, and max of a numeric series?

We can compute the minimum, 25th percentile, median, 75th, and maximum of p as below example:

Output:

array([ 4.61498692, 12.15572753, 14.67780756, 17.58054104, 33.24975515])

Explanation:

This code bit uses the pandas and numpy libraries to create a pandas Series 'p' with 22 irregular numbers inspected from an ordinary conveyance with a mean of 14 and a standard deviation of 6. It likewise sets a particular irregular state for reproducibility. The code then, at that point, computes and prints the percentiles (0th, 25th, 50th, 75th, and 100th) of the created Series 'p' utilizing the numpy capability np.percentile(). In rundown, it creates an irregular dataset, sets an irregular state, and figures explicit percentiles for the dataset, giving experiences into its dispersion.


22) How to get frequency counts of unique items of a series?

We can calculate the frequency counts of each unique value p as below example:

Output:

s    4
r    4
q    3
p    3
u    3

Explanation:

This code bit utilizes the pandas and numpy libraries to make a pandas Series 'p' with 17 components haphazardly chose from the characters 'p', 'q', 'r', 's', 't', and 'u'. The code then, at that point, uses the value_counts() capability to count the events of every one of a kind component in the Series 'p'. Generally, it gives a brief rundown of the circulation of characters in the produced irregular Series.


23) How to convert a numpy array to a dataframe of given shape?

We can reshape the series p into a dataframe with 6 rows and 2 columns as below example:

Output:

0  1  2  3  4
0  3  2  5  5  1
1  3  2  5  5  5
2  1  3  1  2  6
3  1  1  1  2  2
4  3  5  3  3  3
5  2  5  3  6  4
6  3  6  6  6  5

Explanation:

In this code snippet, the pandas and numpy libraries are imported as 'pd' and 'np', separately. It creates a pandas Series 'p' with 35 irregular whole numbers somewhere in the range of 1 and 6 (comprehensive) utilizing np.random.randint(). Then, it makes a DataFrame 'data' by reshaping the upsides of 'p' into a 7x5 framework utilizing the reshape() capability. At last, the code prints the subsequent DataFrame 'data', giving an organized portrayal of the irregular number qualities in a 7x5 even configuration. Basically, it puts together the irregular information into a matrix for simpler understanding and investigation.


24) How can we convert a Series to DataFrame?

The Pandas Series.to_frame() function is used to convert the series object to the DataFrame.

name: Refers to the object. Its Default value is None. If it has one value, the passed name will be substituted for the series name.

Output:

       vals
0          a
1          b
2          c

Explanation:

The code snippet creates a pandas Series 's' with elements "a", "b", and "c", named "vals". The to_frame() method is used to convert this Series into a DataFrame, allowing for more versatile data handling with a labeled column.


25) What is Pandas NumPy array?

Numerical Python (Numpy) is defined as a Python package used for performing the various numerical computations and processing of the multidimensional and single-dimensional array elements. The calculations using Numpy arrays are faster than the normal Python array.


26) How can we convert DataFrame into a NumPy array?

For performing some high-level mathematical functions, we can convert Pandas DataFrame to numpy arrays. It uses the DataFrame.to_numpy() function.

The DataFrame.to_numpy() function is applied to the DataFrame that returns the numpy ndarray.


27) How can we convert DataFrame into an excel file?

We can export the DataFrame to the excel file by using the to_excel() function.

To write a single object to the excel file, we have to specify the target file name. If we want to write to multiple sheets, we need to create an ExcelWriter object with target filename and also need to specify the sheet in the file in which we have to write.


28) How can we sort the DataFrame?

We can efficiently perform sorting in the DataFrame through different kinds:

  • By label
  • By Actual value

By label

The DataFrame can be sorted by using the sort_index() method. It can be done by passing the axis arguments and the order of sorting. The sorting is done on row labels in ascending order by default.

By Actual Value

It is another kind through which sorting can be performed in the DataFrame. Like index sorting, sort_values() is a method for sorting the values.

It also provides a feature in which we can specify the column name of the DataFrame with which values are to be sorted. It is done by passing the 'by' argument.


29) What is Time Series in Pandas?

The Time series data is defined as an essential source for information that provides a strategy that is used in various businesses. From a conventional finance industry to the education industry, it consists of a lot of details about the time.

Time series forecasting is the machine learning modeling that deals with the Time Series data for predicting future values through Time Series modeling.


30) What is Time Offset?

A time offset, often referred to as a time zone offset, represents the difference in hours and minutes between a specific location's local time and Coordinated Universal Time (UTC). It is essential for expressing the temporal variation from the standard reference point (UTC) and is typically defined as UTC plus or minus a specific number of hours and minutes.


31) Define Time Periods?

The Time Periods represent the time span, e.g., days, years, quarter or month, etc. It is defined as a class that allows us to convert the frequency to the periods.


32) How to convert String to date?

The below code demonstrates how to convert the string to date:

Output:

2017-07-14 00:00:00
2017-07-14 00:00:00
2018-07-14 00:00:00

Explanation:

The code utilizes the datetime.strptime() technique from the datetime module to change over date strings into datetime objects. The date strings address dates in various arrangements: 'Wednesday, July 14, 2018', '14/7/17', and '14-07-2017'. The comparing datetime objects (dmy_dt1, dmy_dt2, dmy_dt3) are then printed, exhibiting the effective change. In rundown, the code shows the transformation of date strings in different arrangements into datetime objects for normalized portrayal and further control.


33) What is Data Aggregation?

The main task of Data Aggregation is to apply some aggregation to one or more columns. It uses the following:

  • sum: It is used to return the sum of the values for the requested axis.
  • min: It is used to return a minimum of the values for the requested axis.
  • max: It is used to return a maximum values for the requested axis.

34) What is Pandas Index?

Pandas Index is defined as a vital tool that selects particular rows and columns of data from a DataFrame. Its task is to organize the data and to provide fast accessing of data. It can also be called a Subset Selection.


35) Define Multiple Indexing?

Multiple indexing is defined as essential indexing because it deals with data analysis and manipulation, especially for working with higher dimensional data. It also enables us to store and manipulate data with the arbitrary number of dimensions in lower-dimensional data structures like Series and DataFrame.


36) Define ReIndexing?

Reindexing is used to change the index of the rows and columns of the DataFrame. We can reindex the single or multiple rows by using the reindex() method. Default values in the new index are assigned NaN if it is not present in the DataFrame.

DataFrame.reindex(labels=None, index=None, columns=None, axis=None, method=None, copy=True, level=None, fill_value=nan, limit=None, tolerance=None)


37) How to Set the index?

We can set the index column while making a data frame. But sometimes, a data frame is made from two or more data frames, and then the index can be changed using this method.


38) How to Reset the index?

The Reset index of the DataFrame is used to reset the index by using the 'reset_index' command. If the DataFrame has a MultiIndex, this method can remove one or more levels.


39) Describe Data Operations in Pandas?

In Pandas, there are different useful data operations for DataFrame, which are as follows:

  • Row and column selection

We can select any row and column of the DataFrame by passing the name of the rows and columns. When you select it from the DataFrame, it becomes one-dimensional and considered as Series.

  • Filter Data

We can filter the data by providing some of the boolean expressions in DataFrame.

  • Null values

A Null value occurs when no data is provided to the items. The various columns may contain no values, which are usually represented as NaN.


40) Define GroupBy in Pandas?

In Pandas, groupby() function allows us to rearrange the data by utilizing them on real-world data sets. Its primary task is to split the data into various groups. These groups are categorized based on some criteria. The objects can be divided from any of their axes.

DataFrame.groupby(by=None, axis=0, level=None, as_index=True, sort=True, group_keys=True, squeeze=False, **kwargs)




Latest Courses