Pandas从基础统计到高级分析的完整指南【第77篇—Pandas高级分析】

Pandas从基础统计到高级分析的完整指南

在数据科学和分析领域中,Pandas是Python中最受欢迎的数据处理库之一。它提供了丰富而强大的功能,其中包括各种统计方法,用于更好地理解和分析数据。本文将介绍Pandas中常用的统计方法,通过代码实例和解析,帮助读者更好地掌握这些强大的工具。

image-20240212234032203

1. 基本统计方法

1.1 描述性统计

Pandas的describe()方法提供了数据的基本描述性统计信息,包括均值、标准差、最小值、最大值等。

import pandas as pd# 创建DataFrame
data = {'A': [1, 2, 3, 4, 5],'B': [10, 20, 30, 40, 50]}
df = pd.DataFrame(data)# 描述性统计
statistics = df.describe()
print(statistics)

image-20240212234053644

1.2 汇总统计

sum()mean()等方法提供了对数据进行求和、计算平均值等汇总统计功能。

# 汇总统计
total_sum = df.sum()
mean_value = df.mean()
print("总和:", total_sum)
print("平均值:", mean_value)

image-20240212234110479

2. 分类统计方法

2.1 唯一值统计

value_counts()方法用于计算Series中唯一值的频率。

# 唯一值统计
unique_counts = df['A'].value_counts()
print("唯一值统计:\n", unique_counts)
2.2 分组统计

groupby()方法可以对数据进行分组,然后使用聚合函数进行统计。

# 分组统计
grouped = df.groupby('A')
grouped_sum = grouped.sum()
print("分组统计:\n", grouped_sum)

3. 缺失值处理

3.1 缺失值统计

isnull()sum()结合使用,可以统计每列的缺失值数量。

# 缺失值统计
missing_values = df.isnull().sum()
print("缺失值统计:\n", missing_values)
3.2 缺失值填充

fillna()方法用于填充缺失值,可以使用均值、中位数等进行填充。

# 缺失值填充
df_filled = df.fillna(df.mean())
print("填充缺失值后的DataFrame:\n", df_filled)

通过上述代码实例,我们介绍了Pandas中一些常用的统计方法,包括基本统计、分类统计以及缺失值处理等。这些功能使得Pandas成为数据分析和处理的得力助手,为用户提供了丰富的工具来更深入地理解和探索数据。希望本文对你在数据分析的实践中能够起到指导作用,让你更加熟练地运用Pandas进行数据处理。

4. 相关性和协方差

4.1 相关性分析

corr()方法用于计算DataFrame中列之间的相关性。

# 相关性分析
correlation_matrix = df.corr()
print("相关性分析:\n", correlation_matrix)
4.2 协方差分析

cov()方法用于计算DataFrame中列之间的协方差。

# 协方差分析
covariance_matrix = df.cov()
print("协方差分析:\n", covariance_matrix)

5. 窗口统计方法

5.1 移动平均

rolling()方法可以创建一个滑动窗口对象,结合mean()等函数,实现移动平均的计算。

# 移动平均
rolling_window = df['A'].rolling(window=2)
moving_average = rolling_window.mean()
print("移动平均:\n", moving_average)
5.2 指数加权窗口

ewm()方法用于创建指数加权窗口对象,可用于计算指数加权移动平均。

# 指数加权移动平均
ewm_window = df['B'].ewm(span=2)
ewm_average = ewm_window.mean()
print("指数加权移动平均:\n", ewm_average)

6. 数据采样

resample()方法用于对时间序列数据进行重采样,可以实现数据的降采样和升采样。

# 数据采样
df_time = pd.DataFrame({'value': [10, 20, 30, 40, 50]}, index=pd.date_range('2022-01-01', periods=5, freq='D'))
resampled_data = df_time.resample('W').sum()
print("周采样:\n", resampled_data)

image-20240212234142340

7. 数据透视表

数据透视表是一种强大的数据分析工具,通过pivot_table()方法,可以实现对数据进行灵活的透视和聚合。

# 数据透视表
pivot_table = pd.pivot_table(df, values='B', index='A', aggfunc='mean')
print("数据透视表:\n", pivot_table)

8. 分位数和离群值

8.1 分位数计算

quantile()方法用于计算数据的分位数,帮助理解数据的分布情况。

# 分位数计算
quantiles = df['B'].quantile([0.25, 0.5, 0.75])
print("分位数计算:\n", quantiles)
8.2 离群值检测

通过箱线图和quantile()等方法,可以识别并处理数据中的离群值。

# 离群值检测
Q1 = df['B'].quantile(0.25)
Q3 = df['B'].quantile(0.75)
IQR = Q3 - Q1
outliers = df[(df['B'] < (Q1 - 1.5 * IQR)) | (df['B'] > (Q3 + 1.5 * IQR))]
print("离群值检测:\n", outliers)

9. 时间序列分析

9.1 时间索引设置

通过set_index()方法,可以将DataFrame的列设置为时间索引,便于时间序列分析。

# 时间索引设置
df_time_indexed = df.set_index(pd.date_range('2022-01-01', periods=5, freq='D'))
print("时间索引设置:\n", df_time_indexed)
9.2 移动窗口时间序列统计

结合rolling()方法,可以对时间序列数据进行滑动窗口统计。

# 移动窗口时间序列统计
rolling_window_time = df_time_indexed['B'].rolling(window=2)
moving_average_time = rolling_window_time.mean()
print("移动窗口时间序列统计:\n", moving_average_time)

通过这些高级的统计方法,你可以更深入地分析时间序列数据,发现数据中的趋势和规律,为预测和决策提供更多有力的支持。

10. 数据可视化

为了更直观地理解数据,数据可视化是至关重要的一环。Pandas与其他可视化库(如Matplotlib和Seaborn)结合使用,提供了强大的数据可视化功能。

10.1 直方图

使用hist()方法可以绘制直方图,帮助了解数据的分布情况。

# 直方图
df['B'].plot.hist(bins=5, alpha=0.7)
plt.title('Histogram of Column B')
plt.xlabel('Values')
plt.ylabel('Frequency')
plt.show()
10.2 箱线图

箱线图是识别离群值的重要工具,通过boxplot()方法可以轻松绘制。

# 箱线图
df.boxplot(column='B')
plt.title('Boxplot of Column B')
plt.show()
10.3 散点图

散点图是用于观察两个变量之间关系的有效手段,通过scatter()方法实现。

# 散点图
df.plot.scatter(x='A', y='B')
plt.title('Scatter Plot between A and B')
plt.xlabel('A')
plt.ylabel('B')
plt.show()

通过这些可视化方法,你可以更直观地发现数据中的模式、趋势和异常值,为进一步分析提供了更深入的视角。

11. 高级统计方法

Pandas还提供了一些高级统计方法,用于处理更复杂的数据分析问题。以下是其中一些方法的示例:

11.1 主成分分析(PCA)

主成分分析是一种降维技术,通过PCA类实现。

from sklearn.decomposition import PCA# 创建DataFrame
data = {'Feature1': [1, 2, 3, 4, 5],'Feature2': [5, 4, 3, 2, 1]}
df_pca = pd.DataFrame(data)# 主成分分析
pca = PCA(n_components=1)
result = pca.fit_transform(df_pca)
print("PCA Result:\n", result)
11.2 线性回归

使用statsmodelsscikit-learn库,可以进行线性回归分析。

import statsmodels.api as sm
from sklearn.linear_model import LinearRegression# 创建DataFrame
data = {'X': [1, 2, 3, 4, 5],'Y': [2, 4, 5, 4, 5]}
df_regression = pd.DataFrame(data)# 使用statsmodels进行线性回归
X = sm.add_constant(df_regression['X'])
model = sm.OLS(df_regression['Y'], X).fit()
print("Statsmodels Linear Regression Summary:\n", model.summary())# 使用scikit-learn进行线性回归
regressor = LinearRegression()
regressor.fit(df_regression[['X']], df_regression['Y'])
print("Scikit-learn Linear Regression Coefficients:\n", regressor.coef_)
11.3 时间序列分解

时间序列分解可以将时间序列数据拆分为趋势、季节性和残差部分,通过seasonal_decompose()方法实现。

from statsmodels.tsa.seasonal import seasonal_decompose# 创建时间序列
time_series_data = pd.Series([1, 2, 3, 4, 5, 6, 7, 8, 9], index=pd.date_range('2022-01-01', periods=9, freq='M'))# 时间序列分解
result = seasonal_decompose(time_series_data, model='additive')
print("Time Series Decomposition Result:\n", result.plot())

image-20240212234205920

总结:

本文全面介绍了Pandas中常用的统计方法,从基础的描述性统计到高级的主成分分析、线性回归和时间序列分解,为数据科学家和分析师提供了强大的工具。通过代码实例和解析,读者可以深入了解如何使用Pandas进行数据分析,包括数据的汇总统计、分类统计、缺失值处理、相关性分析、时间序列分析等多个方面。

在基本统计方法中,我们学习了如何使用describe()sum()mean()等函数进行数据的描述性统计和汇总统计。在分类统计方法中,value_counts()groupby()方法展示了如何对数据进行唯一值统计和分组统计。对于缺失值处理,我们介绍了如何统计和填充缺失值。在相关性和协方差分析中,使用corr()cov()方法计算了列之间的相关性和协方差。窗口统计方法包括移动平均和指数加权移动平均,以及数据采样、数据透视表和分位数处理等,都为更深入的数据分析提供了支持。

在高级统计方法中,我们探讨了主成分分析、线性回归和时间序列分解等方法,帮助读者应对更复杂的数据分析任务。最后,通过数据可视化,我们展示了如何使用Matplotlib和Seaborn库对数据进行可视化,更直观地理解数据的分布、趋势和异常值。

总体而言,Pandas作为Python中强大的数据处理库,为数据科学家和分析师提供了丰富而灵活的工具,本文通过详细的代码实例和解析,旨在帮助读者更深入地掌握这些工具,提高在数据分析领域的技能水平。希望本文对你在数据分析实践中的应用有所帮助。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/467096.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

分享80个jQuery特效,总有一款适合您

分享80个jQuery特效&#xff0c;总有一款适合您 80个jQuery特效下载链接&#xff1a;https://pan.baidu.com/s/1o8TcFu68r67e7VeiwmR-XQ?pwd8888 提取码&#xff1a;8888 Python采集代码下载链接&#xff1a;采集代码.zip - 蓝奏云 学习知识费力气&#xff0c;收集整理…

游泳耳机怎么选?四大口碑最好游泳耳机推荐

在挑选适合游泳的耳机时&#xff0c;选择合适的产品至关重要。游泳不仅是一项身体锻炼&#xff0c;更是一种享受。佩戴耳机能够为游泳者提供更加愉悦的体验&#xff0c;但确保所选耳机符合水中使用的要求至关重要。 传统的有线耳机和非防水设计的蓝牙耳机并不适合水中使用&…

牛客错题整理——C语言(实时更新)

1.以下程序的运行结果是&#xff08;&#xff09; #include <stdio.h> int main() { int sum, pad,pAd; sum pad 5; pAd sum, pAd, pad; printf("%d\n",pAd); }答案为7 由于赋值运算符的优先级高于逗号表达式&#xff0c;因此pAd sum, pAd, pad;等价于(…

嵌入式Qt Qt Creator安装与工程介绍

一.Qt概述 什么是Qt&#xff1a;Qt是一个跨平台的C图形用户界面应用程序框架。它为应用程序开发者提供建立图形界面所需的所有功能。它是完全面向对象的&#xff0c;很容易扩展&#xff0c;并且允许真正的组件编程。 二.Qt Creator下载安装 下载地址&#xff1a;Index of /a…

从零开始实现消息队列(一)

从零开始实现消息队列 .什么是消息队列需求分析核心概念模型 . 什么是消息队列 相信大家都了解过阻塞队列和生产者消费者模型,而阻塞队列最大的用途,就是用于实现生产者消费者模型,生产者消费者模型有以下好处: 解耦合 解释: 当主机A给主机B发消息时,A给B发送请求,B给A返回响应…

C语言第二十三弹---指针(七)

✨个人主页&#xff1a; 熬夜学编程的小林 &#x1f497;系列专栏&#xff1a; 【C语言详解】 【数据结构详解】 指针 1、sizeof和strlen的对比 1.1、sizeof 1.2、strlen 1.3、sizeof 和 strlen的对比 2、数组和指针笔试题解析 2.1、⼀维数组 2.2、二维数组 总结 1、si…

全坚固平板EM-I12U,全新升级后的优质体验

平板终端机在户外勘探、制造业、畜牧业、银行金融行业当中都不是陌生的&#xff0c;能采集各种数据来转换成信息流向企业和行业的各个分支当中&#xff0c;在整个行业发展、社会推动上面都起着关键性作用&#xff0c;而平板终端机的升级也就意味着未来的这些行业发展会进入一个…

服务治理中间件-Eureka

目录 简介 搭建Eureka服务 注册服务到Eureka 简介 Eureka是Spring团队开发的服务治理中间件&#xff0c;可以轻松在项目中&#xff0c;实现服务的注册与发现&#xff0c;相比于阿里巴巴的Nacos、Apache基金会的Zookeeper&#xff0c;更加契合Spring项目&#xff0c;缺点就是…

Python算法题集_合并K个升序链表

Python算法题集_合并K个升序链表 题23&#xff1a;合并K个升序链表1. 示例说明2. 题目解析- 题意分解- 优化思路- 测量工具 3. 代码展开1) 标准求解【双层循环】2) 改进版一【列表排序】3) 改进版二【堆排序】4) 改进版三【分区海选】 4. 最优算法 本文为Python算法题集之一的代…

LeetCode Python - 13.罗马数字转整数

目录 题目答案运行结果 题目 罗马数字包含以下七种字符: I&#xff0c; V&#xff0c; X&#xff0c; L&#xff0c;C&#xff0c;D 和 M。 字符 数值 I 1 V 5 X 10 L 50 C 100 D 500 M 1000 例如&#xff0c; 罗马数字 2 写做 II &#xff0c;即为两个并列的 1 。12 写做 XII…

three.js 细一万倍教程 从入门到精通(二)

目录 三、全面认识three.js物体 3.1、掌握几何体顶点_UV_法向属性 3.2、BufferGeometry设置顶点创建矩形 3.3、生成酷炫三角形科技物体 四、详解材质与纹理 4.1、初识材质与纹理 4.2、详解纹理偏移_旋转_重复 偏移 旋转 重复 4.3、设置纹理显示算法与mipmap mapFil…

Stable Diffusion 模型下载:Disney Pixar Cartoon Type B(迪士尼皮克斯动画片B类)

本文收录于《AI绘画从入门到精通》专栏,专栏总目录:点这里。 文章目录 模型介绍生成案例案例一案例二案例三案例四案例五案例六案例七案例八案例九案例十