এখানে সময় নির্ধারণের চেয়ে নীচেরটি ধীর গতির , তবে আমরা একাধিক কলামের সামগ্রীর উপর ভিত্তি করে অতিরিক্ত কলামটি গণনা করতে পারি এবং অতিরিক্ত কলামের জন্য দুটিরও বেশি মান গণনা করা যায়।
কেবল "সেট" কলামটি ব্যবহার করে সাধারণ উদাহরণ:
def set_color(row):
if row["Set"] == "Z":
return "red"
else:
return "green"
df = df.assign(color=df.apply(set_color, axis=1))
print(df)
Set Type color
0 Z A red
1 Z B red
2 X B green
3 Y C green
অ্যাকাউন্টে নেওয়া আরও রঙ এবং আরও কলামগুলির উদাহরণ:
def set_color(row):
if row["Set"] == "Z":
return "red"
elif row["Type"] == "C":
return "blue"
else:
return "green"
df = df.assign(color=df.apply(set_color, axis=1))
print(df)
Set Type color
0 Z A red
1 Z B red
2 X B green
3 Y C blue
সম্পাদনা (21/06/2019): প্লাইটাটা ব্যবহার করে
এই ধরণের জিনিসগুলি করার জন্য প্লাইটাটা ব্যবহার করাও সম্ভব (এটি ব্যবহারের চেয়েও ধীর বলে মনে হয় assign
এবং apply
)।
from plydata import define, if_else
সাধারণ if_else
:
df = define(df, color=if_else('Set=="Z"', '"red"', '"green"'))
print(df)
Set Type color
0 Z A red
1 Z B red
2 X B green
3 Y C green
বাসিন্দা if_else
:
df = define(df, color=if_else(
'Set=="Z"',
'"red"',
if_else('Type=="C"', '"green"', '"blue"')))
print(df)
Set Type color
0 Z A red
1 Z B red
2 X B blue
3 Y C green