繁体   English   中英

Python 将字典转换为数据框失败

[英]Python converting dictionary to dataframe fail

当我尝试将以下字典转换为数据帧时,python 将每行重复两次。

a = [[[[130.578125, 96, 130.59375, 541],
       [130.5625, 635, 130.609375, 1055],
       [130.546875, 657, 130.625, 1917],
       [130.53125, 707, 130.640625, 1331],
       [130.515625, 1530, 130.65625, 2104]],
      [[130.578125, 96, 130.59375, 541],
       [130.5625, 635, 130.609375, 1055],
       [130.546875, 657, 130.625, 1917],
       [130.53125, 707, 130.640625, 1331],
       [130.515625, 1530, 130.65625, 2104]]],
     [[[143.34375, 5, 143.359375, 79],
       [143.328125, 142, 143.375, 129],
       [143.3125, 132, 143.390625, 137],
       [143.296875, 126, 143.40625, 118],
       [143.28125, 113, 143.421875, 125]],
      [[143.34375, 5, 143.359375, 79],
       [143.328125, 142, 143.375, 129],
       [143.3125, 132, 143.390625, 137],
       [143.296875, 126, 143.40625, 118],
       [143.28125, 113, 143.421875, 125]]]]

b = ['Mini','on']

c = dict(zip(b,a))

d = pd.DataFrame.from_dict(c)

print d

Python 打印以下输出:

                                                Mini  \
0  [[130.578125, 96, 130.59375, 541], [130.5625, ...
1  [[130.578125, 96, 130.59375, 541], [130.5625, ...

                                                  on
0  [[143.34375, 5, 143.359375, 79], [143.328125, ...
1  [[143.34375, 5, 143.359375, 79], [143.328125, ...

所需的输出是:

                                                Mini  \
0  [[130.578125, 96, 130.59375, 541], [130.5625, ...

                                                  on
0  [[143.34375, 5, 143.359375, 79], [143.328125, ...

有人可以建议我如何解决这个问题吗?

让我们从一个例子开始

你得到

pd.DataFrame({'Mini': [1, 1], 'on': [2, 2]})

在此处输入图片说明

当你想要的时候

pd.DataFrame({'Mini': [1], 'on': [2]})

在此处输入图片说明


您定义的a是列表形式的 2x2x5x4 数组。 第一个维度被压缩到dict的值中。 第二个维度是长度为 2 的列表,我刚刚演示了将这样的字典传递给pd.DataFrame时会发生什么

要修复它,请将以下行与您之前对d定义交换

    d = pd.Series(c).to_frame().T

回复评论
打印整个单元格内容

with pd.option_context('display.max_colwidth', -1):
    print d

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM