I have a dataframe like this
df = pd.DataFrame(columns = ['A', 'B'])
df.A = [1,1,1,2,2,2,2,4,4,5]
df.B = [5,2,4,3,1,5,4,1,2,2]
What I'm currently using
d = {}
for i in df.A:
d[i] = []
for v in df.A[df.A == i].index:
d[i].append(df.B[v])
Resulting in
{1: [5, 2, 4], 2: [3, 1, 5, 4], 4: [1, 2], 5: [2]}
But it's slow.
What is a pythonic way of doing this?
EDIT:
d = {}
for i in df.A.unique():
d[i] = df[df.A == i].B.tolist()
Still seems like there must be a faster way
Thanks for any help!