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

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

相关文章

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

基于MySQL Binlog的Elasticsearch数据同步实践

一、为什么要做 随着马蜂窝的逐渐发展,我们的业务数据越来越多,单纯使用 MySQL 已经不能满足我们的数据查询需求,例如对于商品、订单等数据的多维度检索。 使用 Elasticsearch 存储业务数据可以很好的解决我们业务中的搜索需求。而数据进行异构存储后,随之而来的就是数据同步的问题。 二、现有方法及问题 对于数据同步,我们目前的解决方案是建立数据中间表。把需要检索的业务数据,统一放到一张M

关于数据埋点,你需要了解这些基本知识

产品汪每天都在和数据打交道,你知道数据来自哪里吗? 移动app端内的用户行为数据大多来自埋点,了解一些埋点知识,能和数据分析师、技术侃大山,参与到前期的数据采集,更重要是让最终的埋点数据能为我所用,否则可怜巴巴等上几个月是常有的事。   埋点类型 根据埋点方式,可以区分为: 手动埋点半自动埋点全自动埋点 秉承“任何事物都有两面性”的道理:自动程度高的,能解决通用统计,便于统一化管理,但个性化定

使用SecondaryNameNode恢复NameNode的数据

1)需求: NameNode进程挂了并且存储的数据也丢失了,如何恢复NameNode 此种方式恢复的数据可能存在小部分数据的丢失。 2)故障模拟 (1)kill -9 NameNode进程 [lytfly@hadoop102 current]$ kill -9 19886 (2)删除NameNode存储的数据(/opt/module/hadoop-3.1.4/data/tmp/dfs/na

异构存储(冷热数据分离)

异构存储主要解决不同的数据,存储在不同类型的硬盘中,达到最佳性能的问题。 异构存储Shell操作 (1)查看当前有哪些存储策略可以用 [lytfly@hadoop102 hadoop-3.1.4]$ hdfs storagepolicies -listPolicies (2)为指定路径(数据存储目录)设置指定的存储策略 hdfs storagepolicies -setStoragePo

Hadoop集群数据均衡之磁盘间数据均衡

生产环境,由于硬盘空间不足,往往需要增加一块硬盘。刚加载的硬盘没有数据时,可以执行磁盘数据均衡命令。(Hadoop3.x新特性) plan后面带的节点的名字必须是已经存在的,并且是需要均衡的节点。 如果节点不存在,会报如下错误: 如果节点只有一个硬盘的话,不会创建均衡计划: (1)生成均衡计划 hdfs diskbalancer -plan hadoop102 (2)执行均衡计划 hd

变量与命名

引言         在前两个课时中,我们已经了解了 Python 程序的基本结构,学习了如何正确地使用缩进来组织代码,并且知道了注释的重要性。现在我们将进一步深入到 Python 编程的核心——变量与命名。变量是我们存储数据的主要方式,而合理的命名则有助于提高代码的可读性和可维护性。 变量的概念与使用         在 Python 中,变量是一种用来存储数据值的标识符。创建变量很简单,

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

烟火目标检测数据集 7800张 烟火检测 带标注 voc yolo

一个包含7800张带标注图像的数据集,专门用于烟火目标检测,是一个非常有价值的资源,尤其对于那些致力于公共安全、事件管理和烟花表演监控等领域的人士而言。下面是对此数据集的一个详细介绍: 数据集名称:烟火目标检测数据集 数据集规模: 图片数量:7800张类别:主要包含烟火类目标,可能还包括其他相关类别,如烟火发射装置、背景等。格式:图像文件通常为JPEG或PNG格式;标注文件可能为X

pandas数据过滤

Pandas 数据过滤方法 Pandas 提供了多种方法来过滤数据,可以根据不同的条件进行筛选。以下是一些常见的 Pandas 数据过滤方法,结合实例进行讲解,希望能帮你快速理解。 1. 基于条件筛选行 可以使用布尔索引来根据条件过滤行。 import pandas as pd# 创建示例数据data = {'Name': ['Alice', 'Bob', 'Charlie', 'Dav