用pandas中的DataFrame时选取行或列的方法


Posted in Python onJuly 11, 2018

如下所示:

import numpy as np
import pandas as pd
from pandas import Sereis, DataFrame
ser = Series(np.arange(3.))
data = DataFrame(np.arange(16).reshape(4,4),index=list('abcd'),columns=list('wxyz'))
data['w'] #选择表格中的'w'列,使用类字典属性,返回的是Series类型
data.w  #选择表格中的'w'列,使用点属性,返回的是Series类型
data[['w']] #选择表格中的'w'列,返回的是DataFrame属性
data[['w','z']] #选择表格中的'w'、'z'列
data[0:2] #返回第1行到第2行的所有行,前闭后开,包括前不包括后
data[1:2] #返回第2行,从0计,返回的是单行,通过有前后值的索引形式,
    #如果采用data[1]则报错
data.ix[1:2] #返回第2行的第三种方法,返回的是DataFrame,跟data[1:2]同
data['a':'b'] #利用index值进行切片,返回的是**前闭后闭**的DataFrame, 
    #即末端是包含的 
data.irow(0)  #取data的第一行
data.icol(0)  #取data的第一列
data.head() #返回data的前几行数据,默认为前五行,需要前十行则dta.head(10)
data.tail() #返回data的后几行数据,默认为后五行,需要后十行则data.tail(10)
ser.iget_value(0) #选取ser序列中的第一个
ser.iget_value(-1) #选取ser序列中的最后一个,这种轴索引包含索引器的series不能采用ser[-1]去获取最后一个,这回引起歧义。
data.iloc[-1]  #选取DataFrame最后一行,返回的是Series
data.iloc[-1:]  #选取DataFrame最后一行,返回的是DataFrame
data.loc['a',['w','x']]  #返回‘a'行'w'、'x'列,这种用于选取行索引列索引已知
data.iat[1,1]  #选取第二行第二列,用于已知行、列位置的选取。

例子:

import pandas as pd
from pandas import Series, DataFrame
import numpy as np
data = DataFrame(np.arange(15).reshape(3,5),index=['one','two','three'],columns=['a','b','c','d','e'])
data
Out[7]: 
    a  b  c  d  e
one   0  1  2  3  4
two   5  6  7  8  9
three 10 11 12 13 14
#对列的操作方法有如下几种
data.icol(0)  #选取第一列
E:\Anaconda2\lib\site-packages\spyder\utils\ipython\start_kernel.py:1: FutureWarning: icol(i) is deprecated. Please use .iloc[:,i]
 # -*- coding: utf-8 -*-
Out[35]: 
one    0
two    5
three  10
Name: a, dtype: int32
data['a']
Out[8]: 
one    0
two    5
three  10
Name: a, dtype: int32
data.a
Out[9]: 
one    0
two    5
three  10
Name: a, dtype: int32
data[['a']]
Out[10]: 
    a
one   0
two   5
three 10
data.ix[:,[0,1,2]] #不知道列名只知道列的位置时
Out[13]: 
    a  b  c
one   0  1  2
two   5  6  7
three 10 11 12
data.ix[1,[0]] #选择第2行第1列的值
Out[14]: 
a  5
Name: two, dtype: int32
data.ix[[1,2],[0]]  #选择第2,3行第1列的值
Out[15]: 
    a
two   5
three 10
data.ix[1:3,[0,2]] #选择第2-4行第1、3列的值
Out[17]: 
    a  c
two   5  7
three 10 12
data.ix[1:2,2:4] #选择第2-3行,3-5(不包括5)列的值
Out[29]: 
   c d
two 7 8
data.ix[data.a>5,3]
Out[30]: 
three  13
Name: d, dtype: int32
data.ix[data.b>6,3:4] #选择'b'列中大于6所在的行中的第4列,有点拗口
Out[31]: 
    d
three 13
data.ix[data.a>5,2:4] #选择'a'列中大于5所在的行中的第3-5(不包括5)列
Out[32]: 
    c  d
three 12 13
data.ix[data.a>5,[2,2,2]] #选择'a'列中大于5所在的行中的第2列并重复3次
Out[33]: 
    c  c  c
three 12 12 12
#还可以行数或列数跟行名列名混着用
data.ix[1:3,['a','e']]
Out[24]: 
    a  e
two   5  9
three 10 14
data.ix['one':'two',[2,1]]
Out[25]: 
   c b
one 2 1
two 7 6
data.ix[['one','three'],[2,2]]
Out[26]: 
    c  c
one   2  2
three 12 12
data.ix['one':'three',['a','c']]
Out[27]: 
    a  c
one   0  2
two   5  7
three 10 12
data.ix[['one','one'],['a','e','d','d','d']]
Out[28]: 
   a e d d d
one 0 4 3 3 3
one 0 4 3 3 3
#对行的操作有如下几种:
data[1:2] #(不知道列索引时)选择第2行,不能用data[1],可以用data.ix[1]
Out[18]: 
   a b c d e
two 5 6 7 8 9
data.irow(1)  #选取第二行
E:\Anaconda2\lib\site-packages\spyder\utils\ipython\start_kernel.py:1: FutureWarning: irow(i) is deprecated. Please use .iloc[i]
 # -*- coding: utf-8 -*-
Out[36]: 
a  5
b  6
c  7
d  8
e  9
Name: two, dtype: int32
data.ix[1]  #选择第2行
Out[20]: 
a  5
b  6
c  7
d  8
e  9
Name: two, dtype: int32

data['one':'two'] #当用已知的行索引时为前闭后闭区间,这点与切片稍有不同。
Out[22]: 
   a b c d e
one 0 1 2 3 4
two 5 6 7 8 9
data.ix[1:3] #选择第2到4行,不包括第4行,即前闭后开区间。
Out[23]: 
    a  b  c  d  e
two   5  6  7  8  9
three 10 11 12 13 14
data.ix[-1:] #取DataFrame中最后一行,返回的是DataFrame类型,**注意**这种取法是有使用条件的,只有当行索引不是数字索引时才可以使用,否则可以选用`data[-1:]`--返回DataFrame类型或`data.irow(-1)`--返回Series类型
Out[11]: 
    a  b  c  d  e
three 10 11 12 13 14
data[-1:] #跟上面一样,取DataFrame中最后一行,返回的是DataFrame类型
Out[12]: 
    a  b  c  d  e
three 10 11 12 13 14
data.ix[-1] #取DataFrame中最后一行,返回的是Series类型,这个一样,行索引不能是数字时才可以使用
Out[13]: 
a  10
b  11
c  12
d  13
e  14
Name: three, dtype: int32
data.tail(1)  #返回DataFrame中的最后一行
data.head(1)  #返回DataFrame中的第一行

最近处理数据时发现当pd.read_csv()数据时有时候会有读取到未命名的列,且该列也用不到,一般是索引列被换掉后导致的,有强迫症的看着难受,这时候dataframe.drop([columns,])是没法处理的,怎么办呢,

最笨的方法是直接给列索引重命名:

data6
    Unnamed: 0 high  symbol time
date        
2016-11-01 0  3317.4 IF1611 18:10:44.8
2016-11-01 1  3317.4 IF1611 06:01:04.5
2016-11-01 2  3317.4 IF1611 07:46:25.5
2016-11-01 3  3318.4 IF1611 09:30:04.0
2016-11-01 4  3321.8 IF1611 09:31:04.0

data6.columns = list('abcd')
data6
  a  b  c  d
date        
2016-11-01 0  3317.4 IF1611 18:10:44.8
2016-11-01 1  3317.4 IF1611 06:01:04.5
2016-11-01 2  3317.4 IF1611 07:46:25.5
2016-11-01 3  3318.4 IF1611 09:30:04.0
2016-11-01 4  3321.8 IF1611 09:31:04.0

以上这篇用pandas中的DataFrame时选取行或列的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Python 相关文章推荐
基于Python对象引用、可变性和垃圾回收详解
Aug 21 Python
浅谈python 线程池threadpool之实现
Nov 17 Python
python 通过xml获取测试节点和属性的实例
Mar 31 Python
如何实现删除numpy.array中的行或列
May 08 Python
将pip源更换到国内镜像的详细步骤
Apr 07 Python
python写日志文件操作类与应用示例
Jul 01 Python
详解Python绘图Turtle库
Oct 12 Python
在flask中使用python-dotenv+flask-cli自定义命令(推荐)
Jan 05 Python
python自动点赞功能的实现思路
Feb 26 Python
利用python绘制数据曲线图的实现
Apr 09 Python
Python实现加密的RAR文件解压的方法(密码已知)
Sep 11 Python
python计算列表元素与乘积详情
Aug 05 Python
Python2实现的图片文本识别功能详解
Jul 11 #Python
利用Python进行数据可视化常见的9种方法!超实用!
Jul 11 #Python
基于数据归一化以及Python实现方式
Jul 11 #Python
numpy.std() 计算矩阵标准差的方法
Jul 11 #Python
使用sklearn进行对数据标准化、归一化以及将数据还原的方法
Jul 11 #Python
使用sklearn之LabelEncoder将Label标准化的方法
Jul 11 #Python
Python实现识别图片内容的方法分析
Jul 11 #Python
You might like
PHP 单引号与双引号的区别
2009/11/24 PHP
thinkPHP中_initialize方法实例分析
2016/12/05 PHP
javascript 模拟JQuery的Ready方法实现并出现的问题
2009/12/06 Javascript
Javascript 获取链接(url)参数的方法[正则与截取字符串]
2010/02/09 Javascript
一个js的tab切换效果代码[代码分离]
2010/04/11 Javascript
jquery实现心算练习代码
2010/12/06 Javascript
AngularJS打开页面隐藏显示表达式用法示例
2016/12/25 Javascript
jquery获取select,option所有的value和text的实例
2017/03/06 Javascript
图解Javascript——作用域、作用域链、闭包
2017/03/21 Javascript
JS字符串统计操作示例【遍历,截取,输出,计算】
2017/03/27 Javascript
JS 验证密码 不能为空,必须含有数字、字母、特殊字符,长度在8-12位
2017/06/21 Javascript
基于node.js express mvc轻量级框架实践
2017/09/14 Javascript
vue2手机APP项目添加开屏广告或者闪屏广告
2017/11/28 Javascript
深入浅析Vue.js中 computed和methods不同机制
2018/03/22 Javascript
webpack+vue-cil中proxyTable处理跨域的方法
2018/07/20 Javascript
Layui Form 自定义验证的实例代码
2019/09/14 Javascript
基于JavaScript实现简单抽奖功能代码实例
2020/10/20 Javascript
Nodejs 微信小程序消息推送的实现
2021/01/20 NodeJs
在Django框架中伪造捕捉到的URLconf值的方法
2015/07/18 Python
Python双精度浮点数运算并分行显示操作示例
2017/07/21 Python
Python基于多线程操作数据库相关问题分析
2018/07/11 Python
python斐波那契数列的计算方法
2018/09/27 Python
Tensorflow的梯度异步更新示例
2020/01/23 Python
Python object类中的特殊方法代码讲解
2020/03/06 Python
Python爬虫代理池搭建的方法步骤
2020/09/28 Python
python+openCV对视频进行截取的实现
2020/11/27 Python
使用Django的JsonResponse返回数据的实现
2021/01/15 Python
Pycharm 解决自动格式化冲突的设置操作
2021/01/15 Python
python编写扎金花小程序的实例代码
2021/02/23 Python
英国手机壳购买网站:Case Hut
2019/04/11 全球购物
员工评语大全
2014/01/19 职场文书
党员干部批评与自我批评反四风思想汇报
2014/09/21 职场文书
2014民事授权委托书范本
2014/09/29 职场文书
2014年党风廉政建设工作总结
2014/11/19 职场文书
同学聚会通知书
2015/04/20 职场文书
2015年基层党支部工作总结
2015/05/21 职场文书