The TOCOL function is the fastest way to convert any rectangular range or spilled array into one tidy column that updates automatically. It belongs to Excel’s dynamic array family and is available in Microsoft 365 on Windows, Mac, and the web. The core idea is simple: take values laid out across rows and columns and return them in a single vertical list, in the order you choose, with options to ignore blanks and errors. Microsoft defines the syntax as =TOCOL(array, [ignore], [scan_by_column]), where array is the source range or array, ignore tells Excel which values to drop during the flatten, and scan_by_column controls whether values are read row-wise or column-wise. By default, Excel scans by row and keeps everything, but both behaviors are configurable for cleaner outputs.
Think of TOCOL as the inverse of WRAPROWS or WRAPCOLS. Instead of turning a list into a grid, TOCOL turns a grid into a list. This simple transformation solves many everyday problems. When data arrives in a crosstab layout, TOCOL can create a long-form list that works better with PivotTables, charts, Power Query, and lookups. When modelers collect values from scattered blocks, TOCOL can unify them in a single, filterable column for analysis. And because TOCOL spills, the result grows or shrinks automatically with the source—no VBA, no helper sheets, no copy-paste.
The ignore argument is where TOCOL becomes a data-cleaning tool. Microsoft’s documentation specifies numeric options: 0 keeps all values, 1 ignores blanks, 2 ignores errors, and 3 ignores both blanks and errors. For example, =TOCOL(A2:D20,1) will exclude true empty cells from the resulting list, which is ideal for building validation lists or distinct lists via UNIQUE without carrying forward gaps. If imported data contains errors like #N/A, use =TOCOL(A2:D20,3) to drop both blanks and errors for a clean downstream pipeline. These behaviors are consistent across versions that support the function and are highlighted in Microsoft’s examples and independent tutorials alike.
Order control is the other key lever. By default, TOCOL scans by row—left to right across the first row, then continues on the next row, and so on. If the desired order is top to bottom down the first column, then down the second, set scan_by_column to TRUE or 1. A formula like =TOCOL(A2:D20,,TRUE) reads the range column-wise, producing a list that preserves the visual order users expect in column-major scenarios. This is especially useful when the range contains time series by column and a column-wise consolidation aligns with later calculations or charting. Microsoft’s reference calls out scan_by_column explicitly and shows how the same source returns different sequences depending on this switch.
Real-world patterns make TOCOL indispensable. To normalize a multi-column input into a single-column validation list, pair TOCOL with UNIQUE and SORT: =SORT(UNIQUE(TOCOL(InputRange,1))). This drops blanks, removes duplicates, and orders results—perfect for data validation dropdowns, slicer source lists, or dimensional cleanup before a merge. To prepare a crosstab for Pivot analysis, flatten with TOCOL and add labels via helper columns, or better, use MAKEARRAY or MAP for structured reshaping—yet in many cases, the simplest pipeline is to TOCOL, then split or tag as needed. To consolidate scattered metrics for a KPI audit, wrap disjoint ranges in a single array using parentheses and commas, then feed to TOCOL, for example =TOCOL((B3:B12, F3:F15, J3:J20), 3). Tutorials demonstrate that TOCOL happily consumes array expressions and that combining inputs in one call avoids staging helpers.
Edge behaviors are predictable and easy to manage. If the result would exceed sheet size, Excel returns #NUM, which is a cue to constrain the source or filter first. If the array contains numbers in an array constant that aren’t whole numbers, some builds will throw #VALUE as Microsoft notes. For blanks, remember that “blank” means truly empty; cells that return “” from formulas are not considered blank for the ignore setting and will be kept unless filtered out upstream. Independent guides point this out when explaining why some “empty-looking” cells still appear in the output. When building public-facing blocks, consider wrapping the final output in IFERROR or substituting placeholders downstream if necessary, though in most cases TOCOL’s ignore options suffice for clean lists.
Because TOCOL returns a spill, placement matters. Insert the formula in a cell with sufficient free space below. If you see #SPILL, clear obstructing content or remove merges in the destination area. For interactive sheets, it often helps to define the source as an Excel Table; when users add or remove rows, TOCOL updates automatically, and follow-on functions like UNIQUE and SORT stay in sync. If the flattened list needs to feed a fixed-size range (for chart feeds or exports), follow with EXPAND to pad to a known length while filling extras with “” or “-“, maintaining stable dimensions without cutting the pipeline upstream.
One of the most productive compositions is TOCOL with FILTER and SORTBY. Filter first to keep relevant items, flatten with TOCOL, sort by a measure if needed, and then TAKE the top N for compact, dynamic panels. Another powerful pair is TOCOL and TEXT functions: TOCOL first to build a clean list, then TEXTSPLIT or TEXTAFTER/TEXTBEFORE to parse, followed by MAP/SCAN when row-wise transformations are needed at scale. While Power Query excels for heavier ETL, TOCOL covers a surprising number of reshape tasks directly in the grid with minimal overhead and easy auditability.
Compared to legacy methods, TOCOL saves time and clarifies intent. Old approaches to flattening—like INDEX with ROW/COLUMN arithmetic or copy-paste transforms—are brittle and opaque. With TOCOL, the formula reads like a sentence: “take this array, ignore blanks and errors, scan by columns”. That readability reduces onboarding friction and mistakes, especially in shared models.
If adopting TOCOL as a standard tool, settle on a few conventions. Use ignore=3 when building clean lists unless blanks or errors have semantic meaning. Decide on scan order based on how downstream steps interpret sequence. Prefer Tables as sources for auto-expansion. And document the intent in a nearby note, especially when the flattening step is part of a larger modeling pipeline. With those habits, TOCOL becomes a reliable, low-friction way to turn any 2D block into a 1D list that “just works”, ready for validation, lookups, charts, and analysis.

