تابع value در اکسل
تابع VALUE در اکسل برای تبدیل رشتههای متنی که نمایانگر عدد، تاریخ یا زمان هستند به مقادیر عددی واقعی به کار میرود. این تابع زمانی مفید است که دادهها از سیستمهای دیگر یا فایلهای متنی وارد شده و اعداد بهصورت متن (مثلاً با یک علامت آکسان، فاصلههای غیرمعمول یا نماد واحد) ذخیره شدهاند.
ساختار و سینتکس تابع
سینتکس تابع بسیار ساده است:
=VALUE(text)آرگومان text میتواند یک رشته متنی، مرجع به سلولی که متن دارد، یا ترکیبی از فرمولها باشد که خروجی آنها متن است.
مثالهای پایهای
- تبدیل عدد ذخیرهشده بهصورت متن: “123” → 123
- تبدیل تاریخ متنی: “2025/10/31” → تاریخ قابل محاسبه توسط اکسل
- تبدیل زمان متنی: “14:30” → مقدار زمان اکسل
=VALUE("123")
=VALUE("2025/10/31")
=VALUE("14:30")در مثال اول خروجی عدد 123 خواهد بود. در مثال دوم و سوم خروجی به صورت مقادیر تاریخ/زمان داخلی اکسل است که میتوان با فرمتدهی نمایش داد.
مثالهای واقعی و کاربردی
گاهی دادههای اعدادی بهصورت “1,234” یا “1.234,56” (بسته به منطقه) وارد میشوند. تابع VALUE در برخی نسخهها ممکن است با جداکنندههای محلی مشکل داشته باشد؛ در این حالت از NUMBERVALUE یا تابع SUBSTITUTE کمک بگیرید.
=VALUE(SUBSTITUTE(A2,",",""))در اینجا فرض شده A2 حاوی “1,234” است و با SUBSTITUTE تمامی کاماها حذف شده و سپس VALUE مقدار عددی برگردانده میشود.
=NUMBERVALUE("1.234,56",",",".")تابع NUMBERVALUE (نسخۀ مدرنتر) بهصورت صریح جداکنندهٔ اعشاری و هزارگان را میپذیرد؛ این مثال رشته “1.234,56” را به عدد 1234.56 تبدیل میکند.
جدول نمونهها
| ورودی (متن) | فرمول | خروجی | توضیح |
|---|---|---|---|
| “007” | =VALUE("007") | 7 | صفرهای پیشرو حذف میشوند و عدد بازگردانده میشود. |
| ” 123 “ | =VALUE(TRIM(A2)) | 123 | TRIM فاصلههای اضافی را حذف میکند و سپس VALUE تبدیل میکند. |
| “$1,234.00” | =VALUE(SUBSTITUTE(A3,"$","")) | 1234 | نماد واحد حذف شده؛ بسته به فرمت ممکن است نیاز به پاکسازی بیشتر باشد. |
| “50%” | =VALUE(SUBSTITUTE(A4,"%",""))/100 | 0.5 | نسبت درصد با حذف علامت % و تقسیم بر 100 محاسبه میشود. |
خطاها و مشکلات متداول
- #VALUE! — متن قابلیت تبدیل به عدد را ندارد (مثلاً شامل حروف یا نمادهای نامناسب است).
- مسائل «محلی» (locale) — استفاده از نقطه و کاما متفاوت بسته به تنظیمات سیستم ممکن است مانع تبدیل شود.
- فضاها و کارکترهای نامرئی — کارکترهای غیرقابلدیدن (مثل non-breaking space) باید با CLEAN یا SUBSTITUTE حذف شوند.
روشهای جایگزین و بهترین شیوهها
- استفاده از NUMBERVALUE برای مدیریت جداکنندههای سفارشی (پیشنهاد برای دادههای بینالمللی).
- استفاده از عملیات ریاضی ساده برای تبدیل متن به عدد: =A1*1 یا =A1+0 — این روش برای موارد ساده و بدون نمادهای اضافی کار میکند.
- پاکسازی متن پیش از تبدیل: TRIM، CLEAN، SUBSTITUTE برای حذف فضاها، نمادها و کاراکترهای نامناسب.
- حمایت از خطا با IFERROR یا IFNA برای جلوگیری از شکست فرمول هنگام مواجهه با متن نامعتبر.
=IFERROR(VALUE(TRIM(SUBSTITUTE(A1,"$",""))), "نامعتبر")این فرمول ابتدا نماد دلار را حذف میکند، فاصلهها را پاک میکند، سپس تلاش به تبدیل میکند و در صورت خطا مقدار «نامعتبر» را برمیگرداند.
موارد پیشرفته — استخراج عدد از متن ترکیبی
اگر متن شامل حروف و اعداد ترکیبی باشد (مثلاً “Order1234” یا “Qty: 50 pcs”)، ابتدا باید عدد را جدا کرد. در اکسلهای جدید میتوانید از فرمولهای متن قدرتمند یا توابع جدید مانند TEXTBEFORE/TEXTAFTER یا توابع متن پویا استفاده کنید. برای نسخههای قدیمیتر ممکن است نیاز به فرمولهای طولانیتر یا VBA باشد.
=VALUE(TEXTAFTER(A1, "Qty: "))در نسخههای جدید اکسل اگر A1 برابر “Qty: 50 pcs” باشد، TEXTAFTER قسمت بعد از “Qty: ” را برمیگرداند (“50 pcs”) و سپس با VALUE (بعد از پاکسازی متن اضافی) میتوان عدد را استخراج کرد. در موارد پیچیدهتر باید از ترکیب SUBSTITUTE، MID، FIND و غیره استفاده کنید.
جمعبندی و نکات کلیدی
- تابع VALUE ابزار ساده و مفیدی برای تبدیل متن به عدد است، اما در موارد محلیسازی و نمادهای اضافی ممکن است ناکافی باشد.
- NUMBERVALUE را برای سناریوهای بینالمللی ترجیح دهید؛ برای پاکسازی متن از TRIM، CLEAN و SUBSTITUTE استفاده کنید.
- همیشه دادههای ورودی را واکاوی و با IFERROR محافظت کنید تا فرمولها پایدار بمانند.
با رعایت این نکات و ترکیب مناسب توابع، میتوانید بهراحتی دادههای متنی مشکلدار را به مقادیر عددی قابل محاسبه تبدیل کنید و از آنها در محاسبات و گزارشها استفاده نمایید.
آیا این مطلب برای شما مفید بود ؟




