首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >向DataFrame广播连续剧

向DataFrame广播连续剧
EN

Stack Overflow用户
提问于 2020-01-16 12:12:23
回答 4查看 207关注 0票数 3

我有一个系列,比如:

代码语言:javascript
运行
复制
A    2
B    3
C    4

和一个类似的DataFrame:

代码语言:javascript
运行
复制
    A   B   C
0   1   2   3
1   4   5   6
2   7   8   9

我想将序列赋值给数据帧中的所有行。这是预期的输出:

代码语言:javascript
运行
复制
    A   B   C
0   2   3   4
1   2   3   4
2   2   3   4

当然我能做到

代码语言:javascript
运行
复制
for col in ser.index:
    df[col] = ser[col]

但是,什么是更有效的方法呢?

EN

回答 4

Stack Overflow用户

发布于 2020-01-16 12:58:16

使用pandas.DataFrame.divmul

代码语言:javascript
运行
复制
df.div(df).mul(s)

或者使用numpy.tile (iff df.columns == s.index)要快得多:

代码语言:javascript
运行
复制
pd.DataFrame(np.tile(s, (len(df), 1)), columns=df.columns)

输出:

代码语言:javascript
运行
复制
     A    B    C
0  2.0  3.0  4.0
1  2.0  3.0  4.0
2  2.0  3.0  4.0
票数 4
EN

Stack Overflow用户

发布于 2020-01-16 13:43:52

assign

在没有检查的情况下,只需为在s中找到的所有行分配一列:

代码语言:javascript
运行
复制
df.assign(**s)
#   A  B  C
#0  2  3  4
#1  2  3  4
#2  2  3  4

或者,只需从s创建DataFrame,并仅连接回未更新的列:

代码语言:javascript
运行
复制
pd.concat([df[df.columns.difference(s.index)],
           pd.DataFrame(s.to_dict(), index=df.index)],
          axis=1)
票数 2
EN

Stack Overflow用户

发布于 2020-01-16 12:44:14

代码语言:javascript
运行
复制
df = df.replace(df, ser)

代码语言:javascript
运行
复制
df = df.apply(lambda x : ser, axis=1)

示例

pandas.DataFrame.applylambda functionaxis = 1一起使用

代码语言:javascript
运行
复制
>>> df = pd.DataFrame({'A':[1,4,7],'B':[2,5,8],'C':[3,6,9]})
>>> ser = pd.Series({'A':2,'B':3,'C':4})
代码语言:javascript
运行
复制
>>> df = df.apply(lambda x : ser, axis=1)
代码语言:javascript
运行
复制
>>> df
   A  B  C
0  2  3  4
1  2  3  4
2  2  3  4

第二种解决方案:

代码语言:javascript
运行
复制
>>> df = df.replace(df, ser)
>>> df
   A  B  C
0  2  3  4
1  2  3  4
2  2  3  4
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59762934

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档