1、层次索引

1.1 定义

在某一个方向拥有多个(两个及两个以上)索引级别,就叫做层次索引。

通过层次化索引,pandas能够以较低维度形式处理高纬度的数据

通过层次化索引,可以按照层次统计数据

层次索引包括Series层次索引和DataFrame层次索引

1.2 Series的层次索引

import numpy as np

import pandas as pd

s1 = pd.Series(data=[99, 80, 76, 80, 99],

index=[['2017', '2017', '2018', '2018', '2018'], ['张伊曼', '张巧玲', '张诗诗', '张思思', '张可可']])

print(s1)

1.3 DataFrame的层次索引

# DataFrame的层次索引

df1 = pd.DataFrame({

'year': [2016, 2016, 2017, 2017, 2018],

'fruit': ['apple', 'banana', 'apple', 'banana', 'apple'],

'production': [10, 30, 20, 70, 100],

'profits': [40, 30, 60, 80,10],

})

print("df1===================================")

print(df1)

df2 = df1.set_index(['year', 'fruit'])

print("df2===================================")

print(df2)

print("df2.index===================================")

print(df2.index)

print("df2.sum(level='year')===================================")

print(df2.sum(level='year'))

print("df2.mean(level='fruit')===================================")

print(df2.mean(level='fruit'))

print("df2.sum(level=['year', 'fruit'])===================================")

print(df2.sum(level=['year', 'fruit']))

2、取值的新方法

ix是比较老的方法 新方式是使用iloc loc

iloc 对下标值进行操作 Series与DataFrame都可以操作

loc 对索引值进行操作 Series与DataFrame都可以操作

2.1 Series

# # 取值的新方法

s1 = pd.Series(data=[99, 80, 76, 80, 99],

index=[['2017', '2017', '2018', '2018', '2018'], ['张伊曼', '张巧玲', '张诗诗', '张思思', '张可可']])

print("s1=================================")

print(s1)

print("s1.iloc[2]=================================")

print(s1.iloc[2])

print("s1.loc['2018']['张思思']=================================")

print(s1.loc['2018']['张思思'])

2.2 DataFrame

df1 = pd.DataFrame({

'year': [2016, 2016, 2017, 2017, 2018],

'fruit': ['apple', 'banana', 'apple', 'banana', 'apple'],

'production': [10, 30, 20, 70, 100],

'profits': [40, 30, 60, 80,10],

})

print("df1===================================")

print(df1)

print("旧方法获取值===================================")

print("df1['year'][0]===================================")

print(df1['year'][0])

print("df1.ix[0]['year']===================================")

print(df1.ix[0]['year'])

print("新方法获取值===================================")

print("df1.iloc[0][3]===================================")

print(df1.iloc[0][3])

print("df1.loc[0]['year']===================================")

print(df1.loc[0]['year'])

以上这篇对pandas的层次索引与取值的新方法详解就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

python索引取值_对pandas的层次索引与取值的新方法详解相关推荐

  1. python反向缩进_在Pycharm中对代码进行注释和缩进的方法详解

    在Pycharm中对代码进行注释和缩进的方法详解 一.注释 1. #单行注释 2. """ 多行注释 """ 3. pycharm多行注释快 ...

  2. python可以使用二维元组吗_python中读入二维csv格式的表格方法详解(以元组/列表形式表示)...

    怎么去读取一个没有表头的二维csv文件(如下图所示)? 并以元组的形式表现数据: ((1.0, 0.0, 3.0, 180.0), (2.0, 0.0, 2.0, 180.0), (3.0, 0.0, ...

  3. python更新数据库表的时间字段_python更新数据库中某个字段的数据(方法详解)

    连接数据库基本操作,我把每一步的操作是为什么给大家注释一下,老手自行快进. 请注意这是连接数据库操作,还不是更新. import pymysql #导包 #连接数据库 db = pymysql.con ...

  4. python2和python3分别是python的两个版本_Windows下Python2与Python3两个版本共存的方法详解...

    前言 一向用Python 3,最近研究微信公众号开发,各云平台只支持Python 2.7,想用其他版本需要自己搭建环境.而网上又搜不到Python 3开发微信公众号的资料.暂打算先使用Python 2 ...

  5. python接口自动化测试书籍_蜗牛出版之《接口自动化测试开发实战教程》书籍详解!...

    各位老铁,大家好~ 上周,我们通过一篇分享,给大家详细介绍了蜗牛创想的出版业务. 还不了解的小伙伴请戳:除了培训和研发,我们还有一项90%的人都未曾关注到的业务! 本周开始,我们将对已经出版的< ...

  6. python读二进制格点雷达基数据_对numpy中二进制格式的数据存储与读取方法详解...

    使用save可以实现对numpy数据的磁盘存储,存储的方式是二进制.查看使用说明,说明专门提到了是未经压缩的二进制形式.存储后的数据可以进行加载或者读取,通过使用load方法. In [81]:np. ...

  7. python中如何创建一个空列表_Python创建空列表的字典2种方法详解

    如果要在 Python 中创建键值是空列表的字典,有多种方法,但是各种方法之间是否由区别?需要作实验验证,并且分析产生的原因.本文针对两种方法做了实验和分析. 如果要在 Python 中创建一个键值都 ...

  8. Pandas 导出excel表取消表头与行号方法详解

    使用pandas中DataFrame格式数据导出excel的时候遇到了一个麻烦,数据自动生成了表头和行号,很多余,如下图: 下面是通过参数控制避免这种情况的代码,就两个参数: df2.to_excel ...

  9. 量化延时法时间测量_干货分享:直线度测量发展及几种方法详解

    摘要:直线度是很多轧材需要检测的一项重要尺寸,直线度的测量已经从人工测量方式发展为直线度测量仪自动测量. 关键词:直线度:测量方式: 主要是测量圆柱体和圆锥体的素线直线度误差.机床和其他机器的导轨面以 ...

最新文章

  1. c语言中比较两个数组函数,输入两个数组,调用large函数比较,计数,输出统计结果...
  2. GIA张怡:关于小白入门AI算法工程师的直播分享
  3. python如何解决高并发_Flask 处理高并发、多线程
  4. matplotlib错误:from matplotlib import afm, cbook, ft2font, rcParams, get_cachedirImportError: DLL load
  5. Matlab中的continue、break和return语句
  6. idea 批量导入包
  7. 神经网络入门概念和框架理解(YOLOv1v2v3改进分析)
  8. eclipse要修改的配置
  9. 怎么样采集声音的波形和频率_示波器采集模式
  10. LCA的 Trajan 算法
  11. loj10099 点双连通分量
  12. 微信公众号基础04_分享和录音功能的实现
  13. 那些年我们一起遇到的bug
  14. 苹果百度手机消息推送服务器,苹果消息推送服务教程
  15. WLST 命令和变量
  16. 5473. 【NOIP2017提高组正式赛】小凯的疑惑
  17. 深度学习——损失函数(Regression Loss、Classification Loss)
  18. 五使用计算机上数学课英文,数学课用英语怎么说
  19. 【python量化】国内外基于python开发的量化回测框架
  20. Ubuntu实用工具/软件汇总

热门文章

  1. HBase是个啥子?
  2. 东欧黑客入侵港股造市图利 半年涉款5300万
  3. CSU 1803:2016解题报告
  4. log4j2内容详解
  5. 我今天才知道,原来蒙古包是没有地址的?!
  6. 提高图片的清晰度和加载速度
  7. Android Froyo基于32 bit ubuntu 10.10编译问题
  8. Houdini `@pdg_output`找不到文件
  9. 从哪里租vps远程桌面服务器,租vps远程桌面服务器
  10. 三丰云永久免费云服务器