تابع SIGN در اکسل
تابع SIGN (یا تابع SIGN()) در اکسل یک تابع ساده ولی بسیار کاربردی برای تعیین علامت عدد است. این تابع فقط سه مقدار ممکن را برمیگرداند: 1 برای اعداد مثبت، 0 برای صفر و -1 برای اعداد منفی. در پروژههای تحلیلی، مالی و دادهکاوی این تابع کمک میکند جهت (positive/negative) مقادیر را سریع تشخیص داده و در کنار توابع دیگر رفتارهای پیچیدهتری پیادهسازی کنیم.
ساختار و نحوه استفاده
فرم کلی تابع:
=SIGN(number)در اینجا “number” میتواند یک عدد ثابت، مرجع به سلول یا نتیجه یک عبارت حسابی باشد.
مثالهای ساده
| ورودی (A1) | فرمول | نتیجه |
|---|---|---|
| -25 | =SIGN(A1) | -1 |
| 0 | =SIGN(A1) | 0 |
| 3.14 | =SIGN(A1) | 1 |
این جدول نشان میدهد که تابع SIGN فقط جهت عدد را بازمیگرداند و اندازه را در نظر نمیگیرد.
چند مثال کاربردی و سناریوهای واقعی
- شمارش خالص مقادیر مثبت و منفی: اگر بخواهید تفاوت تعداد مقادیر مثبت و منفی در یک محدوده را محاسبه کنید، کافی است جمع SIGNها را محاسبه کنید:
=SUMPRODUCT(SIGN(A1:A100))این فرمول برای هر مقدار مثبت 1، برای منفی -1 و برای صفر 0 میگذارد و مجموع نهایی نشاندهنده تفاضل تعداد مقادیر مثبت و منفی است.
- محاسبه جهت تغییرات (مثلاً در سریهای زمانی): برای تبدیل تغییرات روزانه به علامت +/− میتوان از SIGN استفاده کرد و سپس روند کلی را تحلیل نمود:
=SIGN(B2-B1)این فرمول جهت افزایش یا کاهش بین دو روز را مشخص میکند.
- نرمالسازی علامت نگهدارنده اندازه: اگر بخواهید فقط علامت را به یک عدد اعمال کنید (مثلاً گرد کردن با حفظ علامت)، میتوانید به این شکل عمل کنید:
=ROUND(ABS(A1),0)*SIGN(A1)ابتدا قدرمطلق عدد گرد میشود، سپس علامت اصلی با SIGN دوباره اعمال میشود تا عدد گرد شده با علامت اصلی بازگردد.
ترکیبهای پیشرفته و الگوهای مفید
- تبدیل نتایج منطقی به -1/0/1: گاهی میخواهیم مقایسههای منطقی را به -1/0/1 نگاشت کنیم. مثال:
=SIGN(A1-B1)نتیجه نشان میدهد A1 بزرگتر است، مساوی است یا کمتر از B1.
- استفاده در فرمولهای وزنی و SUMPRODUCT: در محاسبه شاخصهایی که جهت تاثیر اهمیت دارد، میتوان از SIGN همراه با ABS یا وزنها استفاده کرد:
=SUMPRODUCT(weights, SIGN(values))این الگو جهت تاثیر هر مقدار را در محاسبه نهایی لحاظ میکند.
- جایگزینی برای IF های طولانی: به جای نوشتن IFهای تو در تو برای تعیین علامت، استفاده از SIGN و CHOOSE یا INDEX خوانایی و سرعت را افزایش میدهد:
=CHOOSE(SIGN(A1)+2,"منفی","صفر","مثبت")در این مثال SIGN(A1) مقادیر -1،0،1 میدهد؛ با افزودن 2 به آن ایندکس 1..3 برای CHOOSE بهدست میآید.
نکات فنی، محدودیتها و نکات ایمنی
- SIGN فقط جهت عدد را برمیگرداند؛ برای شمارش و مقایسههای بیشتر ممکن است به توابع تکمیلی نیاز داشته باشید.
- اگر “number” غیرعددی باشد، تابع ممکن است خطای #VALUE! تولید کند. برای ایمنسازی، میتوانید از تابع N یا IFERROR استفاده کنید. مثال:
=SIGN(N(A1))تابع N تلاش میکند مقدار را به عدد تبدیل کند یا در صورت متن آن را به 0 تبدیل کند.
- در برخی کاربردهای آرایهای (Array formulas) یا محاسبات حجیم، استفاده از SUMPRODUCT+SIGN به جای حلقهها یا فرمولهای پیچیده کارایی و خوانایی را افزایش میدهد.
- تابع SIGN در اکسل و Google Sheets موجود است و در نسخههای قدیمیتر اکسل نیز قابل استفاده بوده؛ با این حال همیشه بهتر است قبل از پیادهسازی در مدلهای بزرگ، تست سازگاری انجام دهید.
نمونه کاربرد تحلیلی — شمارش خالص روندها
فرض کنید ستون A شامل تغییرات درصدی روزانه است. میخواهیم بدانیم در طی 30 روز اخیر خالص چند روز افزایش داشتهایم نسبت به کاهش. فرمول ساده:
=SUM(SIGN(A2:A31))این فرمول در اکسلهای قدیمی ممکن است نیاز به ورود به صورت فرمول آرایهای (Ctrl+Shift+Enter) داشته باشد، اما در نسخههای جدید و Office 365 با پشتیبانی آرایه پویا، بهصورت عادی کار میکند. خروجی مثبت یعنی روزهای افزایش بیشتر و خروجی منفی یعنی روزهای کاهش بیشتر.
جمعبندی و نکات پایانی
تابع SIGN یک ابزار کوچک ولی کلیدی برای تشخیص جهت عدد است که در ترکیب با توابع دیگر میتواند مسائل عملی متنوعی را حل کند: از مدلهای مالی و آمار تا پاکسازی داده و تحلیل روند. همیشه به نوع دادههای ورودی توجه کنید و برای جلوگیری از خطاهای نحوی و دادهای از توابع کمکی مانند N یا IFERROR بهره بگیرید.
اگر بخواهید میتوانم چند نمونه فایل نمونه اکسل با کاربردهای مختلف SIGN آماده کنم یا فرمولهای خاص شما را برای شرایط ویژه بهینهسازی کنم.
آیا این مطلب برای شما مفید بود ؟




