تابع code در اکسل
تابع CODE در اکسل برای برگرداندن مقدار عددیِ کُد کاراکترِ اول یک رشته متنی استفاده میشود. این تابع وقتی میخواهید بفهمید کاراکتر اولِ سلول چه کدی در سیستم عامل شما دارد یا قصد پردازش بر اساس نوع کاراکتر (مثلاً عدد، حرف بزرگ، حرف کوچک یا فاصله) را دارید، بسیار کاربردی است.
نحو و پارامترها
نحو تابع بسیار ساده است:
=CODE(text)پارامتر text میتواند یک رشته ثابت داخل گیومه، ارجاع به سلول یا خروجی یک تابع دیگر باشد. تابع تنها کدِ کاراکتر اول متن را برمیگرداند.
مثالهای پایه
| کاراکتر | فرمول | خروجی (نمونه) |
|---|---|---|
| A | =CODE("A") | 65 |
| a | =CODE("a") | 97 |
| 0 | =CODE("0") | 48 |
| space (فاصله) | =CODE(" ") | 32 |
توجه: مقادیر فوق بر پایه جدول ASCII/ANSI متداول هستند و در اکثر سیستمهای ویندوز همین خروجی را میبینید.
مثالهای کاربردی و فرمولهای ترکیبی
1) تشخیص اینکه اولین کاراکتر عدد است یا نه:
=IF(AND(CODE(LEFT(A1,1))>=48, CODE(LEFT(A1,1))<=57), "شروع با عدد", "شروع با غیر عدد")این فرمول کد اولین کاراکتر را میگیرد و اگر بین 48 و 57 (کدهای ‘0’ تا ‘9’) باشد، نتیجه متناظر را برمیگرداند.
2) گرفتن کد کاراکتر nام در یک رشته:
=CODE(MID(A1, n, 1))مثال: =CODE(MID(A1,3,1)) کد سومین کاراکتر را از متن A1 میدهد.
3) حذف یا تشخیص فاصلههای شروع (leading spaces):
=IF(CODE(LEFT(A1,1))=32, "فضای شروع دارد", "ندارد")اگر کد اولین کاراکتر 32 باشد، یعنی یک فاصله است؛ میتوانید سپس TRIM یا CLEAN را برای پاکسازی استفاده کنید.
نکات تخصصی و محدودیتها
- CODE فقط کاراکتر اول را بررسی میکند؛ برای بررسی سایر کاراکترها باید از LEFT/MID/RIGHT استفاده شود.
- وابستگی به مجموعهکاراکتر سیستم: CODE بر اساس مجموعهکاراکترِ سیستم عامل (معمولاً ANSI در ویندوز) عمل میکند. برای متون چندزبانه یا کاراکترهای یونیکد (مثل حروف فارسی یا نمادهای ویژه) ممکن است خروجی غیرمنتظره یا نامناسب داشته باشد.
- برای یونیکد از UNICODE استفاده کنید: اگر با حروف فارسی یا کاراکترهای خارج از بازه 0–255 کار میکنید، تابع UNICODE (برای گرفتن کد یونیکد) و UNICHAR (برای تبدیل کد یونیکد به کاراکتر) مناسبتر و دقیقتر هستند.
- خروجی خطا: اگر متن خالی باشد یا پارامتر نامعتبر باشد، ممکن است تابع خطا دهد؛ پس بهتر است با IFERROR یا شرطهای منطقی از آن جلوگیری کنید.
مقایسه سریع: CHAR، CODE، UNICHAR، UNICODE
| تابع | کاربرد | محدوده/نکته |
|---|---|---|
| CODE(text) | کد کاراکتر اول (براساس سیستم) | مناسب ASCII/ANSI — ممکن است برای یونیکد نادرست باشد |
| CHAR(number) | تبدیل عدد به کاراکتر بر اساس کد سیستم | عدد معمولاً بین 1 تا 255 |
| UNICODE(text) | کد یونیکد (Unicode code point) | مناسب برای فارسی، عربی و نمادهای یونیکد |
| UNICHAR(number) | تبدیل کد یونیکد به کاراکتر | پشتیبانی از کل بازه یونیکد |
نمونهای از مشکل بالقوه و راه حل
فرض کنید در سلولی متن فارسی دارید و میخواهید کد اولین کاراکتر را دریافت کنید. استفاده از CODE ممکن است نتیجه اشتباه بدهد یا محدود به حروفی با کدهای محلی شود. در این حالت بهتر است از UNICODE استفاده کنید.
=UNICODE(A1)این فرمول کد یونیکد کاراکتر اول را برمیگرداند و برای حروف مانند “ا” مقدار 1575 را بازمیگرداند (کد Unicode حرف الف عربی).
نکات عملی برای کارهای روزمره و پردازش دادهها
- برای دستهبندی سطرها بر اساس نوع اولین کاراکتر (عدد، حرف، نماد)، از ترکیب CODE و محدودههای کد استفاده کنید.
- برای تبدیل کاراکترهای عددی به مقدار عددی واقعی: اول بررسی کنید که کاراکتر عدد است، سپس از VALUE یا تبدیل ریاضی استفاده کنید؛ مثال:
=IF(AND(CODE(LEFT(A1,1))>=48,CODE(LEFT(A1,1))<=57), CODE(LEFT(A1,1))-48, ""). - اگر باید پردازش بر پایه کل کاراکترها انجام شود (نه فقط اولی)، از توابع رشتهای همراه با تکرار یا Power Query / VBA بهره ببرید.
پیشنهادهای بهینهسازی
- برای دادههای چندزبانه همواره از UNICODE/UNICHAR استفاده کنید تا سازگاری با حروف فارسی/عربی/چینی و … تضمین شود.
- از IFERROR یا ISBLANK برای جلوگیری از خطا در صورت سلولهای خالی استفاده کنید.
- برای پردازشهای پیچیده روی هر کاراکتر، Power Query یا ماکروهای VBA پُرقدرتتر و قابل کنترلترند.
خلاصه
تابع CODE در اکسل ابزاری ساده و مفید برای استخراج کد کاراکترِ اول یک متن است و در بررسی نوع کاراکتر یا پاکسازی داده کاربرد دارد. با این حال، برای دادههای یونیکد و متون غیرلاتین بهتر است از توابع UNICODE/UNICHAR استفاده شود تا دقت و سازگاری افزایش یابد.
آیا این مطلب برای شما مفید بود ؟




