【pandas基础】–核心数据结构

yizhihongxing

pandas中用来承载数据的两个最重要的结构分别是:

  1. Series:相当于增强版的一维数组
  2. DataFrame:相当于增强版的二维数组

pandas最大的优势在于处理表格类数据,如果数据维度超过二维,一般我们会使用另一个 python的库 numpy

本篇主要介绍这两种核心数据结构的创建方式。

1. Series

pandasSeries是一种带有标签索引的一维数据结构。
它可以表示任何一维带标签的数据,例如时间序列数据、运动员数据、股票价格等等。

pandasSeries由两个数组构成:一个是数据数组,它可以是numpy数组、列表、字典等;另一个是索引数组,它指定数据数组中每个元素的标签。

Series可以进行各种数学运算、逻辑运算和复制操作,可以轻松创建、操作和使用。
pandasSeries特别强大之处就是可以使用各种方法进行数据的操作、处理和分析,因此在数据分析、数据处理和科学计算方面非常有用。

常用的创建 Series有两种方式:

1.1 从列表创建

l = [78, 89, 95]
s = pd.Series(l)
s.head()

image.png
从列表可以直接创建出 Series,可以看出,与一般的一维数组相比,Series多了一列索引信息。
其实,除此之外,Series还有很多用于分析和统计的方法,后续我们再介绍。

索引默认是从0开始的数字,也可以在创建时设置有意义的索引名称。

l = [78, 89, 95]
s = pd.Series(l, index=["语文", "数学", "英语"])
s.head()

image.png

1.2 从字典创建

d = {"a": 78, "b": 89, "c": 95}
s = pd.Series(d)
s.head()

image.png
从字典创建Series时,会将字典的 key作为了索引。
修改索引不用 index参数,而是直接修改字典的 key

d = {"语文": 78, "数学": 89, "英语": 95}
s = pd.Series(d)
s.head()

image.png

2. Dataframe

pandasDataFrame是一个二维的数据结构,可以存储各种类型的数据,类似于Excel中的表格。
它由行和列组成,每一行和每一列都有一个索引值,可以通过索引值进行读写操作。

DataFrame支持许多操作,包括对数据的过滤、切片、排序、连接和聚合等。
它还可以从各种数据源(如CSV、SQL数据库和Excel)中读取数据,并将数据写入这些数据源。

pandas中,DataFrame可以使用字典、列表、Numpy数组、其他pandas数据框等构建。
DataFrame还有一些重要的属性和方法,例如headtaildescribe等,用于查看数据、统
计数据、随机抽样等。

除此之外,DataFrame还支持pandas中的许多高级操作,例如多重索引、透视表、重塑等。
这些功能使DataFrame成为数据分析中必不可少的工具。

2.1 从列表创建

l = [[78, 89, 95], [65, 84, 100]]
df = pd.DataFrame(l)
df.head()

image.png
从列表创建DataFrame之后,默认的索引列名称都是从0开始的数字。
也可以自定义DataFrame的索引名称和列名称,通过 indexcolumns参数。

l = [[78, 89, 95], [65, 84, 100]]
df = pd.DataFrame(l, index=["小明", "小红"], columns=["语文", "数学", "英语"])
df.head()

image.png

2.2 从字典创建

d = [{"语文": 78, "数学": 89, "英语": 95}, {"语文": 65, "数学": 84, "英语": 100}]
df = pd.DataFrame(d)
df.head()

image.png
字典的key作为列名称,索引不设置的话,默认还是从0开始的数字。

2.3 从 numpy 数组创建

import numpy as np

data = np.array([[78, 89, 95], [65, 84, 100]])
df = pd.DataFrame(data)
df.head()

image.png
numpy二维数组创建 DataFrame和直接从列表创建类似。
注意,这里只能从 numpy的二维数组创建,如果是维度更高的数组,创建时会出错。

data = np.array([[[78, 89, 95], [65, 84, 100]]])
df = pd.DataFrame(data)
df.head()

上面的 data是三维数组,执行上面的代码会有如下的错误信息:
image.png

3. 两种结构互相转换

pandas的两种核心结构之间是可以互相转换的,可以将 Series理解为 DataFrame的一列。

3.1 Series 到 DataFrame

对于一个 Series来说,可以理解成一列是索引,一列是数据。
Series转换为 DataFrame有多种方式,通过字典来中转是比较直观的一种方式。

d = {"语文": 78, "数学": 89, "英语": 95}
s = pd.Series(d)
s.head()

image.png
由前面的介绍可知,红色框内的是 Series的索引(即 s.index),
右边一列数字部分是Series的值(即s.values)。

df = pd.DataFrame({"学科": s.index, "分数": s.values})
df.head()

image.png
这样就转换成了一个 DataFrame,列名就是字典的key学科分数

3.2 DataFrame 到 Series

DataFrameSeries更加简单,DataFrame的每一列都可以转成 Series

l = [[78, 89, 95], [65, 84, 100]]
df = pd.DataFrame(l, index=["小明", "小红"], columns=["语文", "数学", "英语"])
df.head()

df["数学"]

image.png

type(df["数学"])

image.png

注意,DataFrame只有选择一列的时候才是一个 Series,如果选择多列的话,则还是一个 DataFrame

print(type(df[["数学", "语文"]]))
df[["数学", "语文"]]

image.png

4. 总结回顾

本篇主要介绍了pandas的两个核心数据结构 SeriesDataFrame
首先介绍了它们各自的创建方式,即从普通的python数据结构创建 SeriesDataFrame的常用方式。
然后也介绍了它们之间常用的互相转换方法。

SeriesDataFrame数据部分就是一维数组和二维数组,pandas不过是在数据部分之上封装了各种各样的管理和分析统计的函数。
然而正因为有了这些函数,才让pandas成为数据分析的一件利器。

本文关联的微信视频号短视频:
pandas02-核心数据结构.png

原文链接:https://www.cnblogs.com/wang_yb/p/17380249.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:【pandas基础】–核心数据结构 - Python技术站

(0)
上一篇 2023年5月8日
下一篇 2023年5月9日

相关文章

  • 通俗易懂详解Python基础五种下划线作用

    以下是 “通俗易懂详解Python基础五种下划线作用”的完整攻略。 一、Python中的下划线 Python中的下划线有多种用途,包括变量名、函数名、类名等等。在Python中,下划线主要有五种不同的用法,分别是单前导下划线、单末尾下划线、双前导下划线、双前导双下划线和双前导后末尾双下划线。 二、单前导下划线 单前导下划线用来指示一个变量或者方法是“非公有的…

    python 2023年6月5日
    00
  • Springboot中动态语言groovy介绍

    SpringBoot中动态语言Groovy介绍 Groovy是一种基于JVM的动态语言,能与Java无缝配合使用。SpringBoot支持在应用程序中使用Groovy,我们可以使用Groovy进行SpringBoot开发和部署。在本文中,我们将详细讲解SpringBoot中动态语言Groovy的使用方法和技巧。 Groovy安装 首先我们需要安装Groovy…

    python 2023年6月3日
    00
  • python两个list[]相加的实现方法

    以下是详细讲解“Python两个list相加的实现方法”的完整攻略。 在Python中,可以使用”+”运算符或extend()方法将两个list相加。本文将介绍这两种方法的实现方式。 方法一:使用”+”运算符 可以使用”+”运算符将两个list相加。例如: lst1 = [1, 2, 3] lst2 = [4, 5, 6] lst3 = lst1 + lst…

    python 2023年5月13日
    00
  • 如何在Python中更新Oracle数据库中的数据?

    在Python中,我们可以使用cx_Oracle模块连接Oracle数据库,并使用SQL语句执行更新操作。以下是如何在Python中更新Oracle数据库中的数据的完整使用攻略,包括连接数据库、执行更新语句、提交事务等步骤。同时,提供两个示例以便更好理解如何在Python中更新Oracle数据库中的数据。 步骤1:安装cx_Oracle模块 在Python中…

    python 2023年5月12日
    00
  • Python爬虫之Selenium库的使用方法

    Python爬虫之Selenium库的使用方法 Selenium概述 Selenium是一个自动化测试工具,可以模拟人的行为,比如点击,输入等。但是Selenium更常用的是用来做爬虫,尤其是一些需要登录或者需要执行JS代码的网站。 Selenium有多种语言支持,其中Python是最为常用。Python中,爬虫常用的Selenium库有selenium和s…

    python 2023年5月14日
    00
  • bootstrap treeview 树形菜单带复选框及级联选择功能

    Bootstrap Treeview 树形菜单带复选框及级联选择功能 Bootstrap Treeview 是一个基于 Bootstrap 的 jQuery 插件,可以用来创建树形菜单,并且支持复选框及级联选择功能。 下面是具体的使用步骤。 步骤一:引入依赖资源 在 HTML 文件中引入插件的 CSS 和 JavaScript: <link rel=&…

    python 2023年6月13日
    00
  • Python hashlib模块加密过程解析

    Python hashlib模块加密过程解析 hashlib 模块是Python中用于数据加密的模块,支持常见的加密算法和散列函数(哈希函数)。 在本文中,我们将详细讲解如何使用Python中的 hashlib 模块进行数据加密。 加密原理 在加密过程中,我们使用哈希函数将明文转换为定长的哈希值或验证值(也称为摘要、签名或消息摘要),并将其存储在数据库或其他…

    python 2023年6月2日
    00
  • Python descriptor(描述符)的实现

    Python descriptor(描述符)是一种协议,它允许自定义的对象(通常是类)来对属性的访问进行控制。在使用描述符时,我们可以在类中定义__get__()、set()、delete()三个方法,用来控制属性的读取、赋值、删除行为。接下来我将详细讲解Python描述符的实现。 Python描述符的实现 Python描述符的实现主要依赖于三个特殊方法:g…

    python 2023年5月19日
    00
合作推广
合作推广
分享本页
返回顶部