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) # 提取月份
# 通用函数
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 官方文档。
       
点我分享笔记