【问题标题】:Merge dict in for loop在for循环中合并dict
【发布时间】:2018-10-24 20:10:19
【问题描述】:

我想使用 for 循环创建一个新的数据框。

for (name, series) in Quantitative.iteritems():
data = {'Name': pd.Series(name), 'Count': pd.Series(Quantitative[name].size), 
        '% Miss.': pd.Series((sum(Quantitative[name].isnull().values.ravel()) / Quantitative[name].size) * 100), 
        'Card.': pd.Series(Quantitative[name].unique().size), 'Min': pd.Series(Quantitative[name].min()), 
        '1st Qrt.': pd.Series(Quantitative[name].quantile(0.25)), 'Mean': pd.Series(Quantitative[name].mean()), 
        'Median': pd.Series(Quantitative[name].median()), '3rd Qrt.': pd.Series(Quantitative[name].quantile(0.75)), 
        'Max': pd.Series(Quantitative[name].max()), 'Std.': pd.Series(Quantitative[name].std())}
dt = pd.DataFrame(data)
print(pd.DataFrame(dt))

但是,它会创建多个字典。如何将它们合并在一起?

【问题讨论】:

    标签: python python-2.7 pandas dataframe data-manipulation


    【解决方案1】:

    您不需要为 dict 中的每个项目创建数据框,然后将它们合并。使用列表推导创建行列表并从中创建数据框:

    rows = [[
        name, series.size, (sum(series.isnull().values.ravel()) / series.size) * 100, 
        series.unique().size, series.min(), series.quantile(0.25), series.mean(), 
        series.median(), series.quantile(0.75), series.max(), series.std()
    ] for name, series in Quantitative.iteritems()]
    
    dt = pd.DataFrame(
        rows, 
        columns=['Name', 'Count', '% Miss.', 'Card.', 'Min', '1st Qrt.',
                 'Mean', 'Median', '3rd Qrt.', 'Max', 'Std.'])
    print(dt)
    

    【讨论】:

      猜你喜欢
      • 2013-05-28
      • 2021-11-27
      • 1970-01-01
      • 2021-02-05
      • 1970-01-01
      • 2021-09-26
      • 1970-01-01
      • 2018-12-01
      • 2020-09-05
      相关资源
      最近更新 更多