You need to group the dataframe by the 'id' and 'group' columns and calculate the count of each unique value in the 'term' column for each unique pair of 'id' and 'group' values. In other words, you need to determine how often each term appears in each id-group combination.
You can achieve this using pandas' groupby and size functions:
df.groupby(['id', 'group', 'term']).size().unstack(fill_value=0)
This will produce a table with the id and group as indices and the term as columns.
This method is highly efficient, even for large datasets. For a dataframe with 1,000,000 rows, the above code takes only about 6 seconds to execute.
The above is the detailed content of How to Efficiently Count Term Occurrences within ID-Group Combinations in a Pandas DataFrame?. For more information, please follow other related articles on the PHP Chinese website!