loc——通过行标签索引行数据
# iloc——通过行号索引行数据
# ix——通过行标签或者行号索引行数据(基于loc和iloc 和at 和iat 的混合)
# 同理,索引列数据也是如此!
# : 在切片操作相当于数组,前后没有值时取全部,前后为数字序号时,不包括末端,前后为名称时则包括末端
# 特殊情况 df[1:] 相当于第一行到最后一行, df[1:-1] 第一行到倒数第二行
# at等价于loc, iat等价于iloc,但是只能取到一个数据, 单数速度更快
# 直接通过df获取数据,和ix的区别,默认序号取行, 默认字符串其他取列, 正常获取格式 df[行][列],(注意列的格式不能使用 :格式, 另外不能使用 df[行,列] 格式获取) data=[[1,2,3],[4,5,6]]
index=['A','B']#行号
columns=['a','b','c']#列号
df=pd.DataFrame(data,index=index,columns=columns)#生成一个数据框 #---------------------------------------获取单行数据-----------------------------------------------------------
# 只能用索引名,如果未指定索引,则是自带(0--N)
print df.loc['A'] # 只能用索序号, 取第一行
print df.iloc[0] # 使用ix测试,取第一行
print df.ix['A']
print df.ix[0] #---------------------------------------获取单行数据----------------------------------------------------------- #---------------------------------------获取列数据-----------------------------------------------------------
# 全部行,列名为'a'的数据 , 等价于 df.loc[:][ 'a'] 和 df['a']
# 使用loc
print df.loc[:, 'a']
print df.loc[:][ 'a']
print df['a']
# 使用iloc
print df.iloc[:, 0]
# 使用ix
print df.ix[:, 0]
print df.ix[:, 'a'] #---------------------------------------获取列数据----------------------------------------------------------- #---------------------------------------获取多行数据-----------------------------------------------------------
# 使用名称时末端包含
print df.loc['A':'B']
# 使用默认索引时,末端不包含,所以需要使用0: 2
print df.iloc[0:2]
print df.ix['A':'B']
print df.ix[0:2]
#---------------------------------------获取多行数据----------------------------------------------------------- #---------------------------------------获取多列数据-----------------------------------------------------------
# 等价于 df.loc[:, ['a','b']]
# 取全部行,'a', 'b'列
print df.loc[:, 'a':'b']
print df.iloc[:, 0:2]
print df.ix[:, 'a':'b']
print df.ix[:, 0:2]
#---------------------------------------获取多列数据----------------------------------------------------------- #---------------------------------------获取多行多列数据-----------------------------------------------------------
#取第一行 'a','b'列
print df.loc['A','a':'b']
print df.iloc[0, 0:2]
print df.ix['A','a':'b']
print df.ix[0, 0:2]
#---------------------------------------获取多行多列数据----------------------------------------------------------- #---------------------------------------直接用df获取数据-----------------------------------------------------------
# 取全部行
# 取全部行,全部列
print df[:]
# 取第一行,全部列
print df[0:1]
# 取第二行到最后一行
print df[1:]
# 取第1行到倒数第二行, 不包括最后一行
print df[0:-1]
# 取倒数第二行
print df[-2:-1]
# 获取前2行
print df[0:2] # 获取'a','b'列, 在df直接取的情况下,不能使用'a':'b', 使用['a', 'b']代替,而且不能和行出现在同一个数组中
print df[['a','b']]
# 第一行,'a','b'列, 在df直接取的情况下,不能使用'a':'b', 使用['a', 'b']代替,而且不能和行出现在同一个数组中,而且必须出现在列后,df[0:1, [['a','b']]]这种写法非法
# 等价于 df.ix[0:1, 'a':'b']
print df[0:1][['a','b']]
print df.ix[0:1, 'a':'b']
print df.ix[0:1, ['a','b']]
print df.ix[0:1][['a','b']] #操作列
#获取列最后一行
print df['a'][-1]
#获取列最后两行
print df['a'][-2:] #---------------------------------------直接用df获取数据----------------------------------------------------------- #---------------------------------------直接用at获取数据-----------------------------------------------------------
print df.at['A', 'a']
#---------------------------------------直接用at获取数据----------------------------------------------------------- #---------------------------------------直接用iat获取数据-----------------------------------------------------------
print df.iat[0, 0]
#---------------------------------------直接用iat获取数据-----------------------------------------------------------

  

dataFrame 切片操作的更多相关文章

  1. Python array,list,dataframe索引切片操作 2016年07月19日——智浪文档

    array,list,dataframe索引切片操作 2016年07月19日——智浪文档 list,一维,二维array,datafrme,loc.iloc.ix的简单探讨 Numpy数组的索引和切片 ...

  2. pandas 对数据帧DataFrame中数据的索引及切片操作

    1.创建数据帧 index是行索引,即每一行的名字:columns是列索引,即每一列的名字.建立数据帧时行索引和列索引都需要以列表的形式传入. import pandas as pd df = pd. ...

  3. python切片操作

    序列类型是其元素被顺序放置的一种数据结构类型,这种方式允许通过下标的方式来获得某一个数据元素,或者通过指定下标范围来获得一组序列的元素.这种访问序列的方式叫做切片.字符串也可以使用切片操作.切片操作符 ...

  4. Python序列的切片操作与技巧

    切片操作 对于具有序列结构的数据来说,切片操作的方法是:consequence[start_index: end_index: step]. start_index: 表示是第一个元素对象,正索引位置 ...

  5. 关于javascript里面仿python切片操作数组的使用方法

    其实在使用了好一段时间的 python之后,我觉得最让我念念不忘的并不是python每次在写函数或者循环的时候可以少用{}括号这样的东西(ps:其实也是了..感觉很清爽,而且又开始写js的时候老是想用 ...

  6. python学习之“切片操作从入门到精通”

    在python学习开发的过程中,我们总是不断的要对List(列表),Tuple(元组)有取值操作:假如我们有一个列表List1现在想取出1其中的前5个元素,改怎么操作呢? >>> L ...

  7. Numpy入门 - 数组切片操作

    本节主要演示数组的切片操作,数组的切片操作有两种形式:更改原数组的切片操作和不更改原数组的切片操作. 一.更改原数组的切片操作 import numpy as np arr = np.array([1 ...

  8. 【Python实践-4】切片操作去除字符串首尾的空格

    #利用切片操作,实现一个trim()函数,去除字符串首尾的空格,注意不要调用str的strip()方法 def trim(s): while s[0:1]==' ': s=s[1:] while s[ ...

  9. python迭代-如何对迭代器做切片操作

    如何对迭代器做切片操作 问题举例 读取某个文件内容的100~300行内容,我们是否可以使用 类似列表切片的方式得到一个100~300行文件内容的生成器 分析 列表的切片操作其实是在重载方法__getI ...

随机推荐

  1. String对象的match方法

    RegExp对象的exec方法和String对象的match方法用法十分相似,分两篇博客讲讲其各自的用法和它们之间的异同.上一篇将exec方法的用法,这篇讲解match方法,并比较其异同. 定义与语法 ...

  2. 【转载】shell实例手册

    原文地址:shell实例手册  作者:没头脑的土豆 shell实例手册 0说明{ 手册制作: 雪松 更新日期: -- 欢迎系统运维加入Q群: 请使用"notepad++"打开此文档 ...

  3. SSM 框架-06-详细整合教程(IDEA版)(Spring+SpringMVC+MyBatis)

    SSM 框架-06-详细整合教程(IDEA版)(Spring+SpringMVC+MyBatis) SSM(Spring.Spring MVC和Mybatis)如果你使用的是 Eclipse,请查看: ...

  4. Python爬虫教程-11-proxy代理IP,隐藏地址(猫眼电影)

    Python爬虫教程-11-proxy代理IP,隐藏地址(猫眼电影) ProxyHandler处理(代理服务器),使用代理IP,是爬虫的常用手段,通常使用UserAgent 伪装浏览器爬取仍然可能被网 ...

  5. maven(15),快照与发布,RELEASE与SNAPSHOT

     发布RELEASE 用户A将代码打包发布到RELEASE仓库,具体操作参考上篇文章.用户B使用时,需要在pom.xml添加JAR包的依赖坐标.如果用户A将版本从1.0升级为2.0,用户B使用时也 ...

  6. 如何在 Azure 中的经典 Windows 虚拟机上设置终结点

    在 Azure 中使用经典部署模型创建的所有 Windows 虚拟机都可以通过专用网络通道与同一云服务或虚拟网络中的其他虚拟机自动通信. 但是,Internet 或其他虚拟网络中的计算机需要终结点将入 ...

  7. 平台支持的从经典部署模型到 Azure Resource Manager 的 IaaS 资源迁移

    本文介绍如何才能将基础结构即服务 (IaaS) 资源从经典部署模型迁移到 Resource Manager 部署模型. 用户可以阅读有关 Azure Resource Manager 功能和优点的更多 ...

  8. centos 卸载python和yum之后的解决办法

    网上看到有同学yum不能使用的消息,出现了下面的结果 无赖的使用了网上的很多方法,还是不行. 于是我卸载了python和yum,觉得自己重新安装python和yum. 步骤1:卸载python rpm ...

  9. 集合、深浅copy

    集合set: 集合也和列表数组一样有增加,但是集合是真正的没有顺序的  所以集合无法查找的,并且集合的外观你看着好像是字典和列表的组合,因为它是用字典的括号一样 ,但是又是里面并没有键值对  只是一个 ...

  10. Linux traceroute命令详解

    traceroute我们可以知道信息从你的计算机到互联网另一端的主机是走的什么路径.当然每次数据包由某一同样的出发点(source)到达某一同样的目的地(destination)走的路径可能会不一样, ...