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://www.mzph.cn/news/835342.shtml

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

相关文章

TDM(BPM)-MIMO-FMCW雷达MATLAB仿真

本文通过对车载毫米波雷达信号流程和链路的仿真,建立基本的算法框架,可用于算法性能的验证。并提供基础MATLAB仿真代码,作为分享和参考。 一、信号的产生 车载毫米波雷达广泛使用线性调频连续波雷达,也即发射信号频率随时间线性变…

日本OTC机械手维修需要注意哪些问题呢?

随着工业4.0时代的到来,机器人在制造业中的应用越来越广泛。OTC(Over The Counter)机器人作为工业机器人的一种,以其高效、精准、稳定的特点受到众多企业的青睐。然而,在实际使用过程中,可能会出现一些OTC机…

如何在路由器上做端口映射

假设现在外网有一台ADSL直接拨号上网的电脑,所获得的是公网IP。然后它想访问局域网内的电脑上面的网站,那么就需要在路由器上做端口映射。在路由器上做端口映射的具体规则是:将所有发向自己端口的数据,都转发到内网的计算机。 访…

github删除自己的仓库

测试Github的时候新建了很多仓库,但是后来想删除,找了半天居然没有找到按钮。 我就推测这个删除的功能肯定藏起来了,后来度娘了一下,发现果然在一个比较隐蔽的位置,不知道以后这个功能会不会改到一个比较明显的位置吧…

c++ 归并排序

归并排序是一种遵循分而治之方法的排序算法。它的工作原理是递归地将输入数组划分为较小的子数组并对这些子数组进行排序,然后将它们合并在一起以获得排序后的数组。 简单来说,归并排序的过程就是将数组分成两半,对每一半进行排序&#xff0c…

原子学习笔记5——点亮 LED

一、应用层操控设备的两种方式 应用层如何操控底层硬件,同样也是通过文件 I/O 的方式来实现,设备文件便是各种硬件设备向应用层提供的一个接口,应用层通过对设备文件的 I/O 操作来操控硬件设备,譬如 LCD 显示屏、串口、按键、摄像…

面向对象设计之套路——设计模式

1、总则 面向对象的分析设计编程思想,通过封装、继承、多态把程序的耦合度降低,用设计模式使得程序更加灵活,容易修改,并且易于复用。 让业务逻辑与界面逻辑分开,让它们的耦合度下降,只有分离,…

nginx--FastCGI

CGI 概念 nginx通过与第三方基于协议实现,即通过某种特定协议将客户端请求转发给第三方服务处理,第三方服务器会新建新的进程处理用户的请求,处理完成后返回数据给Nginx并回收进程(下次处理有需要新建),最后nginx在返回给客户端…

Jenkins流水线部署Maven项目

使用Jenkins的流水线功能,构建部署Java Maven项目,步骤很简单但是不少细节需要注意。 一、安装 Jenkins的安装步骤和流程就不具体描述,这里主要介绍一下安装时要注意的几个问题。 1、Jenkins尽量安装最新的几个版本,否则安装完成…

elixir V2测试网验证器一键部署脚本

实际收益 1、服务器环境 服务器系统:centos 7或者ubuntu 20.04(以上) CPU:2核 内存:4G 硬盘:30G ssd 网络:可靠的 100Mbit 互联网 2、部署脚本 #!/bin/bash set -eif [ "$#" -ne 3 ]; thenecho "Usage:

(已解决)org.springframework.amqp.rabbit.support.ListenerExecutionFailedException

报错截图 解决方案 1、登录rabbitMQ网址,删除所有队列 2、重启rabbitMQ 亲测有效!!!亲测有效!!!亲测有效!!!

uni-appH5Android混合开发二 || 使用Android Studio打包应用APK

前言: 在上一章节我们已经讲了如何uni-app离线打包Android平台教程,这一章就该来讲讲如何使用Android Studio打包应用APK提供给Android手机安装使用了。 uni-app跨平台框架介绍和快速入门 uni-app跨平台框架介绍和快速入门 第一步、首先打开已经编译好的…

javac编译web项目中的src

对于单个文件的且不引用其他类文件的java源码用javac编译大家都很熟悉即 javac hello.java, 服务器未安装idea,现在在服务器里面直接编译src目录 1 idea项目结构如下 2 web目录为最终部署的代码 WEB-INF下面没有 classes 目录 3 使用javac 编译src javac -encod…

图:广度优先遍历(BFS)和深度优先遍历(DFS)

1.工具类:队列和字典 export class DictionNary {// 字典的封装constructor() {this.items {}}set(key, value) {// 添加键this.items[key] value}has(key){// 判断键是否存在return this.items.hasOwnProperty(key)}get(key){// 获取键的valuereturn this.has(k…

六级仔细阅读

画两到三个词,精准定位 要原文和同义都满足才选 先看题目,在看原文,不要先看选项 做不出答案就继续往下读,读出来了就不用继续读了 分清楚是问为什么还是是什么,是什么看前面,为什么看后面 不知道就优先…

力扣HOT100 - 215. 数组中第K个最大元素

解题思路: 快速选择,目标是找出数组中第 k 小(或第 k 大)的元素,而不是对整个数组进行排序。 (需要和快排进行区分,快排的目的是排序) 注意: i l - 1, j r 1; 为什…

Spring Boot集成zookeeper快速入门Demo

1.什么是zookeeper? Zookeeper 是一个开源的分布式协调服务,目前由 Apache 进行维护。Zookeeper 可以用于实现分布式系统中常见的发布/订阅、负载均衡、命令服务、分布式协调/通知、集群管理、Master 选举、分布式锁和分布式队列等功能。它具有以下特性…

学习Java的日子 Day45 HTML常用的标签

Day45 HTML 1.掌握常用的标签 1.1 标题标签 h1-h6 <h1>一级标签</h1> <h2>二级标签</h2> <h3>三级标签</h3> <h4>四级标签</h4> <h5>五级标签</h5> <h6>六级标签</h6> 显示特点&#xff1a; * 文字…

MemoryModule - exp - test

文章目录 MemoryModule - exp - test概述笔记测试环境GetModuleFileName不能正常执行GetModuleFileNameWntdll_LdrGetDllFullName猜测原因用LoadLibrary载入的DLL中功能是正常的 gLog可以正常使用内存载入DLL无法支持的功能的折中方法COM操作正常调用方代码接口代码 接口入参测…

基于springboot实现毕业设计系统项目【项目源码+论文说明】

基于springboot实现毕业设计系统演示 摘要 在如今社会上&#xff0c;关于信息上面的处理&#xff0c;没有任何一个企业或者个人会忽视&#xff0c;如何让信息急速传递&#xff0c;并且归档储存查询&#xff0c;采用之前的纸张记录模式已经不符合当前使用要求了。所以&#xff…