03 -3 pandas 层次化索引(隐式构造,显示构造)、多层列索引、多层索引对象的索引与切片操作(Series的操作,DataFrame的操作)

本文深入探讨了Pandas的层次化索引,包括隐式和显示构造多层行索引,详细讲解了多层列索引的创建,并通过实例展示了多层索引对象在Series和DataFrame中的索引与切片操作。强调了.loc()方法的重要性,并给出了相关练习以巩固理解。
摘要由CSDN通过智能技术生成

pandas层次化索引

多级索引包括: 多级行索引 和 多级列索引

1. 创建多层行索引

1) 隐式构造

最常见的方法是给DataFrame构造函数的index参数传递两个或更多的数组

  • Series也可以创建多层索引
import numpy as np
import pandas as pd
from pandas import Series,DataFrame
index = [np.array(["期中","期中","期末","期末"]),np.array(["语文","英语","语文","英语"])]
Series(np.random.randn(4),index=index)
结果为:
期中  语文    1.040276
    英语    0.456647
期末  语文    0.583853
    英语    0.348378
dtype: float64

2) 显示构造pd.MultiIndex

  • 使用数组
index = pd.MultiIndex.from_arrays([["期中","期中","期中","期末","期末","期末"],["语文","英语","数学","语文","英语","数学"]])
columns = ["张三","李四","王五","赵柳"]
data = np.random.randint(0,150,size=(6,4))
DataFrame(data,index,columns)
张三 李四 王五 赵柳
期中 语文 12 146 61 121
英语 120 119 100 68
数学 73 80 40 102
期末 语文 90 143 51 85
英语 6 35 62 90
数学 32 60 114 149
  • 使用tuple
index = pd.MultiIndex.from_tuples([("期中","语文"),("期中","数学"),("期中","英语"),("期末","语文"),("期末","数学"),("期末","英语")])
columns = ["张三","李四","王五","赵柳"]
data = np.random.randint(0,150,size=(6,4))
DataFrame(data,index,columns)
张三 李四 王五 赵柳
期中 语文 0 40 95 1
数学 112 137<
  • 0
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值