ویژگی تصویر

تابع TRANSPOSE در اکسل — راهنمای کامل و کاربردی

  /  اکسل   /  تابع transpose در اکسل
بنر تبلیغاتی الف

تابع TRANSPOSE در اکسل برای تبدیل سطرها به ستون‌ها و ستون‌ها به سطرها استفاده می‌شود. این تابع برای بازآرایی داده‌ها، آماده‌سازی گزارش و عملیات ماتریسی بسیار مفید است. در این مقاله به صورت گام‌به‌گام، مثال‌های واقعی، نکات حرفه‌ای و خطاهای متداول مربوط به تابع TRANSPOSE را بررسی می‌کنیم.

تعریف و ساختار تابع

تابع TRANSPOSE یک آرایه خروجی برمی‌گرداند و ساختار آن به شکل زیر است:

=TRANSPOSE(array)

در اینجا “array” محدوده‌ای از سلول‌ها (مثلاً A1:C3) است که می‌خواهید سطرها و ستون‌های آن جابجا شوند.

روش‌های استفاده: نسخه‌های جدید و قدیمی اکسل

  • Excel 365 / Excel 2021 و بالاتر: تابع TRANSPOSE با قابلیت dynamic array کار می‌کند و خروجی به صورت خودکار در سلول مقصد «spill» می‌شود. کافی است فرمول را در یک سلول وارد کنید و مقادیر به صورت خودکار در سلول‌های مجاور قرار می‌گیرند.
  • Excel 2019 و قدیمی‌تر: TRANSPOSE یک فرمول آرایه‌ای است. باید محدوده مقصد با ابعاد معکوس را انتخاب کرده، فرمول را وارد کرده و با Ctrl+Shift+Enter تایید کنید.

مثال ساده

فرض کنید جدول زیر داریم:

ABC
1نامسنشهر
2علی30تهران
3سارا28مشهد

برای نمایش این داده‌ها به صورت معکوس (سطر تبدیل به ستون)، اگر از Excel 365 استفاده می‌کنید، در سلول مثلا E1 بنویسید:

=TRANSPOSE(A1:C3)

در نسخه‌های قدیمی‌تر محدوده مقصد (مثلاً E1:G3 به صورت معکوس) را انتخاب کنید، سپس فرمول را وارد کرده و با Ctrl+Shift+Enter تایید کنید.

مثال تصویری: قبل و بعد

ورودیخروجی (پس از TRANSPOSE)
AB
12
34
AB
13
24

ترکیب TRANSPOSE با توابع دیگر

  • استفاده با FILTER، SORT و UNIQUE: در اکسل‌های جدید می‌توانید ابتدا داده‌ها را فیلتر یا مرتب کنید و سپس خروجی را ترنسپوز کنید. مثال:
    =TRANSPOSE(SORT(FILTER(A1:C10, B1:B10>100),1,TRUE))

    این فرمول ابتدا ردیف‌هایی با مقدار ستون B بالاتر از 100 را فیلتر، سپس مرتب کرده و در نهایت سطرها و ستون‌ها را جابجا می‌کند.

  • حفاظت از مراجع: اگر می‌خواهید فرمول‌ها پس از ترنسپوز، مراجع نسبی خود را حفظ کنند، باید از مراجع مطلق ($A$1) استفاده کنید یا از روش‌های جایگزین مانند Paste Special برای کپی فرمول‌ها استفاده نمایید.

اشکالات و خطاهای متداول

  • #REF!: اگر محدوده مقصد با محدوده منبع همپوشانی داشته باشد یا اندازه مقصد با اندازه معکوس منبع مطابقت نداشته باشد، این خطا رخ می‌دهد. راه‌حل: مقصد را در شیت دیگری انتخاب کنید یا ابعاد مناسب را مشخص کنید.
  • #VALUE!: ممکن است به خاطر وجود داده‌های نامناسب یا سلول‌های ادغام‌شده باشد. TRANSPOSE با سلول‌های ادغام‌شده مشکل دارد؛ قبل از اعمال، ادغام را حذف کنید.
  • وقتی داده‌ها تغییر می‌کنند، اگر از Paste Special استفاده کنید، داده‌ها به‌روزرسانی نمی‌شوند؛ در مقابل استفاده از تابع TRANSPOSE، ارتباط در لحظه حفظ می‌شود.

روش جایگزین: Paste Special → Transpose

اگر می‌خواهید یک بار داده‌ها را بدون فرمول و به عنوان مقادیر استاتیک جابجا کنید:

  • محدوده منبع را کپی کنید (Ctrl+C).
  • به محل مقصد بروید، راست‌کلیک کنید → Paste Special → انتخاب Transpose و سپس OK.

این روش سریع است ولی روشی دینامیک نیست؛ یعنی اگر داده‌های اصلی تغییر کند، نسخه ترنسپوز شده به‌روزرسانی نمی‌شود.

نمونه کد VBA برای ترنسپوز با حفظ فرمول‌ها

Sub TransposeKeepFormulas()
    Dim src As Range, dst As Range
    Set src = Range("A1:C3")
    Set dst = Worksheets("Sheet2").Range("A1")
    src.Copy
    dst.PasteSpecial Paste:=xlPasteFormulas, Operation:=xlNone, SkipBlanks:=False, Transpose:=True
    Application.CutCopyMode = False
End Sub

این ماکرو در شیت جاری محدوده A1:C3 را کپی می‌کند و فرمول‌ها را به صورت ترنسپوز‌شده در شیت “Sheet2” چسبانده (Paste) می‌کند. مزیت این روش نسبت به Paste Special دستی این است که می‌توانید آن را خودکار کنید و فرمول‌ها حفظ شوند.

نکات حرفه‌ای و توصیه‌ها

  • در اکسل‌های جدید از TRANSPOSE به‌همراه توابع دینامیک (مثل SEQUENCE، FILTER) برای ساخت جدول‌های پویا استفاده کنید.
  • قبل از ترنسپوز، سلول‌های ادغام‌شده را حذف کنید تا از خطا جلوگیری شود.
  • اگر فقط می‌خواهید مقادیر را جابجا کنید و ارتباط با منبع لازم نیست، از Paste Special با گزینه Transpose استفاده کنید تا عملکرد فایل بهتر شود.
  • برای ترنسپوز کردن جداول بزرگ و پیچیده همراه با قالب‌بندی، بهتر است از ماکرو استفاده کنید تا قالب‌ها و فرمول‌ها به درستی منتقل شوند.

خلاصه

تابع TRANSPOSE یکی از ابزارهای ساده ولی قدرتمند در اکسل برای جابجایی سطر و ستون است. در نسخه‌های جدید اکسل به صورت دینامیک کار می‌کند و با توابع دیگر ترکیب می‌شود. برای عملیات‌های یک‌بار، Paste Special گزینه مناسبی است و برای اتوماسیون و حفظ فرمول‌ها، VBA کمک‌کننده خواهد بود. با در نظر گرفتن نکات مربوط به اندازه محدوده‌ها، سلول‌های ادغام‌شده و نوع اکسل مورد استفاده، می‌توانید از TRANSPOSE به شکل بهینه بهره ببرید.

آیا این مطلب برای شما مفید بود ؟

خیر
بله
موضوعات شما در انجمن: