变量的千层套路:数据科学中最强大的武器

2024-01-26 11:20

本文主要是介绍变量的千层套路:数据科学中最强大的武器,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

全文共3019字,预计学习时长12分钟

变量的千层套路:数据科学中最强大的武器

图源:unsplash

 

我们无法想象没有数据的现代技术,如同现代技术需要石油一般,数据是信息时代的原材料。数据是我们得到任何事件和空间中信息的源头。

 

如果不了解数据,那你就太out了。首先,我们必须熟悉正在探索的数据。如果不太了解数据,那么在数据之上构建的系统或分析模型最终将毫无用处。因此,我们需要熟悉数据类型及其展示技术。

 

用于保存数据的参数在统计学中称为变量。一个数据集可以描述股票市场,其他数据集可以描述人口,员工数据等。这随系统而异。取值可以变化的属性就称为变量。

 

理解变量是走进数据科学的关键钥匙,而变量千变万化,用法多样,本文就将和大家好好聊聊变量。

 

变量的千层套路:数据科学中最强大的武器

 

变量类型

 

数据源非常庞大,我们可以从不同的数据源中找到不同类型的数据。了解数据的特征很重要,而数据的特征正是由变量定义。通过一些参数,我们可以轻松地对变量进行划分或分类。

 

变量的千层套路:数据科学中最强大的武器

变量类型

 

变量本质上有两种类型:数值和分类。

 

· 数值:以数字表示的所有变量都称为数值变量,也被称为定量变量。它可以是离散的,也可以是连续的。

 

离散变量,简单来说,就是包含可数数据的所有变量。例如,儿童的数量、SAT 分数、人口等,所有这些变量都包含离散数据。

 

连续变量即不可数的变量。对其计数需要花费无穷无尽的时间,计数过程永远不会结束。

 

示例:年龄是一个连续变量。这是为什么呢?假设,你的年龄是25岁,2个月,10天,7小时,40秒,44毫秒,10纳秒,99皮秒...等等。它永远不会结束。再如"平均"变量。如平均数字1.232343542543245....永远不会结束。

 

· 分类:分类变量也被称为定性变量,它表示的数据类型可以分为几组。汽车品牌就是一个分类变量,其中保存着分类数据,如奥迪,丰田,宝马等。答案是一个分类变量,它保存着分类数据是/否。

 

· 对变量的快速比较:

变量的千层套路:数据科学中最强大的武器

定量vs定性

 

变量的千层套路:数据科学中最强大的武器

 

度量水平

 

维基百科这样说:“度量水平或测量尺度是对分配给变量的值中信息性质进行描述的分类”。

 

心理学家斯坦利·史密斯·史蒂文斯提出了最著名的分类,其有四个度量层次或尺度:标称、次序、等距、等比。标称尺度和次序尺度用于测量定性和分类变量,等距尺度和等比尺度用于测量定量和数值变量。

 

变量的千层套路:数据科学中最强大的武器

度量水平

 

标称(Nominal):这是一个表示名称的拉丁语单词。标称尺度表示无法按任何顺序排列的类别。此尺度仅表示单个类别或名称。它只代表质量,而不提供有关差异大小的任何信息。它使用标称刻度,可以通过该变量定义两个人之间的差异。

 

示例:假设某变量表示汽车品牌:奥迪、丰田、宝马等。我们不能以任何方式对它们进行排序。因此,这些类型的变量属于标称尺度。

 

变量的千层套路:数据科学中最强大的武器

图源:unsplash

 

· 次序(Ordinal):这是一个有序的尺度。它指示可以按顺序排列的分类变量。我们可以用该尺度来确定变量间差异的方向,但无法确定差异的大小。

 

示例:有一个名为"身高"的变量表示人的身高,这又分为矮个子、中等个子和高个子。这些值的排序非常容易:高→中等→矮。这个顺序能很好地展示差异方向,但它不提供用以确定具体身高差的任何线索。

 

变量的千层套路:数据科学中最强大的武器

次序尺度的直觉

 

· 等距(Interval):表示各个级别之间相等间隔并可以表示为实数的变量称为等距尺度。它不仅对度量进行分类和排序,而且还规定沿低区间到高区间的刻度上每个间隔的距离相等。

 

示例:温度是一个变量,其中10摄氏度与20摄氏度,70摄氏度和80摄氏度之间的间隔相同。考试分数,高度,时间等都可以作为等距尺度的好例子。

 

· 等比(Ratio):这具有等距尺度的所有特性。它必须满足刻度中的零有意义。

 

假设我们正在考虑以°C和°F为单位测量体温,发现两个人的体温分别是10°C和20°C或10°F和20°F。我们不能说第二个人的体温是第一个人的2倍。因为0°C和0°F不是真正的零,它们并不意味着没有温度。如果要用等比尺度表示温度,则必须让开氏标度为0度,此时表明不存在温度。

 

变量的千层套路:数据科学中最强大的武器

 

使用Python展示数据

 

接下来,我们将讨论如何使用条形图,饼图和帕累托图来展示变量。

 

展示分类变量

 

假设有一个汽车销售市场的数据集,我们可以分析“汽车品牌”变量。首先计算不同汽车品牌出现的频率,就像下图所示:

 

变量的千层套路:数据科学中最强大的武器

演示汽车品牌频率

 

让我们将其转换为数据框。因为要分析此演示数据来进行图表展示。频率代表每个品牌的已售汽车数量。你可以对任何数据集执行相同的操作,使用pandas数据框转换此图像。

 

importpandas as pd
import matplotlib.pyplot as plt
df=pd.DataFrame({"Brand":['Audi',"BMW","Mercedes"],"Frequency":[124,98,113]})

变量的千层套路:数据科学中最强大的武器

Pandas数据框

 

计算相对频率

 

相对频率以百分比表示单个频率的分布:相对频率(%)=(个体频率/总频率)* 100。

 

df['RelativeFrequency(%)']=
round((df.Frequency/sum(df.Frequency))*100,2)

 

我们在主要数据集中添加了一个相对频率列:

 

变量的千层套路:数据科学中最强大的武器

有相对频率列的数据框

 

条形图

 

接下来,让我们用频率来绘制条形图。

 

import matplotlib.pyplot as pltfig,ax=plt.subplots()
var=plt.bar(df.Brand, df.Frequency,, alpha=0.5)#this loop isused to represent frequency on each bar
for idx,rect in enumerate(var):height = rect.get_height()ax.text(rect.get_x() +rect.get_width()/2., 1.01*height,df.Frequency[idx],ha='center', va='bottom',rotation=0)#adding labels and title
plt.ylabel('Frequency')
plt.xlabel('Brand Name')
plt.title('Car Sales Statistics')plt.show()

变量的千层套路:数据科学中最强大的武器

展示频率的条形图

 

饼图

 

我们还可以使用饼图表示不同类别数据之间频率的分布。

 

fig = plt.figure()
ax = fig.add_axes([0,0,1,1])
ax.axis('equal')ax.pie(df.Frequency, labels = df.Brand,autopct='%1.2f%%')
plt.show()

变量的千层套路:数据科学中最强大的武器

相对频率的饼图

 

帕累托图

 

帕累托图是一种特殊的条形图,其中类别以频率降序显示,累计频率用单独的曲线显示。

 

变量的千层套路:数据科学中最强大的武器

含有累计频率的数据框

 

frommatplotlib.ticker import PercentFormatterdf =df.sort_values(by='Frequency',ascending=False)
df["Cumulative Frequency"] =round(df["Frequency"].cumsum()/df["Frequency"].sum()*100,2)
fig, ax = plt.subplots(figsize=(10,5))
ax.bar(df.Brand, df["Frequency"], color="blue")
ax2 = ax.twinx()
ax2.plot(df.Brand, df["Cumulative Frequency"], color="red",marker="D", ms=7)
ax2.yaxis.set_major_formatter(PercentFormatter())ax.tick_params(axis="y",colors="black")
ax2.tick_params(axis="y", colors="black")
ax2.set_ylim(0,105)
ax.set_ylim(0,130)
plt.show()

变量的千层套路:数据科学中最强大的武器

图表的左侧代表频率,右侧代表累计频率

 

展示数值变量

 

还可以用条形图,饼图和帕累托图展示数值数据。如果想找到数值数据的频率,我们可能会发现每个数据的频率为1。但对于展示数据而言这是不可行的。那么应该怎么办呢?

 

我们可以将数值数据划分为不同的区间,然后计算该区间内数据的频率。通过一个python数据框可以获得更直观的感受。

 

df=pd.DataFrame({"data":[10,40,20,5,30,100,110,70,80,63,55,32,45,85,87,77,65,44,33,4,56,90,95,96]})

变量的千层套路:数据科学中最强大的武器

数据框的前五行数据

 

如果要计算频率,则大多数数据的频率将为1。

 

df['data'].value_counts()

变量的千层套路:数据科学中最强大的武器

数值数据的频率

 

现在,如果想用条形图,饼图来展示以上的频率,它们不能提供任何信息。所以需要计算区间内的频率。假设我们将数据分成5个相等的区间。

 

d=df['data'].value_counts(bins= 5).sort_index()

变量的千层套路:数据科学中最强大的武器

左列表示间隔,右列表示频率

 

Bingo!我们能够应用条形图,饼图和帕累托图来表示数值变量的频率啦。试着自己按照上述技巧为数值变量绘制图表吧。

 

变量的千层套路:数据科学中最强大的武器

图源:unsplash

 

变量的共同性质对于数据科学任务非常重要,想要进入数据科学领域,或者仅仅是想要对数据有所了解,都必须攻下变量这一关。希望本文能帮你搞懂一些关键内容。

变量的千层套路:数据科学中最强大的武器

一起分享AI学习与发展的干货
欢迎关注全平台AI垂类自媒体 “读芯术”

(添加小编微信:dxsxbb,加入读者圈,一起讨论最新鲜的人工智能科技哦~)

这篇关于变量的千层套路:数据科学中最强大的武器的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/646628

相关文章

Python获取中国节假日数据记录入JSON文件

《Python获取中国节假日数据记录入JSON文件》项目系统内置的日历应用为了提升用户体验,特别设置了在调休日期显示“休”的UI图标功能,那么问题是这些调休数据从哪里来呢?我尝试一种更为智能的方法:P... 目录节假日数据获取存入jsON文件节假日数据读取封装完整代码项目系统内置的日历应用为了提升用户体验,

Java利用JSONPath操作JSON数据的技术指南

《Java利用JSONPath操作JSON数据的技术指南》JSONPath是一种强大的工具,用于查询和操作JSON数据,类似于SQL的语法,它为处理复杂的JSON数据结构提供了简单且高效... 目录1、简述2、什么是 jsONPath?3、Java 示例3.1 基本查询3.2 过滤查询3.3 递归搜索3.4

MySQL大表数据的分区与分库分表的实现

《MySQL大表数据的分区与分库分表的实现》数据库的分区和分库分表是两种常用的技术方案,本文主要介绍了MySQL大表数据的分区与分库分表的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有... 目录1. mysql大表数据的分区1.1 什么是分区?1.2 分区的类型1.3 分区的优点1.4 分

Mysql删除几亿条数据表中的部分数据的方法实现

《Mysql删除几亿条数据表中的部分数据的方法实现》在MySQL中删除一个大表中的数据时,需要特别注意操作的性能和对系统的影响,本文主要介绍了Mysql删除几亿条数据表中的部分数据的方法实现,具有一定... 目录1、需求2、方案1. 使用 DELETE 语句分批删除2. 使用 INPLACE ALTER T

Python Dash框架在数据可视化仪表板中的应用与实践记录

《PythonDash框架在数据可视化仪表板中的应用与实践记录》Python的PlotlyDash库提供了一种简便且强大的方式来构建和展示互动式数据仪表板,本篇文章将深入探讨如何使用Dash设计一... 目录python Dash框架在数据可视化仪表板中的应用与实践1. 什么是Plotly Dash?1.1

Redis 中的热点键和数据倾斜示例详解

《Redis中的热点键和数据倾斜示例详解》热点键是指在Redis中被频繁访问的特定键,这些键由于其高访问频率,可能导致Redis服务器的性能问题,尤其是在高并发场景下,本文给大家介绍Redis中的热... 目录Redis 中的热点键和数据倾斜热点键(Hot Key)定义特点应对策略示例数据倾斜(Data S

Python实现将MySQL中所有表的数据都导出为CSV文件并压缩

《Python实现将MySQL中所有表的数据都导出为CSV文件并压缩》这篇文章主要为大家详细介绍了如何使用Python将MySQL数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到... python将mysql数据库中所有表的数据都导出为CSV文件到一个目录,并压缩为zip文件到另一个

SpringBoot整合jasypt实现重要数据加密

《SpringBoot整合jasypt实现重要数据加密》Jasypt是一个专注于简化Java加密操作的开源工具,:本文主要介绍详细介绍了如何使用jasypt实现重要数据加密,感兴趣的小伙伴可... 目录jasypt简介 jasypt的优点SpringBoot使用jasypt创建mapper接口配置文件加密

使用Python高效获取网络数据的操作指南

《使用Python高效获取网络数据的操作指南》网络爬虫是一种自动化程序,用于访问和提取网站上的数据,Python是进行网络爬虫开发的理想语言,拥有丰富的库和工具,使得编写和维护爬虫变得简单高效,本文将... 目录网络爬虫的基本概念常用库介绍安装库Requests和BeautifulSoup爬虫开发发送请求解

Oracle存储过程里操作BLOB的字节数据的办法

《Oracle存储过程里操作BLOB的字节数据的办法》该篇文章介绍了如何在Oracle存储过程中操作BLOB的字节数据,作者研究了如何获取BLOB的字节长度、如何使用DBMS_LOB包进行BLOB操作... 目录一、缘由二、办法2.1 基本操作2.2 DBMS_LOB包2.3 字节级操作与RAW数据类型2.