weixin_45187722 2022-02-11 23:51 采纳率: 100%
浏览 123
已结题

提问!python中list里的元素是dateframe,如何选取每个dataframe中的某个特定列呢?

ad_data 是个列表,其中每个元素都是一个dataframe,想要将每个df的第24列取倒数,但是不会切片。
错误代码如下:
for i in range(0,5):

ad_data[i][:,24]= 1/ad_data[i][:,24]

报错:'(slice(None, None, None), 24)' is an invalid key
请问是我切片写错了吗?还是其他错误呢?这种形式如何切片呢?

  • 写回答

2条回答 默认 最新

  • CSDN专家-HGJ 2022-02-12 00:04
    关注

    使用iloc,ad_data[i].iloc[:,24]= 1import /ad_data[i].iloc[:,24]
    示例:

    import pandas as pd
    
    d=[pd.DataFrame({'a':[1,2,3],'b':[4,5,6],'c':[7,8,9]}),pd.DataFrame({'m':[2,3,1],'n':[3,3,5],'t':[5,6,7]}),pd.DataFrame({'x':[0,1,3],'y':[2,2,5],'z':[1,0,1]})]
    for i in range(len(d)):
        d[i].iloc[:, 2] = 1/d[i].iloc[:, 2]
        print(d[i])
    
    

    运行结果:

    a  b         c
    0  1  4  0.142857
    1  2  5  0.125000
    2  3  6  0.111111
       m  n         t
    0  2  3  0.200000
    1  3  3  0.166667
    2  1  5  0.142857
       x  y    z
    0  0  2  1.0
    1  1  2  inf
    2  3  5  1.0
    
    

    如有帮助,请点击采纳按钮~~

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 系统已结题 2月20日
  • 已采纳回答 2月12日
  • 创建了问题 2月11日

悬赏问题

  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容