Представьте, что у меня есть следующий фрейм данных df:
Contract_Id, date, product, qty
1,2016-08-06,a,1
1,2016-08-06,b,2
1,2017-08-06,c,2
2,2016-08-06,a,1
3,2016-08-06,a,2
3,2017-08-06,a,2
4,2016-08-06,b,2
4,2017-09-06,a,2
Я пытаюсь выяснить, имеет ли каждый идентификатор контракта продукт b или продукт a, и возвращает 2 столбца.
Идеальный результат:
Contract_Id, date, product, qty, contract_id_has_a, contract_id_has_b
1,2016-08-06,a,1,True,True
1,2016-08-06,b,2,True,True
2,2016-08-06,a,1,True,False
3,2016-08-06,a,2,True,False
4,2016-08-06,b,2,False,True
Это вернет только, если в этой строке есть продукт a или нет
df[‘product’].str.contains('a', flags=re.IGNORECASE, regex=True)
Я пытался:
import re
df[‘product’].groupby([‘Contract_Id']).str.contains('a', flags=re.IGNORECASE, regex=True)
KeyError: ‘Contract_Id'
Может ли кто-нибудь просветить? Спасибо!