qq_38411575 2021-04-08 14:12 采纳率: 77.8%
浏览 1905
已结题

如何在Dataframe中,根据某列的值取另外一列的某个值的标量?

我现在用的是最原始的方法,代码如下:

import pandas as pd
import numpy as np

df = pd.DataFrame()
df[['A', 'B']] = pd.DataFrame(np.arange(10).reshape((5, 2)))
df = df.loc[df['A'] == 4, 'B'].values[0]
print(df)

结果

5

请问,这行能再简化么?

df = df.loc[df['A'] == 4, 'B'].values[0]

大牛回答的:

方法1:如果一直能匹配使用Series.to_numpy()代替Series.values

https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.Series.to_numpy.html

df = df.loc[df['A'] == 4, 'B'].to_numpy()[0]

方法2:如果可能不匹配,使用next和iter1,因为使用.loc可能出错

a = next(iter(df.loc[df['A'] == 4, 'B']), 'no match')
print (a)
5

a = next(iter(df.loc[df['A'] == 1000, 'B']), 'no match')
print (a)
no match

方法3:

df1=df.loc[df['A'] == 4, 'B'].item()
  • 写回答

3条回答 默认 最新

  • 关注

    这种不知道算不算简单了

    import pandas as pd
    import numpy as np
     
    df = pd.DataFrame()
    df[['A', 'B']] = pd.DataFrame(np.arange(10).reshape((5, 2)))
    
    # 变成字典,以A为keys
    df.set_index('A').T.to_dict('list')[4][0]
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 8月19日

悬赏问题

  • ¥15 安卓adb backup备份应用数据失败
  • ¥15 eclipse运行项目时遇到的问题
  • ¥15 关于#c##的问题:最近需要用CAT工具Trados进行一些开发
  • ¥15 南大pa1 小游戏没有界面,并且报了如下错误,尝试过换显卡驱动,但是好像不行
  • ¥15 没有证书,nginx怎么反向代理到只能接受https的公网网站
  • ¥50 成都蓉城足球俱乐部小程序抢票
  • ¥15 yolov7训练自己的数据集
  • ¥15 esp8266与51单片机连接问题(标签-单片机|关键词-串口)(相关搜索:51单片机|单片机|测试代码)
  • ¥15 电力市场出清matlab yalmip kkt 双层优化问题
  • ¥30 ros小车路径规划实现不了,如何解决?(操作系统-ubuntu)