تابع address در اکسل
تابع ADDRESS یکی از توابع مفید اکسل برای ساختن آدرس یک سلول بهصورت متن (string) است. این تابع آدرس سلول را برمیگرداند و معمولا در ترکیب با توابعی مانند INDIRECT، MATCH، ROW و COLUMN کاربرد دارد تا ارجاعهای پویا بسازید.
فرمول و پارامترها
ساختار تابع ADDRESS به صورت زیر است:
=ADDRESS(row_num, column_num, [abs_num], [a1], [sheet_text])توضیح پارامترها به تفصیل:
- row_num: شماره سطر (عدد صحیح)، اجباری
- column_num: شماره ستون (عدد صحیح، مثلاً 1 = A, 2 = B)، اجباری
- abs_num: نوع مطلق/نسبی بودن آدرس (اختیاری، پیشفرض 1)
- a1: قالب آدرس، TRUE یا حذفشده برای سبک A1، FALSE برای R1C1 (اختیاری)
- sheet_text: نام شیت به صورت متن برای قرار گرفتن قبل از آدرس (اختیاری)
مقادیر معمول abs_num
| مقدار | نتیجه | توضیح |
|---|---|---|
| 1 | $A$1 | آدرس مطلق ستون و سطر |
| 2 | A$1 | ستون نسبی، سطر مطلق |
| 3 | $A1 | ستون مطلق، سطر نسبی |
| 4 | A1 | آدرس نسبی کامل |
مثالهای پایهای
=ADDRESS(2,3)نتیجه: “$C$2” — چون پیشفرض abs_num برابر 1 است (آدرس مطلق).
=ADDRESS(5,1,4)نتیجه: “A5” — abs_num=4 آدرس نسبی کامل تولید میکند.
=ADDRESS(2,3,1,FALSE)نتیجه: “R2C3” — قالب R1C1 زمانی که a1=FALSE استفاده شود.
ترکیب با INDIRECT برای گرفتن مقدار سلول
تابع ADDRESS خروجی را بهصورت متن تولید میکند، برای خواندن مقدار آن آدرس باید از INDIRECT استفاده کنید:
=INDIRECT(ADDRESS(MATCH("سیب",A:A,0),2))توضیح: این فرمول ابتدا با MATCH مکان سطر حاوی “سیب” را در ستون A پیدا میکند و سپس ADDRESS آدرس سلول متناظر در ستون 2 (B) را میسازد. در نهایت INDIRECT مقدار سلول ساختهشده را برمیگرداند.
مثال کاربردی: جمع بازه پویا
=SUM(INDIRECT(ADDRESS(1,2)&":"&ADDRESS(10,2)))توضیح: جمع سلولهای B1 تا B10 را محاسبه میکند. ADDRESS برای ساختن ابتدا و انتهای بازه بهصورت متن استفاده شده و سپس INDIRECT بازه متنی را به بازه واقعی تبدیل میکند.
خطرات و بهینهسازی: INDIRECT و عملکرد
نکته مهم: INDIRECT یک تابع volatile است؛ یعنی در هر بار بازخوانی شیت یا تغییرات کلی مجددا ارزیابی میشود که در کاربرگهای بزرگ میتواند عملکرد را کاهش دهد. در مواردی که ممکن است، بهتر است از توابع غیرvolatile مانند INDEX استفاده کنید.
-- Volatile approach
=INDIRECT(ADDRESS(MATCH("سیب",A:A,0),2))
-- Non-volatile alternative
=INDEX(B:B, MATCH("سیب", A:A, 0))توضیح: نسخه دوم با INDEX غیرvolatile است و همان مقدار را بازمیگرداند اما سریعتر و پایدارتر در شیتهای بزرگ عمل میکند. بنابراین هرگاه هدف برگشت مقدار سلول باشد، اولویت دهید از INDEX یا OFFSET (با احتیاط) استفاده کنید.
استفادههای پیشرفته و ترکیب با توابع دیگر
- ساخت نام (Named Range) پویا با ADDRESS و INDIRECT برای تغییر بازهها بر اساس ورودی کاربر.
- ترکیب با ROW و COLUMN برای ساخت آدرس بر اساس موقعیت فعلی فرمول: ADDRESS(ROW(), COLUMN()+1).
- استفاده از sheet_text برای ارجاع به شیتهای دیگر: =ADDRESS(1,1,1,TRUE,”‘سال 1404’!”) → “‘سال 1404’!$A$1”
- ساختن آدرسهای داینامیک در گزارشهای داشبورد که کارکننده میخواهد با تغییر شماره شیت یا شماره سطر، محاسبه تغییر کند.
مثال پیشرفته: نام شیت داینامیک
=INDIRECT(ADDRESS(1,1,1,TRUE, "'" & A1 & "'!"))توضیح: اگر در سلول A1 نام شیت مدنظر نوشته شده باشد، این فرمول مقدار سلول A1 شیتِ مشخصشده را بازمیگرداند. توجه داشته باشید که قالب نام شیت باید در صورت داشتن فاصله داخل کوتیشن و علامت تعجب قرار داده شود.
نکات تخصصی و بهترین روشها
- وقتی فقط نیاز به مقدار یک سلول دارید، INDEX را جایگزین INDIRECT کنید تا از مشکلات عملکردی جلوگیری شود.
- اگر با R1C1 کار میکنید یا با ماکروها تعامل دارید، پارامتر a1 را بهصراحت مشخص کنید تا سردرگمی نشود.
- برای نمایش آدرس در متنی خروجی (مثلاً گزارش یا سند) استفاده از ADDRESS مناسب است؛ برای محاسبات بهتر INDIRECT را با احتیاط بهکار ببرید.
- در استفاده از sheet_text دقت کنید؛ نام شیت باید مطابق قوانین اکسل نقلقولها و تعجب داشته باشد.
خطاهای رایج
- استفاده از شماره ستون بزرگتر از محدوده مجاز → #REF!
- آدرس ساختهشده بهشکل متن باقی میماند مگر اینکه از INDIRECT یا دیگر تابع مناسب استفاده شود.
- وابستگی بیش از حد به توابع volatile باعث کند شدن فایلهای بزرگ میشود.
جمعبندی
تابع ADDRESS ابزاری قدرتمند برای تولید آدرسهای متنی سلول است که در گزارشسازی و ساخت ارجاعات داینامیک کاربرد دارد. ترکیب هوشمندانهٔ ADDRESS با INDIRECT، MATCH، ROW و COLUMN امکانات بسیار انعطافپذیری ایجاد میکند. با این حال برای حفظ عملکرد، هنگام نیاز به مقدار واقعی سلولها از توابع غیرvolatile مانند INDEX استفاده کنید.
آیا این مطلب برای شما مفید بود ؟




