Mastering Data Analysis with Pandas: A Comprehensive Guide and Tutorial

Prince
5 min readJul 9, 2023

--

Pandas

Pandas is an open-source Python library widely utilized for data manipulation and analysis tasks. It provides efficient data structures and functions that empower users to manipulate and analyze structured data effectively. With its extensive capabilities, Pandas is invaluable for activities like data cleaning, preprocessing, wrangling, and exploratory data analysis.

The core data structures in Pandas are the Series and DataFrame. A Series is a one-dimensional labeled array that can hold diverse data types. On the other hand, a DataFrame is a two-dimensional table-like structure comprising rows and columns, resembling a spreadsheet or SQL table. Leveraging these data structures, along with a wide range of functions, users can seamlessly load, transform, filter, aggregate, and visualize data.

Pandas seamlessly integrates with other popular Python libraries like NumPy, Matplotlib, and scikit-learn. This integration facilitates seamless workflows for data manipulation, analysis, and visualization. Due to its intuitive syntax and extensive functionality, Pandas has become the go-to tool for data scientists, analysts, and researchers working with tabular or structured data in Python.

In this article, I am going to Introduce all important Pandas function and I am going to explain clear and concise use of them.

  1. Importing Data and Reading files using Pandas

To import data and read files using pandas, we can use the read_* functions provided by the library.

# Importing Pandas
import pandas as pd
# Reading file using Pandas

# Read a CSV file
df = pd.read_csv('file.csv')
# Read an Excel file
df = pd.read_excel('file.xlsx')
# Read a JSON file
df = pd.read_json('file.json')
# Reading Sql query
pd.read_sql(query,connection_object)
# Read a Parquet file
df = pd.read_parquet('file.parquet')
# Read HTML tables from a URL
url = 'https://www.example.com/table.html'
tables = pd.read_html(url)

2. Viewing and Inspecting Objects

When working with data in Pandas, we can use several methods to view and inspect the objects, such as DataFrames and Series.

# For displaying first n rows of a dataframe 
df.head(n)
# For displaying last n rows of a dataframes
df.tail(n)
# For getting number of rows and columns
df.shape
# For index,Datatype and memory informations
df.info()

3. Data Selection using Pandas

Pandas provides various data selection techniques that allow you to extract specific data from DataFrames or Series.

# For getting column with label Column as series
df[column]
# Select multiple columns
df[['column_name1', 'column_name2']]
# Select a single row by label
df.loc[label]

# Select multiple rows by labels
df.loc[[label1, label2, label3]]

# Select a single row by integer index
df.iloc[index]

# Select multiple rows by integer indices
df.iloc[start_index:end_index]

# Filter rows based on a condition
df[df['column_name'] > 5]

# Filter rows using multiple conditions
df[(df['column_name1'] > 5) & (df['column_name2'] == 'value')]

# Select specific rows and columns by label
df.loc[row_labels, column_labels]

# Select specific rows and columns by integer indices
df.iloc[row_indices, column_indices]

# Select rows based on a condition and specific columns
df.loc[df['column_name'] > 5, ['column_name1', 'column_name2']]

4. Data Cleaning

Data cleaning is an essential step in the data preprocessing phase, where you transform and modify the data to ensure its accuracy, consistency, and reliability.

# Check for missing values
df.isnull()

# Drop rows with missing values
df.dropna()

# Fill missing values with a specific value
df.fillna(value)

# Interpolate missing values
df.interpolate()

# Check for duplicate rows
df.duplicated()

# Drop duplicate rows
df.drop_duplicates()

# Calculate z-score
z_scores = (df - df.mean()) / df.std()

# Identify outliers based on z-score
outliers = df[z_scores > threshold]

# Remove outliers
df_cleaned = df[z_scores <= threshold]

# Replace values in a column
df['column_name'] = df['column_name'].str.replace('old_value', 'new_value')

# Remove leading/trailing whitespace
df['column_name'] = df['column_name'].str.strip()

# Convert strings to lowercase
df['column_name'] = df['column_name'].str.lower()

# Convert column to a different data type
df['column_name'] = df['column_name'].astype('new_type')

# Convert column to datetime
df['date_column'] = pd.to_datetime(df['date_column'])

# Renaming Columns names
df.columns = ['Cat','Mat','Xat']

# Reset the index of a DataFrame
df.reset_index()

5. Filter, Sort, & Group

Pandas is a powerful library in Python for data manipulation and analysis. It provides various functions to filter, sort, and group data in a DataFrame.

# Filter rows based on a condition
df_filtered = df[df['column_name'] > 5]

# Sort DataFrame by a single column
df_sorted = df.sort_values('column_name')

# Sort DataFrame by multiple columns
df_sorted = df.sort_values(['column_name1', 'column_name2'], ascending=[True, False])

# Group DataFrame by a single column and calculate mean of another column
grouped_data = df.groupby('column_name')['other_column'].mean()

# Group DataFrame by multiple columns and calculate sum of another column
grouped_data = df.groupby(['column_name1', 'column_name2'])['other_column'].sum()

# Calculate the sum of a column
sum_value = df['column_name'].sum()

# Calculate the mean of a column
mean_value = df['column_name'].mean()

# Calculate the maximum value of a column
max_value = df['column_name'].max()

# Calculate the minimum value of a column
min_value = df['column_name'].min()

# Count the number of non-null values in a column
count = df['column_name'].count()


# Group DataFrame and reset the index
grouped_data = df.groupby('column_name')['other_column'].sum().reset_index()

6. Join/ Combine

In pandas, you can use various functions to join or combine multiple DataFrames based on common columns or indices.

# Add the rows in df to the end of df2(columns should be identicals)
df.append(df2)

# Add the columns in df to the end of df2 (For this rows should be identical)
pd.concat([df,d# Perform an outer join on column 'A'
outer_join = pd.merge(df1, df2, on='A', how='outer')f2],axis =1)

# Perform an inner join on column 'A'
inner_join = pd.merge(df1, df2, on='A', how='inner')

# Perform a left join on column 'A'
left_join = pd.merge(df1, df2, on='A', how='left')

# Perform a right join on column 'A'
right_join = pd.merge(df1, df2, on='A', how='right')

7. Statistics in Pandas

Pandas provides a wide range of statistical functions and methods to analyze data in DataFrames or Series.

# Calculate descriptive statistics of numerical columns
df.describe()

# Calculate the sum of a column
df['column_name'].sum()

# Calculate the mean of a column
df['column_name'].mean()

# Calculate the maximum value of a column
df['column_name'].max()

# Count the number of non-null values in a column
df['column_name'].count()

# Calculate the sum of a column
df['column_name'].sum()

# Calculate the mean of a column
df['column_name'].mean()

# Calculate the maximum value of a column
df['column_name'].max()

# Count the number of non-null values in a column
df['column_name'].count()

# Count the occurrences of unique values in a column
df['column_name'].value_counts()

8. Exporting data

Pandas is a powerful Python library for data manipulation and analysis. It provides various functions for exporting data to different formats.

# Exporting in csv format
df.to_csv('filename.csv', index=False) # Exporting without row index

# Exporting in Excel Formats
data.to_excel('filename.xlsx', index=False) # Exporting without row index

# Exporting in Json Formats
data.to_json('filename.json', orient='records')

# Exporting in SQL Formats
data.to_sql('table_name', con=engine, if_exists='replace', index=False)

Thank you for reading my article! If you found it valuable and enjoyed the content, I would greatly appreciate your support. Please consider giving it a like 👍 and following me for more insightful articles on Data Science. Your support motivates me to continue sharing valuable content with you. Stay tuned for more exciting articles coming your way! Feel free to connect with me and share your thoughts in the comments.

--

--