【数学建模】——【python库】——【Pandas学习】

ce6fbd68767d465bbe94b775b8b811db.png

 

731bd47804784fa2897220a90a387b28.gif

 专栏:数学建模学习笔记

pycharm专业版免费激活教程见资源,私信我给你发

python相关库的安装:pandas,numpy,matplotlib,statsmodels

总篇:【数学建模】—【新手小白到国奖选手】—【学习路线】

第一卷:【数学建模】—【Python库】—【Numpy】—【学习】

本篇属于第二卷——Pandas学习笔记

步骤1:安装PyCharm和Pandas

1.下载并安装PyCharm:

  • 前往JetBrains官网,下载并安装PyCharm Community Edition(免费)或Professional Edition。
  • 安装完成后,启动PyCharm。

2.安装Pandas库:

  • 打开PyCharm,新建一个项目。

在项目窗口中,找到Terminal(终端)窗口,输入以下命令安装Pandas库:

pip install pandas

步骤2:创建并读取数据

1.创建数据文件:

  • 在项目根目录下创建一个名为data.csv的文件,输入一些示例数据。例如:
  • Name    

       Age    

       Score

    Alice    

        23     

         88

    Bob    

        25    

         92

    Charlie  

       22    

        85

    Xiaoli    

        18      

         100 

dd77fee7b03b483c82f30860edb7d575.png

2.读取数据:

  • 在项目中创建一个新的Python文件,例如   Pandas学习.py。

在Pandas学习.py中编写以下代码来读取数据 :

import pandas as pd# 读取CSV文件
data = pd.read_csv('data.csv')# 打印数据
print(data)

点击右上角的绿色运行按钮,或使用快捷键Shift+F10: 

d663ab442b104984a48d1de83efc6db7.png

步骤3:数据清洗和处理

3.1 处理缺失值

假设我们的数据有缺失值,可以用以下代码来处理:

修改data.csv文件,加入一些缺失值:

Name,Age,Score
Alice,23,88
Bob,25,
Charlie,,85
David,22,90
xiaoli,18,100

在Pandas学习.py中编写以下代码:

import pandas as pd# 读取CSV文件
data_with_nan = pd.read_csv('data.csv')
print("原始数据带有缺失值:")
print(data_with_nan)# 用平均值填充缺失的年龄
data_with_nan['Age'].fillna(data_with_nan['Age'].mean(), inplace=True)# 用指定值填充缺失的分数
data_with_nan['Score'].fillna(0, inplace=True)print("\n处理后的数据:")
print(data_with_nan)

运行此代码,您将看到以下输出:

bb9ca93917b04d85bf2b6b7458009754.png

3.2 数据转换

假设我们需要将年龄从岁转换为月,可以用以下代码:

在Pandas学习.py中添加以下代码:

data_with_nan['Age_in_Months'] = data_with_nan['Age'] * 12
print("\n添加年龄(以月为单位)后的数据:")
print(data_with_nan)

运行此代码,您将看到以下输出: 

3fc750a4e8114db38970cf606437165d.png

步骤4:数据分析和可视化

1.数据统计:

  • 我们可以使用Pandas提供的统计函数进行简单的数据分析:
    # 计算平均年龄
    mean_age = data['Age'].mean()
    print(f'平均年龄: {mean_age}')# 计算分数的标准差
    score_std = data['Score'].std()
    print(f'分数标准差: {score_std}')
    

    运行此代码,您将看到以下输出:

  • 41b84a22b5594fb7ae9d0873f0b871df.png

2.数据可视化:

虽然你只提到Pandas,但这里简要提及如何使用Matplotlib进行简单可视化:

import matplotlib.pyplot as plt# 绘制年龄分布图
plt.hist(data['Age'], bins=10, alpha=0.75)
plt.xlabel('Age')
plt.ylabel('Frequency')
plt.title('Age Distribution')
plt.show()

运行此代码,您将看到一个年龄分布的直方图。

 909506a0a851457a839b0b21a14b9860.png

步骤5:高级操作

5.1 数据分组和聚合

使用groupby函数对数据进行分组和聚合,例如按年龄分组计算平均分数:

  1. Pandas学习.py中添加以下代码:

age_grouped = data_with_nan.groupby('Age')['Score'].mean()
print("\n按年龄分组的平均分数:")
print(age_grouped)

运行结果 

8d138f4ed4fa427a8205186aa113ca08.png

5.2 数据透视表

使用pivot_table函数创建数据透视表:

main.py中添加以下代码:

pivot_table = data_with_nan.pivot_table(values='Score', index='Age', columns='Name', aggfunc='mean')
print("\n数据透视表:")
print(pivot_table)

f609bd245b4b4232a9f0ab97f5df9022.png

步骤6:保存数据

6.1 保存处理后的数据

将处理后的数据保存为新的CSV文件:

main.py中添加以下代码:

data_with_nan.to_csv('processed_data.csv', index=False)

运行此代码后,您将在项目目录下看到一个名为processed_data.csv的新文件,内容如下: 

948e9f4ef964468fb6242876f1c65ae3.png

444e4fbb2bc743ecbcdcc10e4291532e.png

总结

在PyCharm中使用Pandas进行数据读取、清洗、处理、分析和保存,应用Pandas进行环境设置、数据加载、预处理、分析、可视化到简单建模的全过程。欢迎友友的提问指导!

7.进一步细节和注意事项

1.数据质量控制

数据质量控制是数据分析中至关重要的一环。确保数据的准确性和完整性是数据分析成功的基础。以下是一些常见的数据质量控制方法:

  1. 数据验证

    • 检查数据是否有重复记录,确保每一行数据的唯一性。
    • 验证数据范围是否在合理范围内(例如,年龄不应超过100岁)。
  2. 数据一致性

    • 检查同一字段的数据类型是否一致。
    • 确保同一字段的数据格式一致,例如日期格式统一为YYYY-MM-DD。
  3. 数据完整性

    • 确保关键字段没有缺失值。
    • 检查数据表之间的关联性,确保外键关系的完整性。

2.数据处理技巧

1.处理异常值

异常值是指与大多数数据点明显不同的数据点。处理异常值的方法包括:

删除异常值:如果异常值是由于数据录入错误造成的,可以直接删除。

替换异常值:使用中位数或均值替换异常值。

data_filtered = data[(data['Age'] > 0) & (data['Age'] < 100)]

2.数据转换

数据转换是指将数据从一种形式转换为另一种形式,以便于分析。

例如,可以将分类数据转换为数值数据,使用One-Hot编码:

data['Gender'] = data['Gender'].map({'Male': 1, 'Female': 0})

3.数据分析与可视化

高级可视化

数据可视化能够帮助我们更直观地理解数据。以下是一些常见的数据可视化方法:

箱线图:用于显示数据的分布情况,特别是检测异常值。

sns.boxplot(x=data['Score'])
plt.title('Score Boxplot')
plt.show()

散点图:用于显示两个变量之间的关系。

sns.scatterplot(x=data['Age'], y=data['Score'])
plt.title('Age vs Score')
plt.show()

4.时间序列分析

  • 如果数据包含时间维度,可以进行时间序列分析。
data['Date'] = pd.to_datetime(data['Date'])
data.set_index('Date', inplace=True)
data['Score'].plot()
plt.title('Score over Time')
plt.show()

8.更多数据分析与处理细节

1.扩展数据清洗技术

1.去除重复值

data_without_duplicates = data.drop_duplicates()
print("去除重复值后的数据:")
print(data_without_duplicates)

2.处理异常值: 

# 假设年龄和分数的合理范围
data_filtered = data[(data['Age'] > 0) & (data['Age'] < 100) & (data['Score'] >= 0) & (data['Score'] <= 100)]
print("去除异常值后的数据:")
print(data_filtered)

3.转换数据类型: 

data['Age'] = data['Age'].astype(int)
data['Score'] = data['Score'].astype(float)
print("转换数据类型后的数据:")
print(data.dtypes)

2.详细分析数据 

1.更多统计分析

# 计算中位数
median_age = data['Age'].median()
print(f'年龄中位数: {median_age}')# 计算分数的方差
variance_score = data['Score'].var()
print(f'分数方差: {variance_score}')

2.高级可视化: 

import seaborn as sns# 绘制箱线图
sns.boxplot(x=data['Score'])
plt.title('Score Boxplot')
plt.show()# 绘制散点图
sns.scatterplot(x=data['Age'], y=data['Score'])
plt.title('Age vs Score')
plt.show()

9.实战 接单

242fe09b34ff4610be62d974ba2073e0.png

ddd1a61cdc8447c093dc62d6d34aabe0.png

import pandas as pd
import numpy as np
import matplotlib.pyplot as plt
from matplotlib.font_manager import FontProperties# 设置字体
plt.rcParams['font.sans-serif'] = ['SimSun']  # 设置默认字体为宋体
plt.rcParams['axes.unicode_minus'] = False  # 解决负号显示问题# 读取数据
file_path = 'E:/python/零食大礼包销售/SuperMarket_order.txt'
data = pd.read_csv(file_path, sep=',')# 按照付款金额分类
bins = [0, 100, 500, float('inf')]
labels = ['100以下', '100-500', '500以上']
data['付款金额分类'] = pd.cut(data['931.79'], bins=bins, labels=labels)# 分别对订单状态、物品类别、购物方式、支付类别、付款人所在省份进行统计分析
status_counts = data['已完成'].value_counts()
category_counts = data['文体类'].value_counts()
shopping_method_counts = data['PC'].value_counts()
payment_type_counts = data['微信'].value_counts()
province_counts = data['江苏省'].value_counts()
amount_category_counts = data['付款金额分类'].value_counts()# 绘制图表
fig, axes = plt.subplots(2, 3, figsize=(18, 12))# 订单状态统计图
axes[0, 0].bar(status_counts.index, status_counts.values)
axes[0, 0].set_title('订单状态统计')
axes[0, 0].set_xlabel('订单状态')
axes[0, 0].set_ylabel('数量')# 物品类别统计图
axes[0, 1].bar(category_counts.index, category_counts.values)
axes[0, 1].set_title('物品类别统计')
axes[0, 1].set_xlabel('物品类别')
axes[0, 1].set_ylabel('数量')# 购物方式统计图
axes[0, 2].bar(shopping_method_counts.index, shopping_method_counts.values)
axes[0, 2].set_title('购物方式统计')
axes[0, 2].set_xlabel('购物方式')
axes[0, 2].set_ylabel('数量')# 支付类别统计图
axes[1, 0].pie(payment_type_counts.values, labels=payment_type_counts.index, autopct='%1.1f%%')
axes[1, 0].set_title('支付类别统计')# 付款人所在省份统计图
axes[1, 1].scatter(province_counts.index, province_counts.values)
axes[1, 1].set_title('付款人所在省份统计')
axes[1, 1].set_xlabel('省份')
axes[1, 1].set_ylabel('数量')# 付款金额分类统计图
axes[1, 2].bar(amount_category_counts.index, amount_category_counts.values)
axes[1, 2].set_title('付款金额分类统计')
axes[1, 2].set_xlabel('付款金额分类')
axes[1, 2].set_ylabel('数量')plt.tight_layout()
plt.show()

94cac4f7c2b841178008da5f280c6ba7.png

 39718f204d3346bb975fdd18fbffde61.png

10.相关应用

Pandas在实际数据分析中的应用非常广泛,以下是一些常见的应用场景:

1.金融数据分析

分析股票市场数据,包括股价趋势分析、波动率分析、技术指标计算等。

stock_data = pd.read_csv('stock_data.csv')
stock_data['Daily Return'] = stock_data['Close'].pct_change()
stock_data['Daily Return'].plot()
plt.title('Daily Return of Stock')
plt.show()

2.市场营销数据分析

  • 分析客户购买行为,进行客户细分、预测客户价值等。
sales_data = pd.read_csv('sales_data.csv')
customer_segments = sales_data.groupby('CustomerID')['PurchaseAmount'].sum()
customer_segments.plot(kind='bar')
plt.title('Customer Purchase Amount')
plt.show()

3.社会科学研究

分析社会调查数据,包括人口统计分析、社会行为模式分析等。

survey_data = pd.read_csv('survey_data.csv')
age_distribution = survey_data['Age'].value_counts()
age_distribution.plot(kind='pie')
plt.title('Age Distribution of Survey Respondents')
plt.show()

11.注意事项

1.数据隐私

  • 在处理个人数据时,确保遵守相关数据隐私法律法规,如GDPR(General Data Protection Regulation)。
  • 避免在数据处理中泄露个人敏感信息,使用数据匿名化技术。

2.性能优化

  • 对于大规模数据,使用Pandas可能会导致内存消耗过高。可以考虑使用Dask或Pandas的chunking功能进行分块处理。
    chunk_size = 10000
    chunks = pd.read_csv('large_data.csv', chunksize=chunk_size)
    for chunk in chunks:# 处理每个chunkprocess_chunk(chunk)
    

3.版本兼容性

  • 使用Pandas时,确保使用相同版本的Pandas库,以避免因版本差异导致的代码不兼容问题。

 

 

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

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

相关文章

互联网信息服务算法备案流程与要求

一、备案申请的办理流程 企业通过网信办的互联网信息服务算法备案系统&#xff08;https://beian.cac.gov.cn/#/index&#xff09;提交算法备案申请。填报信息包括三部分&#xff0c;分别是算法主体信息、产品及功能信息、算法信息。备案中比较重要的文件包括主体信息中的《落…

▶《强化学习的数学原理》(2024春)_西湖大学赵世钰 Ch5 蒙特卡洛方法【model-based ——> model-free】

PPT 截取必要信息。 课程网站做习题。总体 MOOC 过一遍 1、视频 学堂在线 习题 2、 过 电子书 是否遗漏 【下载&#xff1a;本章 PDF GitHub 页面链接 】 【第二轮 才整理的&#xff0c;忘光了。。。又看了一遍视频】 3、 过 MOOC 习题 看 PDF 迷迷糊糊&#xff0c; 恍恍惚惚。…

深度学习 - Transformer 组成详解

整体结构 1. 嵌入层&#xff08;Embedding Layer&#xff09; 生活中的例子&#xff1a;字典查找 想象你在读一本书&#xff0c;你不认识某个单词&#xff0c;于是你查阅字典。字典为每个单词提供了一个解释&#xff0c;帮助你理解这个单词的意思。嵌入层就像这个字典&#xf…

道路救援入驻派单小程序开源版开发

道路救援入驻派单小程序开源版开发 1、用户立即救援 2、后台收到救援通知&#xff0c;派单救援师傅. 道路救援入驻派单小程序通常会包含一系列功能&#xff0c;旨在方便救援服务提供商、用户和后台管理系统之间的交互。以下是一个可能的功能列表&#xff1a; 用户端功能&…

Camera开发-相机输出常用数据格式

作者简介&#xff1a; 一个平凡而乐于分享的小比特&#xff0c;中南民族大学通信工程专业研究生在读&#xff0c;研究方向无线联邦学习 擅长领域&#xff1a;驱动开发&#xff0c;嵌入式软件开发&#xff0c;BSP开发 作者主页&#xff1a;一个平凡而乐于分享的小比特的个人主页…

OpenGL-ES 学习(6)---- 立方体绘制

目录 立方体绘制基本原理立方体的顶点坐标和绘制顺序立方体颜色和着色器实现效果和参考代码 立方体绘制基本原理 一个立方体是由8个顶点组成&#xff0c;共6个面&#xff0c;所以绘制立方体本质上就是绘制这6个面共12个三角形 顶点的坐标体系如下图所示&#xff0c;三维坐标…

【极速入门版】编程小白也能轻松上手Comate AI编程插件

文章目录 概念使用错误检测与修复能力API生成代码生成json格式做开发测试 在目前的百模大战中&#xff0c;AI编程助手是程序员必不可少的东西&#xff0c;市面上琳琅满目的产品有没有好用一点的&#xff0c;方便一点的呢&#xff1f;今天工程师令狐向大家介绍一款极易入门的国产…

three.js - MeshStandardMaterial(标准网格材质)- 金属贴图、粗糙贴图

金属贴图、粗糙贴图 金属贴图&#xff1a;metalnessMap 和 粗糙贴图&#xff1a;roughnessMap&#xff0c;是用于模拟物体表面属性的两种重要贴图技术&#xff0c;这两种贴图&#xff0c;通常与基于物理的渲染&#xff08;PBR&#xff09;材质&#xff08;如&#xff1a;MeshSt…

nuxt3项目打包后获取.env设置的环境变量无效的解决办法

问题描述 在nuxt3项目开发过程中&#xff0c;设置了开发环境变量和生产环境变量&#xff0c;在本地开发时都能正常获取&#xff0c;但打包部署时获取不到&#xff0c;设置如下&#xff1a; //.env.development文件示例 SERVER_API_PATHhttp://192.168.25.100//.env.productio…

Elasticsearch环境搭建|ES单机|ES单节点模式启动|ES集群搭建|ES集群环境搭建

文章目录 版本选择单机ES安装与配置创建非root用户导入安装包安装包解压配置JDK环境变量配置single-node配置JVM参数后台启动|启动日志查看启动成功&#xff0c;访问终端访问浏览器访问 Kibana安装修改配置后台启动|启动日志查看浏览器访问 ES三节点集群搭建停止es服务域名配置…

小区物业管理收费系统源码小程序

便捷、透明、智能化的新体验 一款基于FastAdminUniApp开发的一款物业收费管理小程序。包含房产管理、收费标准、家属管理、抄表管理、在线缴费、业主公告、统计报表、业主投票、可视化大屏等功能。为物业量身打造的小区收费管理系统&#xff0c;贴合物业工作场景&#xff0c;轻…

未来20年人工智能将如何塑造社会

照片由Brian McGowan在Unsplash上拍摄 更多资讯&#xff0c;请访问 2img.ai “人工智能会成为我们的救星还是我们的末日&#xff1f;” 几十年来&#xff0c;这个问题一直困扰着哲学家、科学家和科幻爱好者。 当我们踏上技术革命的边缘时&#xff0c;是时候透过水晶球&#x…

【java算法专场】双指针(上)

目录 前言 基本原理 对撞指针 快慢指针 移动零 算法思路 算法步骤 代码实现 算法分析 复写零 算法思路 算法步骤 代码实现 快乐数 算法思路 算法步骤 代码实现 盛最多水的容器 ​编辑算法思路 代码实现 前言 双指针是一种在数组或链表等线性数据结构中高效…

CV每日论文--2024.6.26

1、StableNormal: Reducing Diffusion Variance for Stable and Sharp Normal 中文标题&#xff1a;StableNormal&#xff1a;减少扩散方差以实现稳定且锐利的法线 简介&#xff1a;本文介绍了一种创新解决方案&#xff0c;旨在优化单目彩色输入&#xff08;包括静态图片与动态…

CCS的安装步骤

CCS的安装步骤 安装之前有几件重要的事情要做&#xff1a; 首先肯定是要下载安装包啦&#xff01;点击此处是跳到官网下载地址安装包不能处的路径中不能包含中文关闭病毒防护和防火墙&#xff0c;以及其他杀毒软件最后是在重启后进行安装 主要的步骤如下&#xff1a; 找到安…

PDF转成清晰长图

打开一个宝藏网址在线PDF转换器/处理工具 - 在线工具系列 点击图下所示位置 按照图下所示先上传文件&#xff0c;设置转换参数后点击转换&#xff0c;等待 等待转换完成后&#xff0c;可以在转换结果处选择下载地址&#xff0c;点击即可进行下载使用了。对比了其他几个网站的转…

.NET C# Asp.Net Core Web API 配置 Nginx

.NET C# Asp.Net Core Web API 配置 Nginx 目录 .NET C# Asp.Net Core Web API 配置 Nginx1 创建Asp.Net Core Web API应用2 接口代码3 发布4 启动服务5 Nginx安装6 配置Nginx7 启动Nginx8 测试9 Nginx日志10 附&#xff1a; 1 创建Asp.Net Core Web API应用 2 接口代码 Weath…

高考志愿填报选专业,解读“冲稳保”三步策略

高考界流传着一句话“一分压倒千人”&#xff0c;在特定的分数段&#xff0c;比别人高一分&#xff0c;高考排名就比别人高一千并不是危言耸听&#xff0c;而利用好这些分数和排名&#xff0c;则有利于我们人生进入新的阶段。 纵观每年的高考&#xff0c;无论是老师考生还是家…

“北京到底有谁在啊”影视APP开发,解锁最简单的快乐

随着电视剧《玫瑰的故事》在腾讯视频APP热播&#xff0c;APP也增加了很多热度&#xff0c;一款丰富的影视APP&#xff0c;无论是热门大片、经典影视剧、还是最新综艺节目&#xff0c;能畅享无限精彩的影视内容&#xff01; 开发影视APP&#xff0c;需要专业的技术服务商来解决…

[leetcode]k-th-smallest-in-lexicographical-order 字典序的第K小数字

. - 力扣&#xff08;LeetCode&#xff09; class Solution { public:int getSteps(int curr, long n) {int steps 0;long first curr;long last curr;while (first < n) {steps min(last, n) - first 1;first first * 10;last last * 10 9;}return steps;}int find…