 
- Python Pandas - Home
- Python Pandas - Introduction
- Python Pandas - Environment Setup
- Python Pandas - Basics
- Python Pandas - Introduction to Data Structures
- Python Pandas - Index Objects
- Python Pandas - Panel
- Python Pandas - Basic Functionality
- Python Pandas - Indexing & Selecting Data
- Python Pandas - Series
- Python Pandas - Series
- Python Pandas - Slicing a Series Object
- Python Pandas - Attributes of a Series Object
- Python Pandas - Arithmetic Operations on Series Object
- Python Pandas - Converting Series to Other Objects
- Python Pandas - DataFrame
- Python Pandas - DataFrame
- Python Pandas - Accessing DataFrame
- Python Pandas - Slicing a DataFrame Object
- Python Pandas - Modifying DataFrame
- Python Pandas - Removing Rows from a DataFrame
- Python Pandas - Arithmetic Operations on DataFrame
- Python Pandas - IO Tools
- Python Pandas - IO Tools
- Python Pandas - Working with CSV Format
- Python Pandas - Reading & Writing JSON Files
- Python Pandas - Reading Data from an Excel File
- Python Pandas - Writing Data to Excel Files
- Python Pandas - Working with HTML Data
- Python Pandas - Clipboard
- Python Pandas - Working with HDF5 Format
- Python Pandas - Comparison with SQL
- Python Pandas - Data Handling
- Python Pandas - Sorting
- Python Pandas - Reindexing
- Python Pandas - Iteration
- Python Pandas - Concatenation
- Python Pandas - Statistical Functions
- Python Pandas - Descriptive Statistics
- Python Pandas - Working with Text Data
- Python Pandas - Function Application
- Python Pandas - Options & Customization
- Python Pandas - Window Functions
- Python Pandas - Aggregations
- Python Pandas - Merging/Joining
- Python Pandas - MultiIndex
- Python Pandas - Basics of MultiIndex
- Python Pandas - Indexing with MultiIndex
- Python Pandas - Advanced Reindexing with MultiIndex
- Python Pandas - Renaming MultiIndex Labels
- Python Pandas - Sorting a MultiIndex
- Python Pandas - Binary Operations
- Python Pandas - Binary Comparison Operations
- Python Pandas - Boolean Indexing
- Python Pandas - Boolean Masking
- Python Pandas - Data Reshaping & Pivoting
- Python Pandas - Pivoting
- Python Pandas - Stacking & Unstacking
- Python Pandas - Melting
- Python Pandas - Computing Dummy Variables
- Python Pandas - Categorical Data
- Python Pandas - Categorical Data
- Python Pandas - Ordering & Sorting Categorical Data
- Python Pandas - Comparing Categorical Data
- Python Pandas - Handling Missing Data
- Python Pandas - Missing Data
- Python Pandas - Filling Missing Data
- Python Pandas - Interpolation of Missing Values
- Python Pandas - Dropping Missing Data
- Python Pandas - Calculations with Missing Data
- Python Pandas - Handling Duplicates
- Python Pandas - Duplicated Data
- Python Pandas - Counting & Retrieving Unique Elements
- Python Pandas - Duplicated Labels
- Python Pandas - Grouping & Aggregation
- Python Pandas - GroupBy
- Python Pandas - Time-series Data
- Python Pandas - Date Functionality
- Python Pandas - Timedelta
- Python Pandas - Sparse Data Structures
- Python Pandas - Sparse Data
- Python Pandas - Visualization
- Python Pandas - Visualization
- Python Pandas - Additional Concepts
- Python Pandas - Caveats & Gotchas
Python Pandas read_pickle() Method
The read_pickle() method in Python's Pandas library allows you to load data (also known as "deserialized" data) from a file or file-like object into a Pandas DataFrame or Series. This method can also support various compression formats, making data retrieval efficient and convenient.
Pickle is a Python-specific file format used for serializing and deserializing Python objects. Deserialization, or "unpickling," is the process of taking this byte stream and converting it back into the original Python Pandas object.
In this tutorial, we will learn how to use the Pandas read_pickle() method to load and deserialize pickle files into DataFrames and Series, with examples.
Note: Loading pickled data from untrusted sources can be risky as it is not secure. Always ensure data sources are from the trusted sources.
Syntax
Following is the syntax of the Python Pandas read_pickle() method −
pandas.read_pickle(filepath_or_buffer, compression='infer', storage_options=None)
Parameters
The Python Pandas read_pickle() method accepts the below parameters −
- filepath_or_buffer: This parameter accepts a string, path object, or file-like object representing the file location. URLs, including S3 and GCS, are also supported. 
- compression: Specifies the compression format. If set to 'infer', the method detects compression type from the file extensions like .gz, .bz2, .zip, and more. You can also pass a dictionary to customize compression methods such as gzip, zip, bz2, zstd, etc. If set to None, no compression is applied. 
- storage_options: A dictionary of extra options for storage connection such as AWS S3, Google Cloud Storage, or HTTP(S). Key-value pairs are forwarded to relevant libraries. 
Return Value
The Pandas read_pickle() method returns the same type of object that was stored in the file, such as a DataFrame or Series.
Example: Loading a DataFrame from a Pickle File
Here is a basic example that demonstrates how to load a Pandas DataFrame from a pickle file using the Pandas read_pickle() method.
import pandas as pd
# Create a DataFrame
df = pd.DataFrame({"Col_1": range(5), "Col_2": range(5, 10)})
print("Original DataFrame:")
print(df)
# Save the DataFrame as a pickle file
df.to_pickle("df_pickle_file.pkl")
# Load the DataFrame from the pickle file
unpickled_df = pd.read_pickle("df_pickle_file.pkl")
print("\nLoaded DataFrame:")
print(unpickled_df)
When we run above program, it produces following result −
Original DataFrame:
| Col_1 | Col_2 | |
|---|---|---|
| 0 | 0 | 5 | 
| 1 | 1 | 6 | 
| 2 | 2 | 7 | 
| 3 | 3 | 8 | 
| 4 | 4 | 9 | 
| Col_1 | Col_2 | |
|---|---|---|
| 0 | 0 | 5 | 
| 1 | 1 | 6 | 
| 2 | 2 | 7 | 
| 3 | 3 | 8 | 
| 4 | 4 | 9 | 
Example: Loading a Series from a Pickle File
This example loads a Pandas Series object from a pickle file using the Pandas read_pickle() method.
import pandas as pd
# Creating a Pandas Series
s = pd.Series([1, 2, 3, 4], index=["cat", "dog", "fish", "mouse"])
# Display the Input Series
print("Original Series:")
print(s)
# Save the Series as a pickle file
s.to_pickle("series_read_pickle_file.pkl")
# Load the Series from the pickle file
unpickled_series = pd.read_pickle("series_read_pickle_file.pkl")
print("\nLoaded Series:")
print(unpickled_series)
While executing the above code we get the following output −
Original Series: cat 1 dog 2 fish 3 mouse 4 dtype: int64 Loaded Series: cat 1 dog 2 fish 3 mouse 4 dtype: int64
Example: Loading a Pickle File with Compression (gzip)
This example demonstrates how to read a gzip-compressed pickle file into a Pandas object using the read_pickle() method.
import pandas as pd
# Create a DataFrame
df = pd.DataFrame({"Col_1": range(5), "Col_2": range(5, 10)})
print("Original DataFrame:")
print(df)
# Save the DataFrame to a pickle file with gzip compression
df.to_pickle("dataframe_compressed.pkl.gz", compression="gzip")
# Load the compressed file
compressed_df = pd.read_pickle("dataframe_compressed.pkl.gz")
print("\nLoaded Compressed DataFrame:")
print(compressed_df)
Following is an output of the above code −
Original DataFrame:
| Col_1 | Col_2 | |
|---|---|---|
| 0 | 0 | 5 | 
| 1 | 1 | 6 | 
| 2 | 2 | 7 | 
| 3 | 3 | 8 | 
| 4 | 4 | 9 | 
| Col_1 | Col_2 | |
|---|---|---|
| 0 | 0 | 5 | 
| 1 | 1 | 6 | 
| 2 | 2 | 7 | 
| 3 | 3 | 8 | 
| 4 | 4 | 9 | 
Example: Loading a Custom Compressed Pickle File
The read_pickle() method can also load the custom compressed pickle file. Here is an example demonstrating how to load a custom compressed pickle file (zip) with specific compression level.
import pandas as pd
# Create a DataFrame
df = pd.DataFrame({"Col_1": [1, 2, 3, 4, 5],
"Col_2": ["a", "b", "c", "d", "e"]})
print("Original DataFrame:")
print(df)
# Save the DataFrame to a pickle file with custom zip compression
df.to_pickle("dataframe_custom_compressed.pkl.zip", compression={'method': 'zip', 'compresslevel': 2})
# Load the custom compressed file
custom_df = pd.read_pickle("dataframe_custom_compressed.pkl.zip")
print("\nLoaded Custom Compressed DataFrame:")
print(custom_df)
Following is an output of the above code −
Original DataFrame:
| Col_1 | Col_2 | |
|---|---|---|
| 0 | 1 | a | 
| 1 | 2 | b | 
| 2 | 3 | c | 
| 3 | 4 | d | 
| 4 | 5 | e | 
| Col_1 | Col_2 | |
|---|---|---|
| 0 | 1 | a | 
| 1 | 2 | b | 
| 2 | 3 | c | 
| 3 | 4 | d | 
| 4 | 5 | e |