Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Welcome To Ask or Share your Answers For Others

Categories

0 votes
475 views
in Technique[技术] by (71.8m points)

python - Looping over groups in a grouped dataframe

Consider this small example:

data={"X":[1, 2, 3, 4, 5], "Y":[6, 7, 8, 9, 10], "Z": [11, 12, 13, 14, 15])
frame=pd.DataFrame(data,columns=["X","Y","Z"],index=["A","A","A","B","B"])

I want to group frame with

grouped=frame.groupby(frame.index)

Then I want to loop over the groups by:

for group in grouped:

But I'm stuck on the next step: How can I extract the group in each loop as a pandas DataFrame so I can further process it?

See Question&Answers more detail:os

与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome To Ask or Share your Answers For Others

1 Answer

0 votes
by (71.8m points)

df.groupby returns an iterable of 2-tuples: the index, and the group. You can iterate over each group like this:

for _, g in frame.groupby(frame.index):
    .... # do something with `g`

However, if you want to perform some operation on the groups, there are probably better ways than iteration.


与恶龙缠斗过久,自身亦成为恶龙;凝视深渊过久,深渊将回以凝视…
Welcome to OStack Knowledge Sharing Community for programmer and developer-Open, Learning and Share
Click Here to Ask a Question

2.1m questions

2.1m answers

60 comments

56.9k users

...