一文速学-Pandas处理分类数据(Categorical data)详解+代码演示(一)

简介: 一文速学-Pandas处理分类数据(Categorical data)详解+代码演示(一)

前言


时至如今Pandas仍然是十分火热的基于Python的数据分析工具,与numpy、matplotlib称为数据分析三大巨头,是学习Python数据分析的必经之路。Pandas提供了大量能使我们快速便捷地处理数据的函数和方法,它是使Python成为强大而高效的数据分析环境的重要因素之一。

使用Pandas进行数据预处理时需要对Pandas的基础数据结构Series和DataFrame有一个基础的了解。若是还不清楚的可以再去看看我之前的详解博文:


一文速学-数据分析之Pandas数据结构和基本操作代码


结合Pandas处理不同种类的数据,算下来共有重复值处理、缺失值处理、异常值处理等众多处理数据的方法。但我们使用Pandas做数据分析进阶操作,经常会使用到机器学习算法模型以及神经网络等算法,需要我们对数据进行预处理操作,其中就有label标签数据。而Pandas将此类标签数据单独提取出作为Catagorical data分类数据。了解处理此类型数据能够高效提升对我们进行数据进行建模和分析。对数据分析处理感兴趣的还可以阅读博主前几篇详解博文:


一文速学-Pandas异常值检测及处理操作各类方法详解+代码展示


一文速学-Pandas处理重复值操作各类方法详解+代码展示


一文速学-Pandas处理缺失值操作各类方法详解


以上三篇很容易学会,没有比较难的实战。此篇博客基于Jupyter之上进行演示,本篇博客的愿景是希望我或者读者通过阅读这篇博客能够学会方法并能实际运用,而且能够记录到你的思想之中。希望读者看完能够提出错误或者看法,博主会长期维护博客做及时更新。


一、分类数据(Categorical data)


分类是与统计中的分类变量相对应的数据类型。分类变量具有有限且通常固定的可能值数量(类别;R因子级别)。例如性别、社会阶层、血型、国家归属、观察时间或通过李克特量表进行的评级。


离散与分类


在学习该数据类型之前,我给大家稍微讲讲统计学的一些相关知识,方便大家后续理解函数的相关操作。根据数据类型我们可以可以将数据分为两种类型:


8326dcbeee1843afab2ba758ebc9aef8.png

在统计学中,数据按变量值是否连续可分为连续数据与离散数据两种.


变离数据是指其数值只能用自然数或整数单位计算.例如,企业个数,职工人数,设备台数等,只能按计量单位数计数,这种数据的数值一般用计数方法取得.

反之,在一定区间内可以任意取值的数据叫连续数据,其数值是连续不断的,相邻两个数值可作无限分割,即可取无限个数值.例如,生产零件的规格尺寸,人体测量的身高,体重,胸围等为连续数据,其数值只能用测量或计量的方法取得.

性质:符号x如果能够表示对象集合S中的任意元素,就是变量。如果变量的域(即对象的集合S)是离散的,该变量就是离散变量;如果它的域是连续的,它就是连续变量。


       与统计分类变量相比,分类数据可能有一个顺序(例如“强烈同意”与“同意”或“第一次观察”与“第二次观察”),但不可能进行数值运算(加法、除法等)。 在R语言基础之中,名义型变量和有序型变量称为因子,这些分类变量的可能值称为一个水平,level,例如good,better,best,都称为一个level。由这些水平值构成的向量就称为因子。我们发现R语言的因子和Pandas的Catagorical data数据类型几乎差不多。分类数据的所有值要么在类别中,要么就是np.nan。顺序是由类别的顺序定义的,而不是值的词汇顺序。在内部,数据结构由一个类别数组和一个整数代码数组组成,这些代码指向类别数组中的实值。


实例场景


仅由几个不同值组成的字符串变量。将这样的字符串变量转换为分类变量将节省一些内存。

变量的词汇顺序与逻辑顺序不同(“一”、“二”、“三”)。通过转换为分类并指定类别的顺序,排序和最小/最大将使用逻辑顺序而不是词汇顺序。

作为向其他Python库传递数据时,该列应被视为分类变量(例如,使用适当的统计方法或绘图类型)。


二、创建


1.Series创建


通过Series创建只需要在创建语句后面加上dtype="catagory":


series_cate=pd.Series(["a", "b", "c", "a"], dtype="category")


通过DataFrame创建后使用一列astype直接转换就好了:

df = pd.DataFrame({"A": ["a", "b", "c", "a"]})
df["B"] = df["A"].astype("category")
df.dtypes

ff03273f50494954af4b1fe48805b412.png

标签转换


通过使用自定义函数或者功能函数,例如cut(),能够将数值特征通过范围打上标签:

df = pd.DataFrame({"value": np.random.randint(0, 100, 20)})
labels = ["{0} - {1}".format(i, i + 9) for i in range(0, 100, 10)]
df["group"] = pd.cut(df.value, range(0, 105, 10), right=False, labels=labels)
df

57dfa2646e9f4742a5ee0d818daea464.png

通过Categorical函数可以实现更高级的标签转换:


1. raw_cat=pd.Categorical(df['group'], categories=['40 - 49','60 - 69'])
2. df["group2"] = raw_cat
3. df


97cd1d5d445f41a3a17b63eff61adfa9.png


可以去除空值保留想要保留的特征。


2.DataFrame创建


DataFrama可以整个转化为Catagory

df = pd.DataFrame({"A": ["a", "b", "c", "a"],"B":[1,2,3,4]},dtype="category")
df.dtypes

af41dcb926244fec87a5f56eea0ead02.png

或者和转换一列一样全部转换为category:

df = pd.DataFrame({"A": ["a", "b", "c", "a"],"B":[1,2,3,4]})
df_cat = df.astype("category")
df_cat.dtypes

f5d99ed5428541cd92041373f0185ba6.png

3.操作


1.CategoricalDtype函数


在上面传递dtype='category'的示例中参数均为默认,默认转换的category的类别:.


  • 类别是从数据中推断出来的。
  • 类别是无序的。


若需要控制上述两种情况,需要引入CategoricalDtype函数:

from pandas.api.types import CategoricalDtype
s = pd.Series(["a", "b", "c", "a"])
cat_type = CategoricalDtype(categories=["b", "c", "d"], ordered=True)
s_cat = s.astype(cat_type)
s_cat

db82f840ea354454baa80d25f288441b.png


上述代码就是在默认情况下,转换为category类型并没有设定categories,可以通过CategoricalDtype后期加上去。


对于DataFrame也是如此:

from pandas.api.types import CategoricalDtype
df = pd.DataFrame({"A": ["a", "b", "c", "a"],"B":[1,2,3,4]})
cat_type = CategoricalDtype(categories=list("abcd"), ordered=True)
df_cat = df.astype(cat_type)
df_cat.info

7b37fdc29d854ca39352647858848b0d.png


2.unique唯一标签


为了执行逐表转换,整个DataFrame中的所有标签都用作每列的类别,可以通过编程方式通过categories=pd.unique(df.to_numpy().ravel())确定categories参数。

df = pd.DataFrame({"A": ["a", "b", "c", "a"],"B":[1,2,3,4]})
categories = pd.unique(df['A'].to_numpy().ravel())
categories

array(['a', 'b', 'c'], dtype=object)


如果已经有了代码和类别,那么可以使用from_codes()构造函数在正常构造函数模式下保存分解步骤:

splitter = np.random.choice([0, 1], 5, p=[0.5, 0.5])
s = pd.Series(pd.Categorical.from_codes(splitter, categories=["train", "test"]))

2121e0b33c084fb989e25a592e866c19.png


三.转换


我们知道Category可以通过Series和DataFrame来创建,那么转换成原格式也是一样的:


Series.astype(original_dtype)
np.asarray(categorical)


目录
相关文章
|
20天前
|
数据处理 Python
如何使用Python的Pandas库进行数据排序和排名
【4月更文挑战第22天】Pandas Python库提供数据排序和排名功能。使用`sort_values()`按列进行升序或降序排序,如`df.sort_values(by='A', ascending=False)`。`rank()`函数用于计算排名,如`df['A'].rank(ascending=False)`。多列操作可传入列名列表,如`df.sort_values(by=['A', 'B'], ascending=[True, False])`和分别对'A'、'B'列排名。
24 2
|
20天前
|
存储 Python
使用Pandas库对非数值型数据进行排序和排名
在Pandas中,支持对非数值型数据排序和排名。可按以下方法操作:1) 字符串排序,使用`sort_values()`,如`sorted_df = df.sort_values(by='Name', ascending=False)`进行降序排序;2) 日期排序,先用`to_datetime()`转换,再排序,如`sorted_df = df.sort_values(by='Date')`;3) 自定义排序,结合`argsort()`和自定义规则。
27 2
|
2月前
|
数据格式 Python
如何使用Python的Pandas库进行数据透视图(melt/cast)操作?
Pandas的`melt()`和`pivot()`函数用于数据透视。基本步骤:导入pandas,创建DataFrame,然后使用这两个函数转换数据格式。示例代码展示了如何通过`melt()`转为长格式,再用`pivot()`恢复为宽格式。输入数据是包含'Name'和'Age'列的DataFrame,最终结果经过转换后呈现出不同的布局。
43 6
|
2月前
|
数据处理 Python
如何使用Python的Pandas库进行数据排序和排名?
Pandas在Python中提供数据排序和排名功能。使用`sort_values()`进行排序,如`df.sort_values(by='A', ascending=False)`进行降序排序;用`rank()`进行排名,如`df['A'].rank(ascending=False)`进行降序排名。多列操作可传入列名列表,如`df.sort_values(by=['A', 'B'], ascending=[True, False])`。
32 6
|
2月前
|
索引 Python
如何使用Python的Pandas库进行数据合并和拼接?
【2月更文挑战第28天】【2月更文挑战第103篇】如何使用Python的Pandas库进行数据合并和拼接?
|
2月前
|
索引 Python
如何在Python中,Pandas库实现对数据的时间序列分析?
Pandas在Python中提供强大的时间序列分析功能,包括:1) 使用`pd.date_range()`创建时间序列;2) 通过`pd.DataFrame()`将时间序列转为DataFrame;3) `set_index()`设定时间列作为索引;4) `resample()`实现数据重采样(如按月、季度);5) `rolling()`进行移动窗口计算,如计算移动平均;6) 使用`seasonal_decompose()`进行季节性调整。这些工具适用于各种时间序列分析场景。
44 0
|
16天前
|
数据采集 数据处理 索引
如何使用 Pandas 删除 DataFrame 中的非数字类型数据?
如何使用 Pandas 删除 DataFrame 中的非数字类型数据?
27 3
|
18天前
|
存储 数据挖掘 数据处理
使用pandas高效读取筛选csv数据
本文介绍了使用Python的Pandas库读取和处理CSV文件。首先,确保安装了Pandas,然后通过`pd.read_csv()`函数读取CSV,可自定义分隔符、列名、索引等。使用`head()`查看数据前几行,`info()`获取基本信息。Pandas为数据分析提供强大支持,是数据科学家的常用工具。
23 0
|
19天前
|
数据挖掘 数据处理 索引
如何使用Python的Pandas库进行数据筛选和过滤?
Pandas是Python数据分析的核心库,提供DataFrame数据结构。基本步骤包括导入库、创建DataFrame及进行数据筛选。示例代码展示了如何通过布尔索引、`query()`和`loc[]`方法筛选`Age`大于19的记录。
21 0
|
19天前
|
索引 Python
如何使用Pandas进行数据合并?
Pandas提供`merge()`, `join()`, `concat()`等方法进行数据合并。基本步骤包括导入pandas库、创建或加载DataFrame,然后调用这些方法合并数据。示例中展示了如何使用`merge()`和`join()`:创建两个DataFrame `df1`和`df2`,通过`merge()`基于索引合并,以及`join()`进行外连接合并。
21 0