- Pandas - Install Python and Pandas
- Basic Data Structures in Pandas
- Loading and Saving Data using Pandas
- Exploring Data using pandas
- Correlation Analysis using pandas
- Handling Categorical Data and Unique Values using pandas
- Data Visualization using pandas
- Handling Missing Data in Python
- Strategies for Handling Missing Data
- Handling Missing Data - Example - Part 1
- Handling Missing Data - Example - Part 2
- Handling Missing Data - Example - Part 3 (Non-numeric Values)
- Handling Missing Data - Example - Part 4
- Data Transformation and Feature Engineering
- Converting Data Types in Python pandas
- Encoding Categorical Data in Python pandas
- Handling Date and Time Data in Python pandas
- Renaming Columns in Python pandas
- Filtering Rows in a DataFrame in Python
- Merging and Joining Datasets in Python pandas
- Sorting and Indexing Data for Efficient Analysis in Python
Converting Data Types in Python pandas
Appropriate data types are crucial for efficient memory usage and compatibility with analysis tools. Let’s first check the data types of each column in our loans data frame. To check the data types of each field in a pandas DataFrame in Python, you can use the .dtypes attribute. This attribute returns a Series with the data type of each column.
print(loan_data_cleaned.dtypes)
Once you have the data types, you can follow these general rules to decide on the correct data type for each column and how to fix them:
Numeric Data: Should typically be int for whole numbers or float for numbers with decimals. Use pd.to_numeric() to convert columns to a numeric data type.
Dates: Should be in datetime format for easier manipulation of date-related operations. Use pd.to_datetime() to convert date columns, specifying the date format if necessary.
Categorical Data: If a column has a limited set of values that repeat (like LoanAmountCategory or LoanStatus), you can convert it to category type using .astype('category') to save memory.
Boolean Data: Should be bool if it contains only two values representing True/False conditions.
String Data: If the data is textual, ensure it is of object type, which is the default for strings in pandas. Use .astype(str) to convert a column to strings. The CustomerName column should contain strings, so it should be of object type.
In our data, we will perform the following data type transformations:
Convert LoanStatus to category type
Convert LoanAmountCategory to category type
Convert CustomerLoyalty to category type
Convert LoanDurationDays from float to int
Convert Total Loans by customers from float to int
You can convert the data types of columns in a pandas DataFrame using the astype method. For the numeric columns that you want to convert from float to int, you'll need to ensure there are no missing values because NaN (not a number) is a float value and cannot exist in an integer column. Since we’ve already handled all NaNs in our data, we can convert the data types for the specified columns:
# Convert 'LoanStatus', 'LoanAmountCategory', and 'CustomerLoyalty' to category type
loan_data_cleaned['LoanStatus'] = loan_data_cleaned['LoanStatus'].astype('category')
loan_data_cleaned['LoanAmountCategory'] = loan_data_cleaned['LoanAmountCategory'].astype('category')
loan_data_cleaned['CustomerLoyalty'] = loan_data_cleaned['CustomerLoyalty'].astype('category')
# Convert 'LoanDurationDays' from float to int (assuming no NaN values are present)
loan_data_cleaned['LoanDurationDays'] = loan_data_cleaned['LoanDurationDays'].astype(int)
# Convert 'TotalLoansByCustomer' from float to int (assuming no NaN values are present)
loan_data_cleaned['TotalLoansByCustomer'] = loan_data_cleaned['TotalLoansByCustomer'].astype(int)
# Verify the changes
loan_data_cleaned.dtypes
We now have a pretty good and clean dataset.
You may find these interesting
Related Downloads
Free Guides - Getting Started with R and Python
Enter your name and email address below and we will email you the guides for R programming and Python.