فرمول چند شرطی در اکسل — به زبان ساده

۶۲۷۸۸ بازدید
آخرین به‌روزرسانی: ۱۲ دی ۱۴۰۲
زمان مطالعه: ۱۳ دقیقه
دانلود PDF مقاله
فرمول چند شرطی در اکسل — به زبان سادهفرمول چند شرطی در اکسل — به زبان ساده

ایجاد شرط در یک فرمول، قدرت انتخاب نحوه محاسبات را به کاربر می‌دهد. به این ترتیب بسته به اینکه چه شرط یا شرط‌هایی محقق شوند، نوع محاسبه می‌تواند تغییر کند. چنین مسئله‌ای در محاسبات مربوط به مالیات به وفور دیده می‌شود. از طرفی گاهی برای تبدیل متغیرهای کمی به کیفی یا طبقه‌ای و کدگذاری آن‌ها، چنین امری ضروری به نظر می‌رسد. در اکسل و همینطور بسیاری از زبان‌های برنامه‌نویسی، تابع شرطی IF یکی از مشهورترین و پرکاربردترین تابع‌ها برای ایجاد شرط و محاسبات مرتبط با آن است. هر چند ساختار تابع شرطی IF در اکسل، ساده است ولی ترکیب چندین شرط و پیاده‌سازی آن به کمک ترکیب چندین IF کار سختی خواهد بود. اغلب برای ترکیب شرط‌ها از تابع AND ،OR یا Not نیز استفاده می‌کنند. حتی در مواردی نیز می‌توان از تابع VLookup برای انجام این کار استفاده کرد. در این نوشتار از مجله فرادرس سعی داریم نحوه ایجاد فرمول چند شرطی در اکسل را با توابع یا فرمول‌های مختلف شرح دهیم. در این بین به کمک مثال‌هایی نیز به کارگیری چنین فرمول‌هایی مورد ارزیابی قرار خواهد گرفت.

997696

برای آشنایی بیشتر با نحوه فرمول نویسی و کاربرد تابع IF در اکسل، بهتر است نوشتارهای فرمول نویسی در اکسل – آموزش مقدماتی و تابع IF در اکسل — به زبان ساده را مطالعه کنید. همچنین خواندن مطالب آموزش مقدماتی اکسل (Excel) — به زبان ساده و توابع جدید اکسل ۲۰۱۹ — راهنمای کاربردی  از مجله فرادرس نیز خالی از لطف نیست.

فرمول چند شرطی در اکسل

در بسیاری از فرمول‌ها، لازم است بسته به موقعیت یا شرط‌های مختلف، محاسبات متفاوتی را اجرا کنید. چنین وضعیتی را با عنوان فرمول چند شرطی (Multiple Condition) می‌شناسیم. نوشتن و ایجاد فرمولی که بتواند چنین کاری را انجام بدهد در بعضی از موارد امری پیچیده شده و به سادگی امکان‌پذیر نخواهد بود. البته راه‌کارهای متفاوتی برای غلبه بر این پیچیدگی ارائه شده است.

سعی داریم در این نوشتار از مجموعه مقالات فرادرس، با نحوه اجرا و ایجاد فرمول چند شرطی به کمک توابع متنوع اکسل آشنا شویم. هر چند به کارگیری روش‌های مختلفی برای ایجاد شرط در اکسل وجود دارد ولی بیشتر تکیه به تابع IF و البته IFS خواهیم داشت. به این موضوع نیز توجه داشته باشید که به کارگیری توابع دیگر مانند Choose یا SWITCH نیز در بعضی از موارد می‌تواند مفید باشند.

تابع IF در اکسل

قبل از هر کاری بهتر است با ساده‌ترین روش ایجاد شرط در اکسل آشنا شویم. همانطور که حدس می‌زنید، تابع IF مناسب‌ترین تابع برای ایجاد محاسبات شرطی است. فرم دستوری این تابع به صورت زیر است.

1=IF(test,[true],[false])

در حقیقت تابع IF یک شرط را سنجیده و براساس صحت یا نادرست بودن آن، محاسباتی را انجام می‌دهد. این گزاره شرطی در پارامتر test قرار گرفته و در صورت صحیح بودن شرط، عملیات بخش true صورت گرفته و در صورت غلط بودن آن، محاسبات بخش false انجام خواهد شد.

برای اینکه بهتر کاربرد تابع IF را درک کنید به مثالی که توسط تصویر ۱، ارائه شده است، توجه کنید. نمرات دانشجویان در این ستون Score درج شده. شرط نیز به این شکل بیان شده که افراد دارای نمره بیش از ۶۵، با مقدار متنی "Pass" در ستون Result مشخص شوند و در صورتی که کمتر از ۶۵ امتیاز کسب کرده باشند، مقدار این سلول برایشان FALSE باشد.

basic IF 1
تصویر ۱: استفاده از تابع IF برای ایجاد شرط و طبقه‌بندی نمره دانشجویان

برای مثال همانطور که در تصویر ۱ می‌بینید، مقدار سلول D3 برابر با Pass شده زیرا امتیاز این دانشجو بیش از ۶۵ است. البته دانشجویی به نام Block با نمره ۶۴، مقدار سلول نتیجه برایش FALSE است.

نکته: اگر در قسمت false تابع IF چیزی ننویسید، اکسل در صورت نادرست بودن شرط، به طور خودکار مقدار سلول را با FALSE جایگزین خواهد کرد.

به جدولی که در ناحیه F3 تا G4 قرار دارد نیز توجه کنید. بعداً از این ناحیه برای تعیین حدود شرط استفاده خواهیم کرد. اگر بخواهیم به جای مقدار FALSE (که یک مقدار منطقی است)، مقدار متنی "Fail" قرار گیرد باید فرمول را برای سلول D3 به شکل زیر بنویسیم. توجه دارید که برای آنکه برای دانشجویان دیگر نیز این فرمول به کار گرفته شود، سلول D3 را باید در سلول‌های D4 به بعد کپی کنیم.

1=IF(C3>=65,"Pass","Fail")
basic IF 2
تصویر ۲: استفاده از تابع IF‌ به همراه مقدار متنی برای گزینه FALSE

همانطور مشاهده کردید، دانشجویان به دو دسته یا گروه طبقه‌بندی شدند. حتی می‌توان گفت که نمره‌های آنان با این کار به دو کد مجزا تفکیک شد.

تابع IF تو در تو ساده

آنچه به عنوان تابع IF‌ تو در تو می‌شناسیم، در حقیقت به کار بردن دو تابع IF برای بیان شرط است. این بار با توجه به کاربرگ تصویر ۳، می‌خواهیم کسانی که در ستون Score دارای نمره نیستند، مقدار متنی Incomplete در قسمت Result برایشان ثبت شود. به این ترتیب کسانی که دارای نمره هستند با شرط قبلی متن مربوطه برایشان ثبت می‌شود و در غیر اینصورت مقدار "Incomplete" باید در سلول مربوطه قرار گیرد.

کد دستوری ترکیب دو تابع IF در این حالت به صورت زیر نوشته خواهد شد.

1=IF(C3="","Incomplete",IF(C3>=65,"Pass","Fail"))

همانطور که مشاهده می‌کنید، تابع IF دوم، در قسمت FALSE تابع IF اول نوشته شده و به عنوان پارامتر آن تلقی خواهد شد. نتیجه اجرای این فرمول برای سلول C3 در تصویر ۳ قرار گرفته است.

basic nested IF
تصویر ۳: ترکیب دو تابع IF به شکل ساده برای طبقه‌بندی نمره دانشجویان

واضح است که به صورت منطقی، ابتدا تابع IF‌ اول محاسبه شده در صورتی که نتیجه FALSE باشد، تابع IF دوم برای افرادی که نمره دارند، در نظر گرفته خواهد شد. ولی می‌دانیم که اکسل از داخلی‌ترین تابع یا پرانتز برای محاسبه استفاده می‌کند. بنابراین منطق محاسباتی اکسل، به این شکل عمل می‌کند که ابتدا کسانی که دارای نمره بیشتر از ۶۵ هستند، عبارت Pass و در غیر اینصورت Fail در سلول وابسته قرار می‌گیرد. سپس برای کسانی که مقداری در سلول C3 ندارند، عبارت Incomplete در سلول وابسته ثبت می‌شود.

این بار می‌خواهیم با استفاده از کران‌هایی، حدود نمره افرادی که قبول شده‌اند را با حروف A تا D تقسیم بنده کرده و افرادی که کمتر از ۶۵ نمره کسب کرده‌اند را با کد F‌، نمایش دهیم. در جدول ۱، این تقسیم‌بندی‌ها را مشاهده می‌کنید.

امتیاز (Score)درجه (Grade)شرط (Condition)
۰ - ۶۳F<64
64 - 72D<73
73-84C<85
85 - 94B<95
95-100A

به منظور روشن‌تر شدن روش نوشتن فرمول چند شرطی در اکسل به کمک تابع IF، یک نمودار گردشی (Flow Chart) برای مسئله بالا تهیه کرده‌ایم که در تصویر ۴، قابل مشاهده است

nested if logical flow
تصویر ۴: نمودار گردشی برای فرمول چند شرطی در اکسل

همانطور که مشخص است هر شرط یا تابع IF توسط یک لوزی، نمایش داده شده و محاسبات مربوط به TRUE و FALSE با مستطیل‌هایی تعیین شده‌اند. در تمامی قسمت‌های شرطی، مقدار FALSE با یک تابع شرطی دیگر جایگزین شده است. البته در آخرین بخش (پایین‌تر شرط)، قسمت FALSE، مقدار Grade را برابر با A‌ قرار داده است. به این ترتیب هر یک از شرط‌ها توانسته‌اند سطرهای جدول ۱ را بازسازی کنند.

حال می‌خواهیم چنین روندی را در اکسل پیاده کنیم. به تصویر ۵ توجه کنید، با توجه به محدودیت‌های ذکر شده مقدارهای A تا D و همچنین F برای هر یک از دانشجویان ثبت شده است. همانطور که می‌بینید اولین محاسبه، گروه F را جدا کرده و محاسباتی بعدی، کدهای درجه (Grade) را مشخص می‌کنند.

nested IF grades
تصویر ۵: فرمول چند شرطی در اکسل برای تعیین طبقه نمرات دانشجویان

بهتر است نحوه نوشتن شرط‌های تو در تو (گزاره چند شرطی) را به کمک تابع IF در این حالت به صورت گام به گام شرح دهیم.

  • ابتدا اولین IF را برای تعیین مردودی (درجه F) می‌نویسیم.
1=IF(C5<64,"F")
  • مشخص است که این IF کسانی که نمره مردود گرفته‌اند را جدا می‌کند. در بخش بعدی باید گروه دوم را تعیین کنیم. حال IF دوم را هم در قسمت پارامتر سوم تابع IF‌ اول وارد می‌کنیم.
1=IF(C5<64,"F",IF(C5<73,"D"))

همانطور که مشاهده می‌کنید، قرار گیری IFها در فرمول از پایین به بالای در ترتیب جدول ۱ است. زیرا در محاسبات ترکیبی در اکسل، ابتدا فرمولی که در داخلی‌ترین پرانتز قرار گرفته است، محاسبه شده و به ترتیب به خارجی‌ترین پرانتز می‌رسد.

  • به این ترتیب برای مشخص کردن گروه C از شکل فرمولی زیر استفاده می‌کنیم.
1=IF(C5<64,"F",IF(C5<73,"D",IF(C5<85,"C")))
بر اساس رای ۶۵ نفر
آیا این مطلب برای شما مفید بود؟
اگر بازخوردی درباره این مطلب دارید یا پرسشی دارید که بدون پاسخ مانده است، آن را از طریق بخش نظرات مطرح کنید.
منابع:
exceljetمجله فرادرس
۲۰ دیدگاه برای «فرمول چند شرطی در اکسل — به زبان ساده»

درود بر شما
فرمول VLOOKUP رو درنظر بگیرین برای مثال که مقدار مورد نظر ستون های دیگه رو بهت میده
حالا من توی ستون اولم اگه مثلا 2تا سلول با یک مقدار مشابه باشه میخام هردوتاشو پیدا کنه و متنای ستون بعدش رو توی یه ستون دیگه ادغام کنه برام
چنین چیزی ممکنه؟
امیدوارم منظورمو رسونده باشم

خط دستوریتان اشتباه است …به جای ; در دستورات از , استفاده کردید…واقعا متاسفم

‌‌‌‌
با سلام و احترام؛


دستورات کاملاٌ صحیح هستند.
اینکه از ; استفاده شود یا , در تنظیمات ویندوز و بخش مربوط به Region>AdditionalSettings>ListSeparator قابل تغییر است. احتمالاٌ در سیستم عامل شما روی ; تنظیم شده است.

با تشکر از همراهی شما با مجله فرادرس

سلام وقت بخیر
ببخشید من میخوام ۴ تا معادله خط که تو نمودار در اکسل بدست آوردم یک فرمول واحد بدست بیارم باید چیکار کنم؟

سلام
یه سوال داشتم.اگه بخوایم یه تابع سه شرطی بنویسیم باید از چه دستوری استفاده کرد؟
مثلا:یک رشته عدد از 0 تا 20 داریم.چند کاراکتر با عناوین (مسئول-کارشناس-رئیس) داریم.
میخوایم بگیم اگر عدد بین 1 تا 9 بود و طرف (کارشناس) بود براش توی یه سلول دیگه عدد 10 رو بنویس.
اگر عدد بین 10 تا 20 بود و طرف (مسئول) یا (رئیس) بود براش توی یه سلول دیگه عدد 20 رو بنویس.
روی بخش دوم مشکل دارم که این یا رو چطور به همراه با شرط قبلیش به اکسل بفهمونم.
ممنون میشم راهنمایی بفرمائید

سلام وقت شما بخیر من از 5 شرط در یک سلول دارم استفاده می کنم ولی فقط شرط اول اجرا می شه ، چطوری می شه این مشکل رو حل کرد
Office :2021
فرمول:
IF($Q2=Q3,SUM(L2:L3),IF($Q2=Q4,SUM(L2:L4),IF($Q2=Q5,SUM(L2:L5),IF($Q2=Q6,SUM(L2:L6),IF(Q2=Q7,SUM(L2:L7),0)))))

سلام چجورری میشه بعد از دستوری که درباره 5 درصد کم کردن قیمت ها بود یک تابع دیگه مثل روند اضافه کنم لطقا راهنمایی کنید

سلام در تابع ifsنمیتوان بیشتر از 15داده را مورد برسی قرار داد و بعد ازآن ارور میدهد علت چیست

با سلام وقت بخیر
من با استفاده از F4 فرمولی را محاسبه می کنم، و با کمک F4 اعداد داخل فرمول را ثابت میکنم یک جواب به دست می اورم و زمانی که بدون F4 همان فرمول را باهمان عددگذاری و فقط دستی عدد ثابت را واردمی کنم جواب متفاوت می شود. راهنمایی می کنید؟

با سلام و احترام
ببخشید با استفاده از فرمول vlookup مقدار یک سلولی که با superscript به صورت سانتی متر مکعب درج شده است برگرداندم.اما در مقداری که برگردانده می شود عدد ۳ دیگر بصورت توان نیست و در کنار cm قرار داد , بصورت توانی نمایش داده نمی شود .بریا اینکار راه حلی وجود دارد ؟

سلام عالی بود کار من رو خیلی راه انداخت

باسلام و عرض ادب.در یک سلول اکسل چند تابع IF میتوان قرار داد?

سلام، وقت شما بخیر؛

در زمان پاسخگویی به کامنت شما، حداکثر هفت if را می‌توان در یک سلول اکسل استفاده کرد؛ هر چند راه‌هایی نیز برای دور زدن این محدودیت وجود دارند.

از همراهی شما با مجله فرادرس بسیار سپاسگزاریم.

باعرض سلام و احترام، مطالب بسیار مفید و کاربردی بود. تشکر

خیلی عالی بود ممنونم، بدون هیچ دردسری فرمول صحیح رو نوشتم

سلام اگر ر در سلول(a1) آب تایپ کرده‌ایم و در سلول b1 با شرط اینکه yes یا no باشد
چه فرمولی در سلولc1 بزارم که اگر سلولb1
No باشد همان سلول a1 در سلول c1 کپی شود

سلام.اگر بخوایم بجای نشان دادن pass , fail , good عدد یک سلول رو نشون بده یا محاصبه جمع دو سلول رو نشون بده چی بنویسیم؟

بعد از شرط عبارت مورد نظرت رو بنویس مثلا برای محاسبه جمع که اشاره کردی میشهاین مثال ساده رو زد
اگر سلولA1 بزرگتر از B1 بود اون هارو با هم جمع کن و در غیر اینصورت بنویس کوچک یا هر چیزی که مد نظر شماست:
=IF(A1>B1, SUM(A1,B1),KOCHIC)

عالیه

با درود و احترام-سپاس و قدردانی از زحمات اساتید و دست اندرکاران فرادرس بخاطر ارائه مطالب آموزشی متنوع و بسیار عالی و نیز آرزوی بهروزی و موفقیت روزافزون جهت همگی آنان .

نظر شما چیست؟

نشانی ایمیل شما منتشر نخواهد شد. بخش‌های موردنیاز علامت‌گذاری شده‌اند *