 
- 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_parquet() Method
The read_parquet() method in Python's Pandas library reads Parquet files and loads them into a Pandas DataFrame. This method supports reading parquet file from a variety of storage backends, including local files, URLs, and cloud storage services.
parquet file format is a partitioned binary columnar storage file format designed for efficient data analysis. This file format designed for efficient reading and writing of DataFrames and can provide the options for easy sharing data across data analysis languages.
Note: Before using the DataFrame.read_parquet() method, you need to install either the 'pyarrow' or 'fastparquet' library, depending on the selected engine. These libraries are optional Python dependencies and can be installed using the following commands −pip install pyarrow pip install fastparquet
Syntax
Following is the syntax of the Python Pandas read_parquet() method −
pandas.read_parquet(path, engine='auto', columns=None, storage_options=None, use_nullable_dtypes=<no_default>, dtype_backend=<no_default>, filesystem=None, filters=None, **kwargs)
Parameters
The Python Pandas read_parquet() method accepts the below parameters −
- path: This method accepts a string, path object, or file-like object that specifies the parquet file path. It can be a local file path or a remote URL supporting schemes like http, ftp, s3, and file. For local files, the expected format is file://localhost/path/to/table.parquet. 
- engine: It specifies backend library for reading parquet files ('pyarrow' or 'fastparquet'). Defaults to 'auto'. 
- columns: Specifies which columns to load from the parquet file. If not provided, all columns are load. 
- storage_options: Additional options for storage connections, such as host, port, username, password, etc. 
- dtype_backend: Defines the backend for data types ('numpy_nullable' or 'pyarrow'). 
- filesystem: Filesystem object for reading the parquet file, used mainly with pyarrow. 
- filters: Filters to apply while reading data, useful for row filtering. 
- **kwargs: Additional arguments passed to the Parquet engine. 
Return Value
The Pandas read_parquet() method returns a Pandas DataFrame containing the data from the Parquet file.
Example: Reading a parquet File
Here is a basic example demonstrating loading a Pandas DataFrame object from a parquet file using the Pandas read_parquet() 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 parquet file
df.to_parquet("df_parquet_file.parquet")
# Load the DataFrame from the parquet file
result = pd.read_parquet("df_parquet_file.parquet")
print("DataFrame loaded from parquet File:")
print(result)
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: Reading Selected Columns from a parquet File
This example reads the Pandas DataFrame with the selected columns from a parquet file using the Pandas read_parquet() 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 parquet file
df.to_parquet("df_parquet_file.parquet")
# Read only specific columns
df = pd.read_parquet('df_parquet_file.parquet', columns=['Col_1'])
print("DataFrame from Parquet file with Selected Column:")
print(df)
While executing the above code we get the following output −
Original DataFrame:
| Col_1 | Col_2 | |
|---|---|---|
| 0 | 0 | 5 | 
| 1 | 1 | 6 | 
| 2 | 2 | 7 | 
| 3 | 3 | 8 | 
| 4 | 4 | 9 | 
| Col_1 | |
|---|---|
| 0 | 0 | 
| 1 | 1 | 
| 2 | 2 | 
| 3 | 3 | 
| 4 | 4 | 
Example: Loading a parquet File with Compression
The following example initially saves a compressed parquet file and then loads it using the to_parquet() method to read the compressed parquet file back into the Pandas object.
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 parquet file with compression
df.to_parquet('compressed_data.parquet.gzip', compression='gzip')
print("DataFrame saved with compression..")
# Load the compressed file
compressed_df = pd.read_parquet("compressed_data.parquet.gzip")
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: Reading Parquet data with Filters
The read_parquet() method can also read parquet file data with the filter using the filter parameter.
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 parquet file
df.to_parquet("df_parquet_file.parquet")
# Filtering rows
filters = [("Col_1", ">", 2)]
# Read only specific columns
result = pd.read_parquet('df_parquet_file.parquet', filters=filters)
print("DataFrame from Parquet file with filtered data:")
print(result)
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 | 3 | 8 | 
| 1 | 4 | 9 |