я бью блок здесь.Я должен перевести эту формулу Excel
=IF(COUNTIFS(advisor!$C:$C,$A3)=0,"0 disclosed",
IF(COUNTIFS(advisor!$C:$C,$A3,advisor!$E:$E,2)>0,"Dependent",
IF(IF(COUNTIFS(advisor!$C:$C,$A3,advisor!$B:$B,"auditor")>0,1,0)+IF(COUNTIFS(advisor!$C:$C,$A3,advisor!$B:$B,"compensation")>0,1,0)=2,"Independent","1 disclosed")))
, пока это мое решение для python-pandas:
df['auditor_compensation'] = np.where(df['id'].isin(df_advisor['company_id']).count() == 0,
'0 disclosed',
np.where(df_advisor['dependent'] == 2, 'dependent',
np.where((np.where(df_advisor['type']=='auditor', 1, 0)+np.where(df_advisor['type']=='compensation', 1, 0)) == 2, 'independent', '1 disclosed')))
, которое я продолжаю получать ValueError: Length of values does not match length of index
df пример данных: данные компании
id ticker iq_id company auditor_compensation
48299 ENXTAM:AALB IQ881736 Aalberts Industries ?
48752 ENXTAM:ABN IQ1090191 ABN AMRO Group ?
48865 ENXTAM:ACCEL IQ4492981 Accell Group ?
49226 ENXTAM:AGN IQ247906 AEGON ?
49503 ENXTAM:AD IQ373545 Koninklijke ?
ниже df_advisor пример данных
id type company_id advisor_company_id dependent
1 auditor 4829 6091 1
17 auditor 4875 16512 1
6359 auditor 4886 7360 1
37 auditor 4922 8187 1
4415 compensation 4922 9025 1
53 auditor 4950 8187 1
Любая помощь будет очень признательна.