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

本文介绍了如何在Pandas的DataFrame中选取特定行和列,包括使用`iloc`、`loc`、点属性、列名以及索引等方式。例如,`data['w']`用于选取'w'列,`data[0:2]`选取第1行到第2行(不包括第2行),而`data.irow(0)`则用于获取第一行数据。
摘要由CSDN通过智能技术生成

如下所示:

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:Anaconda2libsite-packagesspyderutilsipythonstart_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]:

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值