python怎么填充数组_python-熊猫:用一些numpy数组填充一列

如果您尝试从传递给应用的函数中返回多个值,并且调用应用的DataFrame沿轴的项目数(在本例中为列)与您返回的值数相同,则Pandas将创建返回值中的一个DataFrame,其标签与原始DataFrame相同.您只要执行以下操作即可看到此信息:

>>> def test(row):

return [1, 2, 3]

>>> df= pd.DataFrame(np.random.randn(4, 3), columns=list('ABC'))

>>> df.apply(test, axis=1)

A B C

0 1 2 3

1 1 2 3

2 1 2 3

3 1 2 3

这就是为什么出现错误的原因,因为您无法将DataFrame分配给DataFrame列.

如果返回任何其他数量的值,它将仅返回可以分配的一系列对象:

>>> def test(row):

return [1, 2]

>>> df= pd.DataFrame(np.random.randn(4, 3), columns=list('ABC'))

>>> df.apply(test, axis=1)

0 [1, 2]

1 [1, 2]

2 [1, 2]

3 [1, 2]

>>> df['D'] = df.apply(test, axis=1)

>>> df

A B C D

0 0.333535 0.209745 -0.972413 [1, 2]

1 0.469590 0.107491 -1.248670 [1, 2]

2 0.234444 0.093290 -0.853348 [1, 2]

3 1.021356 0.092704 -0.406727 [1, 2]

我不确定为什么Pandas会这样做,以及为什么仅在返回值是列表或ndarray时才这样做,因为如果返回元组,它不会这样做:

>>> def test(row):

return (1, 2, 3)

>>> df= pd.DataFrame(np.random.randn(4, 3), columns=list('ABC'))

>>> df['D'] = df.apply(test, axis=1)

>>> df

A B C D

0 0.121136 0.541198 -0.281972 (1, 2, 3)

1 0.569091 0.944344 0.861057 (1, 2, 3)

2 -1.742484 -0.077317 0.181656 (1, 2, 3)

3 -1.541244 0.174428 0.660123 (1, 2, 3)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值