J'ai 2 dataframes df1 et df2. Leur format est identique, à la seule différence que le premier comporte 3 lignes et le second 2.
df1 = pd.DataFrame({
'Company': ['Foo Inc.', 'Foo Inc.', 'Foo Inc.'],
'ID': ['123456', '123456', '123456'],
'Employee': ['John Doe', 'Richard Roe', 'Jane Doe'],
'Position': ['Executive Director', 'Director', 'Company Secretary']
})
df2 = pd.DataFrame({
'Company': ['Bar Inc.', 'Bar Inc.'],
'ID': ['56789', '56789'],
'Employee': ['Mark Moe', 'Larry Loe'],
'Position': ['Tax Consultant', 'Company Secretary']
})
print(df1)
Company Employee ID Position
0 Foo Inc. John Doe 123456 Executive Director
1 Foo Inc. Richard Roe 123456 Director
2 Foo Inc. Jane Doe 123456 Company Secretary
print(df2)
Company Employee ID Position
0 Bar Inc. Mark Moe 56789 Tax Consultant
1 Bar Inc. Larry Loe 56789 Company Secretary
Lorsque j'essaie de faire ce qui suit, cela fonctionne pour le premier mais pas pour le second.
gb1 = df1.set_index(['Company', 'ID', 'Employee']).groupby(['Company', 'ID'])
gb2 = df2.set_index(['Company', 'ID', 'Employee']).groupby(['Company', 'ID'])
for (name, id), new_df in gb1:
print(name)
print(id)
for (name, id), new_df in gb2:
print(name)
print(id)
Foo Inc.
123456
3 print(id)
4
----> 5 for (name, id), new_df in gb2:
6 print(name)
7 print(id)
ValueError: too many values to unpack (expected 2)
Cela s'explique par le fait que leurs indices sont différents
gb1.indices
>>> {('Foo Inc.', '123456'): array([0, 1, 2], dtype=int64)}
gb2.indices
>>> {'Company': array([0], dtype=int64), 'ID': array([1], dtype=int64)}
Est-ce que j'ai raté quelque chose ? Est-ce que c'est un bug ?