设为首页收藏本站
天天打卡

 找回密码
 立即注册
搜索
查看: 70|回复: 17

Python读取DataFrame的某行或某列的方法实现

[复制链接]

1

主题

64

回帖

149

积分

注册会员

积分
149
发表于 2024-4-20 09:44:32 | 显示全部楼层 |阅读模式
目录


行索引、列索引、loc和iloc
  1. import pandas as pd
  2. import numpy as np
  3. # 准备数据
  4. df = pd.DataFrame(np.arange(12).reshape(3,4),index=list("abc"),columns=list("WXYZ"))
复制代码


  • 行索引(index):对应最左边那一竖列
  • 列索引(columns):对应最上面那一横行
  • .loc[]官方释义: Access a group of rows and columns by label(s) or a boolean array.(通过标签或布尔数组访问一组行和列) 官方链接

    • loc使用索引来取值,基础用法 df.loc[[行索引],[列索引]]

  • .iloc[]官方释义: Purely integer-location based indexing for selection by position.(按位置进行索引选择) 官方链接

    • iloc使用位置(从0开始)来取值,基础用法 df.iloc[[行位置],[列位置]]


一、根据列索引取某一列/多列(常用)
  1. df['W']   # 取‘W'列,返回类型是Series
  2. df[['W']] # 取‘W'列,返回类型是DataFrame
  3. df[['W','Y']] # 取‘W'列和‘Y'列
  4. df.loc[:,'W':'Y'] # 取‘W'列到‘Y'列
复制代码
二、根据行索引取某一行/多行
  1. df.loc['a']   # 取‘a'行,返回类型是Series
  2. df.loc[['a']]   # 取‘a'行,返回类型是DataFrame
  3. df.loc[['a','c']]   # 取‘a'行和‘c'行,也可以写成 df.loc[['a','c'],:]
  4. df.loc['a':'c',:]   # 取‘a'行到‘c'行
复制代码
三、根据列位置取某一列/多列
  1. df.iloc[:,1]    # 取第2列(‘X'列),列号为1,返回类型是Series
  2. df.iloc[:,0:2]  # 取前2列(‘W'列和‘X'列),列号为0和1
  3. df.iloc[:,0:-1] # 取最后一列之前的所有列
复制代码
四、根据行位置取某一行/多行(常用)
  1. df[:2]  #取前2行,行号为0和1
  2. df[1:2] #取第2行,行号为1
  3. df.iloc[1] # 取第2行(‘b'行),行号为1,返回类型是Series,也可以写成df.iloc[1,:]
复制代码
五、取某一行某一列(常用)
  1. df.loc[['b'],['W']] # 取‘b'行‘W'列,返回类型是DataFrame,带着行、列索引的
  2. df.loc['b','W']     # 取‘b'行‘W'列的值,返回类型是int,不带行列索引
  3. df.loc['b']['W']    # 取‘b'行‘W'列的值(从Series类型df.loc['b']中通过索引取值)

  4. df.iloc[[0],[0]]    # 取第1行、第1列,返回类型是DataFrame,带着行、列索引的
  5. df.iloc[0,0]        # 取第1行、第1列的值
  6. df.iloc[0][0]       # 取第1行、第1列的值(从Series类型df.iloc[0]中通过序号取值)
  7. df.iloc[0]['W']     # 取第1行、‘W'列的值(从Series类型df.iloc[0]中通过索引取值)
复制代码
六、取多行多列
  1. df[:2][['W','Y']]      # 取前2行的‘W'列和'Y‘列
  2. df[:2].loc[:2,'W':'Y']  # 取前2行的‘W'列到'Y‘列

  3. df.iloc[0][['W','Y']]  # 取第1行的‘W'列和'Y‘列
  4. df.iloc[0]['W':'Y']    # 取第1行的‘W'列到'Y‘列

  5. df.loc[["a","c"],["W","Y"]] # 取‘a'行和‘c'行,‘W'列和‘Y'列
  6. df.iloc[[0,2],[1,3]]        # 取1、3行,2、4列
复制代码
总结: 一般通过行位置来取行,通过列索引来取列,且行索引大多数情况下和行位置是相同的。
最常用的是以下几个
  1. # 取某一列
  2. df['W']
  3. # 取某一行
  4. df.iloc[0]
  5. # 取多列
  6. df.loc[:,'W':'Y'] # 取‘W'列到‘Y'列
  7. df.iloc[:,0:-1]   # 取最后一列之前的所有列
  8. # 取对应行列的值
  9. df.iloc[0]['W']
  10. df.loc['a','W']  # 在行索引和行位置相同的情况下的写法就是,df.loc[0,'W']
复制代码
到此这篇关于Python读取DataFrame的某行或某列的方法实现的文章就介绍到这了,更多相关Python读取DataFrame行列内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

×

3

主题

64

回帖

196

积分

注册会员

积分
196
发表于 2024-4-24 01:16:32 | 显示全部楼层
我想了解更多
  • 打卡等级:无名新人
  • 打卡总天数:1
  • 打卡月天数:0
  • 打卡总奖励:12
  • 最近打卡:2024-05-27 11:13:31

2

主题

49

回帖

155

积分

注册会员

积分
155
发表于 2024-7-3 16:16:33 | 显示全部楼层
顶一个,观点非常中肯!

0

主题

69

回帖

139

积分

注册会员

积分
139
发表于 2024-7-21 10:29:23 | 显示全部楼层
这个话题很有趣,我想多了解一些

1

主题

71

回帖

165

积分

注册会员

积分
165
发表于 2024-7-21 11:12:42 | 显示全部楼层
说得太好了,完全同意!

0

主题

56

回帖

112

积分

注册会员

积分
112
发表于 2024-8-2 19:13:30 | 显示全部楼层
非常感谢你的观点,让我受益良多!

1

主题

58

回帖

137

积分

注册会员

积分
137
发表于 2024-8-28 02:41:39 | 显示全部楼层
顶一个,观点非常中肯!

1

主题

57

回帖

136

积分

注册会员

积分
136
发表于 2024-8-29 03:41:16 | 显示全部楼层
这个话题很有趣,我想多了解一些

1

主题

55

回帖

132

积分

注册会员

积分
132
发表于 2024-9-9 00:00:27 | 显示全部楼层
太棒了!感谢分享这个信息!

5

主题

70

回帖

252

积分

中级会员

积分
252
发表于 2024-9-18 20:35:40 | 显示全部楼层
确实牛逼
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|爱云论坛 - d.taiji888.cn - 技术学习 免费资源分享 ( 蜀ICP备2022010826号 )|天天打卡

GMT+8, 2024-11-28 03:17 , Processed in 0.108306 second(s), 27 queries .

Powered by i云网络 Licensed

© 2023-2028 正版授权

快速回复 返回顶部 返回列表