python - 将 DataFrame 中的值插入另一个 DataFrame

标签 python python-3.x pandas

好吧,我真正的问题比这更大,但我有一个简单的工作示例。

>>> import pandas as pd
>>> import numpy as np
>>> a = pd.DataFrame(np.array([[2, 1990], [4,1991], [5,1992]]), \
...                  index=[1,2,3], columns=['var', 'yr'])
>>> a
   var    yr
1    2  1990
2    4  1991
3    5  1992
>>> b = pd.DataFrame(index=a.index, columns=['new_var'])
>>> b
  new_var
1     NaN
2     NaN
3     NaN
>>> b[a.yr<1992].loc[:, 'new_var'] = a[a.yr<1992].loc[:, 'var']
>>> b
  new_var
1     NaN
2     NaN
3     NaN

我想要以下输出:

>>> b
  new_var
1       2
2       4
3     NaN

最佳答案

有了过滤的东西,你正在创建一个切片的副本,因此它不会分配。

改为这样做:

b.loc[a.yr<1992, 'new_var'] = a['var']

关于python - 将 DataFrame 中的值插入另一个 DataFrame,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41880184/

相关文章:

python - 在 Cython 中创建 C 结构

python - 如何从 pymongo 字段中的所有值创建列表?

python - 如何将 Pandas 数据框保存到 sav 文件中

python - 根据 pandas 中的另一列计算一列的平均值

python - 如何使我修改后的 pandas/numpy .where 函数适应不同大小的列表参数?

python - 你如何将这个正则表达式习语从 Perl 翻译成 Python?

python - 如何在提取包含多个值的 CSV 文件后构建实例

python-3.x - 检查列表中的项目是否在列表类型的列中可用

python-3.x - 使用 PCA 降维,同时保留百分比方差

python - 在Python中循环日期