تابع EXPAND در اکسل
تابع EXPAND یکی از توابع جدید آرایهای در نسخههای اخیر Excel (Microsoft 365 و Excel for the web) است که امکان «گسترش» یک آرایه به ابعاد دلخواه را فراهم میکند. این تابع برای زمانی مفید است که خروجی یک فرمول آرایهای باید حتماً به تعداد ردیفها یا ستونهای مشخصی برسد — مثلاً برای نمایش در داشبورد، تهیه دادههای ورودی برای نمودار یا پر کردن محدودهای که نیاز به اندازه ثابت دارد.
سینتکس و پارامترها
- EXPAND(array, rows, [columns], [pad_with])
- array — آرایه یا محدودهای که میخواهیم گسترش دهیم (الزامی).
- rows — تعداد ردیفهایی که خروجی باید داشته باشد (الزامی).
- columns — (اختیاری) تعداد ستونهایی که خروجی باید داشته باشد.
- pad_with — (اختیاری) مقداری که برای سلولهای اضافهشده استفاده میشود؛ اگر وارد نکنید، Excel مقدار پیشفرضی قرار میدهد یا سلولها خالی/خطا میمانند که بسته به نسخه تفاوت دارد.
مثالهای عملی
1) گسترش یک محدوده 2×2 به 4×3 و پر کردن سلولهای جدید با عدد صفر:
=EXPAND(A1:B2, 4, 3, 0)توضیح: اگر A1:B2 شامل مقادیر اولیه باشد، خروجی این فرمول یک بلوک 4 ردیفی و 3 ستونی خواهد بود که در خانههای اضافی (ردیفهای 3 و 4 یا ستون سوم) عدد 0 قرار میگیرد.
2) استفاده با FILTER برای تضمین اندازه خروجی (مثلاً همیشه 10 ردیف و 2 ستون):
=EXPAND(FILTER(A2:B100, C2:C100="Accepted"), 10, 2, "")توضیح: این فرمول ابتدا رکوردهایی با وضعیت “Accepted” را فیلتر میکند و سپس خروجی را به اندازه 10×2 گسترش میدهد. اگر نتایج کمتر از 10 ردیف باشند، خانههای باقیمانده با رشته خالی (“”) پر میشوند؛ این سبک کاربرد برای تهیه ورودی ثابت برای نمودارها یا برای جلوگیری از خطاهای بعدی مفید است.
3) گسترش یک ستون به چند ستون برای نمایش همزمان:
=EXPAND(A1:A3, 3, 5, "N/A")توضیح: ستون A شامل سه مقدار است. این فرمول خروجی 3 ردیف و 5 ستون بازمیگرداند؛ ستونهای چهارم و پنجم برای هر ردیف با متن “N/A” پر میشوند.
ترکیبهای حرفهای
- استفاده با LET برای خوانایی:
=LET(data, FILTER(A2:C100, D2:D100="Yes"), EXPAND(data, 20, 3, ""))توضیح: ابتدا دادهها با LET نامگذاری میشوند و سپس با EXPAND به اندازه ثابت 20×3 گسترش مییابند؛ مناسب برای مدیریت فرمولهای طولانی.
- استفاده با SORT/UNIQUE برای خروجی با اندازه ثابت:
=EXPAND(SORT(UNIQUE(B2:B100)), 15, 1, "")توضیح: ابتدا مقادیر یکتا و مرتبشده استخراج میشوند و سپس خروجی در 15 ردیف یک ستون جای میگیرد.
- ترکیب با VSTACK/HSTACK برای ساخت بلوکهای داده:
=HSTACK(EXPAND(A1:A3, 3, 3, 0), EXPAND(B1:B3, 3, 3, 0))توضیح: دو ستون مستقل را ابتدا به بلوکهای 3×3 تبدیل و سپس کنار هم قرار میدهد.
موارد کاربرد واقعی و سناریوهای تجاری
- ایجاد محدوده ثابت برای داشبوردهایی که نیازمند ورودی ثابت هستند (مثلاً جدول عملکرد ماهانه با 12 ردیف).
- تهیه داده ورودی برای نمودارها یا Pivot که نمیتوانند با تعداد متغیر ورودی کار کنند.
- ساخت قالبهای خروجی برای اتوماسیون گزارشگیری که همیشه باید شکل و اندازه مشخصی داشته باشند.
- پر کردن خودکار سلولهای خالی با مقادیر پیشفرض قبل از محاسبات بعدی.
نکات و بهترین رویهها
- تابع EXPAND در نسخههای قدیمی Excel (مثل Excel 2016 یا 2019 بدون اشتراک Microsoft 365) در دسترس نیست؛ در این نسخهها باید از روشهای سنتی (مثل فرمولهای آرایهای پیچیده یا VBA) استفاده کنید.
- همیشه مقدار pad_with را مشخص کنید تا رفتار فرمول در همه سیستمها و برای دیگر کاربران یکسان باشد؛ مثلاً از “” یا 0 یا “N/A” بسته به نیاز استفاده کنید.
- برای جلوگیری از خطاهای نمایش (spill errors)، محدوده اطراف فرمول را خالی نگه دارید.
- در صورت لزوم از IFERROR یا IFNA برای مدیریت خطاها استفاده کنید، بهخصوص اگر pad_with مقدار خاصی نیست یا فیلتر بدون نتیجه باشد.
محدودیتها و نکات سازگاری
اگر با نسخهای از اکسل کار میکنید که توابع آرایهای دینامیک را پشتیبانی نمیکند، تابع EXPAND قابل استفاده نیست. همچنین در برخی وضعیتها مقدار پیشفرض pad_with ممکن است رفتار متفاوتی داشته باشد؛ بنابراین توصیه میشود همیشه مقدار padding را صراحتاً تعیین کنید.
جمعبندی
تابع EXPAND ابزاری ساده اما قدرتمند برای کنترل شکل و اندازه خروجی آرایهها در Excel است. با ترکیب آن با دیگر توابع دینامیک مانند FILTER، SORT، UNIQUE، و LET میتوانید خروجیهای منظم، قابل پیشبینی و مناسب برای گزارشدهی و داشبوردها بسازید. رعایت نکات مربوط به pad_with و سازگاری نسخهها، تجربه بهرهوری شما را بهطور قابلتوجهی بهبود میدهد.
| پارامتر | توضیح |
|---|---|
| array | آرایه یا محدوده ورودی |
| rows | تعداد ردیفهای خروجی |
| columns | تعداد ستونهای خروجی (اختیاری) |
| pad_with | مقدار برای پر کردن خانههای جدید (اختیاری) |
آیا این مطلب برای شما مفید بود ؟




