现在位置: 首页 > Pandas 教程 > 正文

Pandas 常用函数

Pandas 提供了大量用于数据处理和分析的函数,以下是一些常用的函数:

通用函数

函数 描述
pd.isna(obj) 检查对象是否为缺失值(NaN 或 None)。
pd.notna(obj) 检查对象是否不为缺失值。
pd.isnull(obj) pd.isna(),检查对象是否为缺失值。
pd.notnull(obj) pd.notna(),检查对象是否不为缺失值。
pd.concat(objs, axis) 沿指定轴连接多个对象(如 Series 或 DataFrame)。
pd.merge(left, right, on) 根据指定列合并两个 DataFrame。
pd.get_dummies(data) 将分类变量转换为哑变量(One-Hot 编码)。
pd.cut(x, bins) 将连续数据分箱为离散区间。
pd.qcut(x, q) 将数据按分位数分箱。
pd.to_numeric(arg) 将参数转换为数值类型。
pd.to_datetime(arg) 将参数转换为日期时间类型。
pd.to_timedelta(arg) 将参数转换为时间差类型。
pd.date_range(start, end) 生成日期范围。
pd.period_range(start, end) 生成周期范围。
pd.timedelta_range(start, end) 生成时间差范围。
pd.unique(values) 返回数组中的唯一值。
pd.value_counts(values) 返回数组中每个值的频率。
pd.factorize(values) 将数组编码为枚举类型。
pd.crosstab(index, columns) 计算交叉表。
pd.pivot_table(data, values, index, columns) 创建透视表。
pd.melt(frame) 将宽格式数据转换为长格式数据。
pd.cut(x, bins) 将连续数据分箱为离散区间。
pd.qcut(x, q) 将数据按分位数分箱。

数学和统计函数

函数 描述
pd.Series.sum() 返回 Series 的和。
pd.Series.mean() 返回 Series 的平均值。
pd.Series.median() 返回 Series 的中位数。
pd.Series.min() 返回 Series 的最小值。
pd.Series.max() 返回 Series 的最大值。
pd.Series.std() 返回 Series 的标准差。
pd.Series.var() 返回 Series 的方差。
pd.Series.corr(other) 返回两个 Series 的相关系数。
pd.Series.cov(other) 返回两个 Series 的协方差。
pd.Series.quantile(q) 返回 Series 的分位数。
pd.Series.mode() 返回 Series 的众数。
pd.Series.skew() 返回 Series 的偏度。
pd.Series.kurt() 返回 Series 的峰度。
pd.Series.cumsum() 返回 Series 的累计和。
pd.Series.cumprod() 返回 Series 的累计积。
pd.Series.cummax() 返回 Series 的累计最大值。
pd.Series.cummin() 返回 Series 的累计最小值。

字符串处理函数

函数 描述
pd.Series.str.lower() 将字符串转换为小写。
pd.Series.str.upper() 将字符串转换为大写。
pd.Series.str.strip() 去除字符串两端的空白字符。
pd.Series.str.replace(old, new) 替换字符串中的子串。
pd.Series.str.contains(pattern) 检查字符串是否包含指定模式。
pd.Series.str.split(sep) 按分隔符拆分字符串。
pd.Series.str.cat(others) 连接字符串。
pd.Series.str.extract(regex) 使用正则表达式提取子串。
pd.Series.str.find(sub) 返回子串的起始位置。
pd.Series.str.len() 返回字符串的长度。

时间序列函数

函数 描述
pd.to_datetime(arg) 将参数转换为日期时间类型。
pd.date_range(start, end) 生成日期范围。
pd.Timestamp() 创建一个时间戳对象。
pd.Timedelta() 创建一个时间差对象。
pd.Period() 创建一个周期对象。
pd.Series.dt.year 返回日期时间的年份。
pd.Series.dt.month 返回日期时间的月份。
pd.Series.dt.day 返回日期时间的天数。
pd.Series.dt.hour 返回日期时间的小时数。
pd.Series.dt.minute 返回日期时间的分钟数。
pd.Series.dt.second 返回日期时间的秒数。
pd.Series.dt.weekday 返回日期时间的星期几(0-6)。

实例

import pandas as pd

# 通用函数
s = pd.Series([1, 2, 3, None])
print(pd.isna(s))  # 检查缺失值

# 数学和统计函数
print(s.sum())  # 计算和

# 字符串处理函数
s_str = pd.Series(['a', 'b', 'c'])
print(s_str.str.upper())  # 转换为大写

# 时间序列函数
dates = pd.to_datetime(['2023-01-01', '2023-02-01'])
print(dates.dt.month)  # 提取月份

如果需要更详细的信息,可以参考 Pandas 官方文档