Pandas | |
Logo Size: | 300px |
Author: | Wes McKinney |
Developer: | Community |
Latest Preview Version: | 2.0rc1 |
Latest Preview Date: | 15 March 2023 |
Programming Language: | Python, Cython, C |
Operating System: | Cross-platform |
Genre: | Technical computing |
License: | New BSD License |
Pandas (styled as pandas) is a software library written for the Python programming language for data manipulation and analysis. In particular, it offers data structures and operations for manipulating numerical tables and time series. It is free software released under the three-clause BSD license.[1] The name is derived from the term "panel data", an econometrics term for data sets that include observations over multiple time periods for the same individuals,[2] as well as a play on the phrase "Python data analysis".[3] Wes McKinney started building what would become Pandas at AQR Capital while he was a researcher there from 2007 to 2010.[4]
The development of Pandas introduced into Python many comparable features of working with DataFrames that were established in the R programming language.[5] The library is built upon another library, NumPy.
Developer Wes McKinney started working on Pandas in 2008 while at AQR Capital Management out of the need for a high performance, flexible tool to perform quantitative analysis on financial data. Before leaving AQR he was able to convince management to allow him to open source the library.
Another AQR employee, Chang She, joined the effort in 2012 as the second major contributor to the library.
In 2015, Pandas signed on as a fiscally sponsored project of NumFOCUS, a 501(c)(3) nonprofit charity in the United States.[6]
Pandas is built around data structures called Series and DataFrames. Data for these collections can be imported from various file formats such as comma-separated values, JSON, Parquet, SQL database tables or queries, and Microsoft Excel.[7]
A Series is a 1-dimensional data structure built on top of NumPy's array.[8] Unlike in NumPy, each data point has an associated label. The collection of these labels is called an index.[3] Series can be used arithmetically, as in the statement series_3 = series_1 + series_2
: this will align data points with corresponding index values in series_1
and series_2
, then add them together to produce new values in series_3
.[3] A DataFrame is a 2-dimensional data structure of rows and columns, similar to a spreadsheet, and analogous to a Python dictionary mapping column names (keys) to Series (values), with each Series sharing an index.[3] DataFrames can be concatenated together or "merged" on columns or indices in a manner similar to joins in SQL.[3] Pandas implements a subset of relational algebra, and supports one-to-one, many-to-one, and many-to-many joins.[8] Pandas also supports the less common Panel and Panel4D, which are 3-dimensional and 4-dimension data structures respectively.[8]
Users can transform or summarize data by applying arbitrary functions.[3] Since Pandas is built on top of NumPy, all NumPy functions work on Series and DataFrames as well.[8] Pandas also includes built-in operations for arithmetic, string manipulation, and summary statistics such as mean, median, and standard deviation.[3] These built-in functions are designed to handle missing data, usually represented by the floating-point value NaN.[3]
Subsets of data can be selected by column name, index, or Boolean expressions. For example, df[df['col1'] > 5]
will return all rows in the DataFrame df
for which the value of the column col1
exceeds 5.[3] Data can be grouped together by a column value, as in df['col1'].groupby(df['col2'])
, or by a function which is applied to the index. For example, df.groupby(lambda i: i % 2)
groups data by whether the index is even.[3]
Pandas includes support for time series, such as the ability to interpolate values [3] and filter using a range of timestamps (e.g. data['1/1/2023':'2/2/2023']
will return all dates between January 1st and February 2nd).[3] Pandas represents missing time series data using a special NaT (Not a Timestamp) object, instead of the NaN value it uses elsewhere.[3]
By default, a Pandas index is a series of integers ascending from 0, similar to the indices of Python arrays. However, indices can use any NumPy data type, including floating point, timestamps, or strings.[3]
Pandas' syntax for mapping index values to relevant data is the same syntax Python uses to map dictionary keys to values. For example, if s
is a Series, s['a']
will return the data point at index a
. Unlike dictionary keys, index values are not guaranteed to be unique. If a Series uses the index value a
for multiple data points, then s['a']
will instead return a new Series containing all matching values.[3] A DataFrame's column names are stored and implemented identically to an index. As such, a DataFrame can be thought of as having two indices: one column-based and one row-based. Because column names are stored as an index, these are not required to be unique.[8]
If data
is a Series, then data['a']
returns all values with the index value of a
. However, if data
is a DataFrame, then data['a']
returns all values in the column(s) named a
. To avoid this ambiguity, Pandas supports the syntax data.loc['a']
as an alternative way to filter using the index. Pandas also supports the syntax data.iloc[n]
, which always takes an integer n and returns the nth value, counting from 0. This allows a user to act as though the index is an array-like sequence of integers, regardless of how it's actually defined.[8]
Pandas supports hierarchical indices with multiple values per data point. An index with this structure, called a "MultiIndex", allows a single DataFrame to represent multiple dimensions, similar to a pivot table in Microsoft Excel.[3] Each level of a MultiIndex can be given a unique name.[8] In practice, data with more than 2 dimensions is often represented using DataFrames with hierarchical indices, instead of the higher-dimension Panel and Panel4D data structures[8]
Pandas has been criticized for its inefficiency. Pandas can require 5 to 10 times as much memory as the size of the underlying data, and the entire dataset must be loaded in RAM. The library does not optimize query plans or support parallel computing across multiple cores. Wes McKinney, the creator of Pandas, has recommended Apache Arrow as an alternative to address these performance concerns and other limitations.[9]