Python之数据分析基础

导言:

“21世纪的竞争是数据的竞争,谁掌握数据,谁就掌握未来”。如何将大量看似杂乱无章的数据进行聚合,并发现潜在的规律也变得越来越重要。本文将先说明数据分析的步骤,再通过python完成实例数据的处理、分析最终展示的全过程,让大家了解数据分析的基础知识。

一、数据分析概述

1.1什么是数据分析

数据分析是指用适当的统计分析方法对收集来的大量数据进行分析,把隐藏在一些看似杂乱无章的数据背后的信息提炼出来,总结出所研究对象的内在规律。现实生活中,数据分析以及运用到各个方面,例如大家在购物的时候,用过你的搜索关键字、收藏、浏览等行为产生的数据,分析你可能想要的东西,并进行相关的推荐。在实际的工作中,我们通过数据分析的结果来决策未来的方向,而非拍脑袋拍板,避免了损失也提高了工作效率。

1.2数据分析的划分

数据分析的数据分析划分为描述性统计分析、探索性数据分析以及验证性数据分析;其中,探索性数据分析侧重于在数据之中发现新的特征,而验证性数据分析则侧重于已有假设的证实或证伪。

1.3数据分析的步骤

图片

  1. 明确目标

聚焦要分析的数据目标,针对性的数据采集,处理分析,确保整个数据分析过程的有效进行。

      2. 数据采集

根据数据分析确定的目标来收集相关的数据,确保后面数据分析的基础材料。

  1. 数据处理

通过数据收集来的数据是杂乱无章的数据进行整理、加工,保证搜集的数据的质量,对于后期数据的分析非常的重要。

      4. 数据分析

经过处理后的数据,就能得到高质量可分析的数据,通过适当的数据分析策略和工具对数据进行研究分析跟实际场景结合,总结出数据潜在的关系。

      5. 数据展示

数据展示及可视化,经过分析的数据,如何跟友好的展示出来,且让用户更好的理解。但是此部分只是辅助,分析出有价值的数据才是重心。

1.4数据分析方法(此处介绍3种常用的易于理解的数据分析方法)

      1.漏斗分析法

漏斗模型是一套流程式数据分析,它能够科学反映用户行为状态以及从起点到终点各阶段用户转化率情况,是一种重要的分析模型。漏斗分析法广泛在互联网行业应用,下图举例银行信用卡申请流程及应用的漏斗模型。

图片

      2.对比分析法

对比分析法又称对比法,通过比较指标的实际数跟基数比较,反应事物数量上的变化。对比法特点是简单、直观、量化。例如我们常见到的环比值=(本周期-上年同周期)/上年同周期  算出环比值。下图为全球主要经济体GDP占世界的比重(%)

图片

图片来源:中国银行在北京发布《2021年度经济金融展望报告》

      3.分组分析法

根据实物的内在特性,按照一定的指标,将数据总体划分成不同的部分,分析其内部结构和相互关系,从而了解实物的规律。在使用过程中,分组分析法一般与对比分析法结合使用。例如对于历年来农民工年龄的分布图:

图片

图片来源:国家统计局《2020年农民工监测调查报告》

二、Python中的常用的数据分析库

1.基础库Numpy

python中跟数据分析相关的基础库Numpy,支持大量的维度数组与矩阵运算,此外也针对数组运算提供大量的数学函数库。

2.分析结构化数据的工具 Pandas

Pandas是基于Numpy的一个分析结构化数据工具,支持SQL和表格的数据处理,纳入了大量库和一些标准的数据模型,提供了高效地操作大型数据集所需的工具。

    2.1安装Pandas:

pip3 install pandas

    

    2.2 Pandas 基本数据结构:series 跟 dataframe 两种基本数据结构类型,前者类似于一维数组,后者则相当于一张二维数据组。

    

    2.3 Pandas常用操作:

    2.3.1创建series 两种方式如下:

 
#通过数组创建t = pd.Series([1,2,3,4,43],index=list('asdfg'))print(t)#通过字典创建temp_dict = {'a':1,'b':2,'c':3}t2 = pd.Series(temp_dict)print(t2)

运行结果:

 
a     1s     2d     3f     4g    43dtype: int64
a    1b    2c    3dtype: int64

    2.3.2创建 dataframe的方式如下:

 

temp_dict = {'name':['putao','xigua'],'kg':[1,23],'large':['small','big']}t1 = pd.DataFrame(temp_dict)print(t1)

运行结果:

 
name  kg  large0  putao   1  small1   xigua  23    big

3.数据可视化的绘图库Matplotlib

数据可视化展示工具,python中使用比较多的就是Matplotlib库,可绘制各种图形展示出来。利用Numpy+Matplotlib实例画一个简单的图:

​​​​​​​
import numpy as npimport matplotlib.pyplot as mt
data = np.random.randn(1000)  #要展示的数据基数,此方法可返回正态分布mt.subplot(2,2,4)#生成一个2*2个子区域的画板,4代表在第四个画板区域画图mt.hist(data,facecolor="blue", edgecolor="black", alpha=0.7)#在画板上绘制直方图mt.xlabel("区间") # 显示横轴标签mt.ylabel("数量") # 显示纵轴标签mt.title("分布") # 显示图标题mt.show() #把图展示出来方法

上述代码运行结果如下:

图片

三、Python进行数据分析实例

1. 对csv 文件进行读取,写入并对数据进行简单处理的基本操作:

基础csv数据如图:

图片

代码处理过程如下:

 

​​​​​​​

import pandas as pdimport csv
old_path = '/Users/zn/Documents/work/data.csv'#数据转换成DataFrame格式df = pd.read_csv(old_path)print(df.head(5))#打印出不同列的数据类型print('datatype of column 姓名 is: ' + str(df['姓名'].dtypes))print('datatype of column 分数 is: ' + str(df['分数'].dtypes))#计算数据之和print('第一名跟第三名分数之和:' + str(df['分数'][0]+df['分数'][2]))

运行结果如下:

 
排名  姓名    分数0   1  张三  99.01   2  李四  98.02   3  张小  97.03   4  张大   NaN4   5  张中  95.0datatype of column 姓名 is: objectdatatype of column 分数 is: float64第一名跟第三名分数之和:196.0Process finished with exit code 0

运行结果可以看出,未空的会自动用占位符 ‘NaN'填补。Pandas还可以自动推断出每列的数据类型,以便于对数据的处理。

文本数据的存储的实现:

 

​​​​​​​

import numpy as npimport pandas as pd
db = pd.DataFrame(np.array([[1,2],[1,3]]),columns=['序列','数量'])db.to_csv('savedata.csv','|')#在此文件同目录下生产一个csv文件

运行后,文件内容:

 

​​​​​​​

|序列|数量0|1|21|1|3

2.数据分析案例

通过上诉的数据分析步骤及python下数据分析的库对上季度本部门测试环境产生的bug进项分析实例。先把数据从bug系统导出后数据放到CSV文件内。文件里的字段信息如下:

图片

  • name:商品名称。

  • goods_id:商品ID。

  • description:商品描述。

  • num:商品销售的数量。

  • time:商品销售时间。

  • price:商品价格。

  • userid:商品购买的用户ID。

整个表格里的数据存在重复、缺失、无用的字段等问题。直接从这些数据里无法看出任何的规律。希望通过以下步骤实现最终的商品价格分布图:

  1. 去掉重复数据。

  2. 去掉异常数据,例如负数或者数量为空的数据。

  3. 找出销量最好的前3名商品。

  4. 展示商品的价格分布图。

具体实现代码如下:

 

​​​​​​​

import pandas as pdimport matplotlib.pyplot as mt
data = pd.read_csv('./goods.csv')# 读取数据data.head()# 去掉没有用的字段例如商品描述data.drop("description", axis=1, inplace=True)data.info
# 查看缺失的数据print('查看用户ID有缺失的数据:\n', data[data['userid'].isnull()])# d对于重点字段填补缺失值data['userid'] = data['userid'].astype("str").fillna("unknow")# 查看重复的数据量,duplicated()方法检测的标准是整行都一样算重复print('统计重复数据的和:\n', data.duplicated().sum())# 删除重复的数据data = data.drop_duplicates()# 获取销量前三的商品,商品ID分组然后按照销量合并算出销量最多的data_thr = data["num"].groupby(data['goods_id']).sum().sort_values(ascending=False)# 获取销量前三的商品print('销量前三的商品:\n', data_thr[:3])# 商品价格分布跟商品价格与销量之间的关系data_stock = data.drop_duplicates(['goods_id'])print('查看处理后的数据:\n',data_stock['price'].describe())#定义商品的价格区间 ,左开右闭price = pd.cut(data_stock['price'],bins=[5,10,20,50,100,500,1000,5000,10000]).value_counts().sort_index()mt.figure(figsize=(6,3))#设置画布的长宽不是cm是英尺price.plot(kind='bar')#bar标示我们画的是个柱状图mt.savefig('./test.png')mt.title('商品价格跟销售数量图')mt.xticks(fontsize =4,rotation=30)mt.xlabel('价格(元)',fontsize=8)mt.ylabel('销售数量',fontsize=8)mt.show()

运行结果:

 

​​​​​​​

查看用户ID有缺失的数据:name  goods_id  num time  price userid13  玩具3        13    2  NaN  12.34    NaN14  玩具4        14    3  NaN  22.00    NaN
统计重复数据的和:2销量前三的商品:goods_id12    1761     1002      99Name: num, dtype: int64查看处理后的数据:count       20.000000mean       616.822000std       2217.183709min        -12.30000025%          7.40750050%         14.33000075%        321.280000max      10000.000000Name: price, dtype: float64

运行后的分析图如下:

图片

pandas.describe()函数的用法:从上面结果可以看出来,对于数值型数据输出结果指标包括count,mean,std,min,max以及第25百分位,中位数(第50百分位)和第75百分位。对于不同类型的,输出的指标不一样,感兴趣的实验下对于对象类型数据和混合数据类型DataFrame输出的指标。

总结

上文中阐述了数据分析的步骤,并通过具体实例,对数据的整理、清洗、汇总、分析、最后把数据展示出来。文中用到的方法,还有很多其他参数可增加会产生不同的效果图及对比值,感兴趣的同学,可以尝试使用

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

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

针对 % 号 | 引起的 不安全情况

把网站开放的课程都检索下来了 一、情况1 org.apache.tomcat.util.http.Parameters processParameters 信息: Character decoding failed. Parameter [Mac] with value [%%%] has been ignored. Note that the name and value quoted here may be corrupted due to the failed…

【北京迅为】《iTOP-3588从零搭建ubuntu环境手册》-第4章 Ubuntu20.04支持中文

RK3588是一款低功耗、高性能的处理器,适用于基于arm的PC和Edge计算设备、个人移动互联网设备等数字多媒体应用,RK3588支持8K视频编解码,内置GPU可以完全兼容OpenGLES 1.1、2.0和3.2。RK3588引入了新一代完全基于硬件的最大4800万像素ISP&…

电商购物系统商品数据结构设置

电商购物系统商品数据结构设置 如上图所示 , 该表为商品表关系的示意图 , 气质我们要溥仪一个电视购物系统要用到的知识那就是SPU和SKU 简单来说这两种就是不同的分类方式 , 我们在浏览淘宝等页面的时候也会遇见相同的情况如我们可以进行品牌的筛选 , 也可以进行商品价格的筛选…

C# WinForm —— 13 ComboBox下拉框/组合框介绍

1. 简介 ComboBox 是由 textBox 和 listBox 组合而成的,只能选择一项,不能选择多项,其他功能和 listBox类似 ComboBox 下拉框的三种样式:(通过 DropDownStyle属性 设置) Simple: 最简单的样式&#xff0c…

YOLO系列笔记(十四)——Compute Canada计算平台及其常见命令介绍

Compute Canada平台及其常见命令介绍 前言优势使用方法1. 检查模块不带版本号带版本号 2. 加载模块3. 检查模块是否加载成功4. 创建虚拟环境5. 编写作业脚本6. 提交作业7. 监控作业状态8. 查看作业开始预计时间9. 查看作业的详细输出10. 取消作业 注意结语 前言 大家好&#x…

QML 本地存储(Setting,sqlite)

Qt hello - 专注于Qt的技术分享平台 QML 原生的储存方有两种: 1,Settings 跟QWidget 中的QSettings 一样,可以简单的存储一些配置。 2,Sqlite sqlite数据库。可以存储一些复杂的数据。 一,Settings 我们以一个按钮的位…

揭秘微服务架构:十大设计模式助力企业数字化转型

微服务架构中10个常用的设计模式 微服务是一种架构风格,它将一个复杂的应用拆分成多个独立自治的服务,每个服务负责应用程序中的一小部分功能。这些服务通过定义良好的API进行通信,通常是HTTP RESTful API或事件流。微服务架构的主要特点包括…

【SpringSecurity源码】过滤器链加载流程

theme: smartblue highlight: a11y-dark 一、前言及准备 1.1 SpringSecurity过滤器链简单介绍 在Spring Security中,过滤器链(Filter Chain)是由多个过滤器(Filter)组成的,这些过滤器按照一定的顺序对进…

工作中使用Optional处理空指针异常

工作中使用Optional处理空指针异常 实体类以前对空指针的判断Optional处理空指针测试结果 实体类 package po;import lombok.AllArgsConstructor; import lombok.Data; import lombok.NoArgsConstructor;import java.io.Serializable;Data AllArgsConstructor NoArgsConstruct…

某大型集团SAP数字化转型方案(95页PPT)

一、资料介绍 《某大型集团SAP数字化转型方案》是一份详尽的95页PPT资料,旨在为某大型集团提供一套全面而深入的SAP数字化转型方案。该方案紧密结合了集团的业务特点和发展需求,以SAP系统为核心,通过数字化技术的运用,实现业务流…

图片格式不对怎么转换?推荐几个图片转换的高效处理方法

在日常使用电脑或处理图片的过程中,我们经常会遇到图片格式不兼容的问题,例如,我们可能收到了一个无法打开的图片文件,或者想将图片转换为其他格式以便在不同的应用程序中使用,这时候就需要将图片转格式,所…

智慧公厕解决了什么问题?

在现代城市生活中,公厕是一个不可忽视的环节。然而,过去的公共厕所常常存在管理不力、环境脏乱差等问题,给人们的生活带来了许多不便和困扰。为了解决这些问题,智慧公厕应运而生,成为了公共厕所使用、运行、管理、养护…

无线收发模块家电控制实验

zkhengyang可申请加入数字音频系统研究开发交流答疑群(课题组) 当然可以先用固定电平发送,可以实现,0/1数据发送,接收。 可以使用51单片机来编码码,解码,或者任何MCU或者SOC,DSP,FPGA。 注意G…

WebSocket基础知识

WebSocket是什么? WebSocket 是一种网络通信协议,它提供了全双工通信机制,允许服务器主动向客户端发送消息,而不仅限于响应客户端的请求。它使用类似于 HTTP 的握手来建立连接,然后使用单独的持久连接来进行通信。这种…

电视剧推荐

1、《春色寄情人》 2、《唐朝诡事录》 3、《南来北往》 4、《与凤行》 5、《利剑玫瑰》 6、《承欢记》

使用nmcli命令在Linux系统上配置各种网络(有线、无线、vlan、vxlan、路由、网桥等)

前言:原文在我的博客网站中,持续更新数通、系统方面的知识,欢迎来访! 使用nmcli命令在Linux系统上配置各种网络(有线、无线、vlan、vxlan、路由、网桥等)https://myweb.myskillstree.cn/123.html 你是否会…

护眼台灯和普通台灯差别很大吗?专业护眼灯品牌有哪些?

随着科技的不断演进,台灯的设计也日益脱胎换骨,从曾经的笨重造型转变为如今轻盈雅致的外观。它们的功能同样经历了多样化的革新,变得更加人性化和便捷。作为学习、阅读和办公环境中不可或缺的照明工具,台灯所提供的光线舒适度至关…

ChatGLM 本地部署指南(问题解决)

硬件要求(模型推理): INT4 : RTX3090*1,显存24GB,内存32GB,系统盘200GB 如果你没有 GPU 硬件的话,也可以在 CPU 上进行推理,但是推理速度会更慢。 模型微调硬件要求更高。…

【ArcGISProSDK】condition属性

示例 通过caption属性可以看出esri_mapping_openProjectCondition的条件是一个工程被打开 condition的作用 由此可知示例中的Tab实在工程被打开才能使用,否则他禁用显示灰色,在未禁用的时候说明条件满足。 参考文档 insertCondition 元素 (arcgis.com…

擦边宣传、质量堪忧、销量惨淡,创维汽车将何去何从?

文/张诗雨 近日,据多家媒体报道,创维汽车创始人黄宏生在公开场合发言称,创维汽车有助于养生,他在创维汽车里午休,高血压没吃药都恢复正常了。该言论引起网友热议。 针对此事件,5月9日,创维汽车…