首頁 專題 excel 深入解析Excel萬金油篩選公式'INDEX-SMALL-IF-ROW”

深入解析Excel萬金油篩選公式'INDEX-SMALL-IF-ROW”

Nov 30, 2022 pm 08:43 PM
excel

本文分享Excel用公式篩選完成一對多查找,是比較經典的excel篩選函數公式自動查找公式資料。

深入解析Excel萬金油篩選公式'INDEX-SMALL-IF-ROW”

總是聽到高手們說有個萬金油公式,可到底什麼是萬金油公式,這個Excel公式又能做什麼?不妨先看看下面這個效果圖:

深入解析Excel萬金油篩選公式INDEX-SMALL-IF-ROW”

這個例子就是一個典型的一對多查找,查找條件是部門,在資料來源內每個部門對應的都是多個數據,萬金油公式最主要的用途就是用來解決一對多查找等一些相對複雜的問題。上面動畫的公式為:

=IFERROR(INDEX($A$2:$D$21,SMALL(IF($C$2:$C$21=$F$2,ROW($1:$20 ),99),ROW(A1)),MATCH(F$3,$A$1:$D$1,0)),"")

看到這個公式,或許很多朋友都會驚嘆:這麼長的公式,看不懂哇!

今天就跟大家一同破解這個看不懂但又很強悍的公式套路,耐心往下看哦…

上面這個公式一共用了六個函數:IFERROR、INDEX 、SMALL、IF、ROW和MATCH,其中的IFERROR和MATCH是本例中輔助性的兩個函數,其餘的四個INDEX-SMALL-IF-ROW就是萬金油公式啦。

因此我們先來學習這個核心部分的原理:

F4單元格的公式為:

=INDEX($A$2:$A$21, SMALL(IF($C$2:$C$21=$F$2,ROW($1:$20),99),ROW(A1)))

深入解析Excel萬金油篩選公式INDEX-SMALL-IF-ROW”

#先從INDEX說起,這個函數基本功能是給一個區域,然後根據對應的行列位置返回查找結果,上圖中INDEX查找的資料區域就是姓名所在的區域$A$2:$A$21。

INDEX函數的基本結構是:INDEX(找出區域,第幾行,第幾列),如果區域是單行或單列的話,後面兩個參數可以省略一個。通俗點說,你拿著電影票去找座位,整個大廳的座位就是區域,第幾排第幾座就是公式中的後面兩個參數,透過這種方式可以準確找到目標位置。

在上面這個例子裡,區域是在一列,所以我們只需要確定每個資料在第幾行就行。

明白這一點的話,我們的重點就該放到INDEX的第二個參數了:

#SMALL(IF($C$2:$C$21=$F$2 ,ROW($1:$20),99),ROW(A1))

深入解析Excel萬金油篩選公式INDEX-SMALL-IF-ROW”

注意看上面這個圖,銷售部一共有四筆記錄,分別在資料區域的第5、8、9和16行(資料區域是從第二行開始)。

因此我們希望公式下拉的時候,INDEX的第二個參數分別是5、8、9和16這四個數字(這一點一定要想明白)。

注意,接下來我們即將接觸到萬金油最核心的部分,請保持高度集中的注意力…

SMALL函數的基本結構:SMALL(一組數,第幾小的數字)

建議自己模擬個簡單的資料來充分理解這個函數,方法如下:

深入解析Excel萬金油篩選公式INDEX-SMALL-IF-ROW”

##在A列輸入一些數字,公式的意思是這列數字中最小的一個,結果是2,很好理解對不對,將公式的第二個參數改成2,再看看結果:

深入解析Excel萬金油篩選公式INDEX-SMALL-IF-ROW”

#倒數第二小的是4。

如果希望繼續得到第三小的數,該怎麼做我想大家都能想到,但是會有個問題,我們只能手動修改第二參數,並不能透過下拉來實現這個參數的變化,如果要想可以下拉的話,第二參數就需要用到ROW函數,也就是這樣修改:

深入解析Excel萬金油篩選公式'INDEX-SMALL-IF-ROW”

ROW函數非常簡單,得到的就是參數的行號,透過這個公式,我們就把A列的資料從小到大排了個序,覺得有意思嗎?

回到我們的萬金油公式,5、8、9和16這四個數字代表什麼意思還記得吧,我們需要用SMALL函數依序得到這四個數字,思路是透過判斷C列是否與F2一致,如果一樣得到行號,如果不一樣,就得到一個比最大行號還大的數字(目的是為了防止被查找到):

深入解析Excel萬金油篩選公式'INDEX-SMALL-IF-ROW”

要達成這個目的,就需要IF函數的介入,於是就有了:

IF($C$2:$C$21=$F$2,ROW($1:$20),99),用這一段作為SMALL的第一個參數。

關於這段IF,就比較容易理解了,我們可以藉助F9來看看這段公式的結果:

深入解析Excel萬金油篩選公式'INDEX-SMALL-IF-ROW”

因為我們的數據就20個,所以IF的第三個參數使用99就足夠了,如果數據量比較大的話,可以用9^9,表示9的9次方,反正足夠大就行。

搞清楚這個IF的話,再來看這段SMALL(IF($C$2:$C$21=$F$2,ROW($1:$20),99),ROW(A1)) 是不是就沒那麼暈了。

關於SMALL這部分,一定要明白是隨著公式下拉的時候,逐一得到我們希望得到的那幾個數字,然後用這些數字作為INDEX的第二參數,就可以得到最終需要的結果。

萬金油的核心就是INDEX、SMALL、IF和ROW,請大家務必反覆琢磨,把這部分原理搞清楚。還有非常重要的一點要強調,萬金油公式是一個陣列公式,因此需要我們按下Ctrl和shift再回車。

至於一開始的公式,考慮到要找多列的內容,所以INDEX的資料區域用的$A$2:$D$21,多列的時候,就需要提供列位置才能找到目標值,因此用MATCH(F$3,$A$1:$D$1,0)來決定資料在第幾列。

每個部門的資料都不一樣多,我們需要將公式多向下拉幾行,這時候就會產生一些錯誤值,在公式的最外層使用IFERROR函數屏蔽了錯誤值,使得查詢結果看起來非常乾淨。

今天只是使用了一對多查找這樣一個例子來解釋萬金油公式的原理,實際上萬金油的套路還有很多,大家喜歡的話以後繼續分享相關的實例,當然,如果看完本文的話能夠自己去解讀一些複雜的公式就更好了。

相關學習推薦:excel教學

以上是深入解析Excel萬金油篩選公式'INDEX-SMALL-IF-ROW”的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

excel列印表格框線消失怎麼辦 excel列印表格框線消失怎麼辦 Mar 21, 2024 am 09:50 AM

如果在開啟一份需要列印的文件時,在列印預覽裡我們會發現表格框線不知為何消失不見了,遇到這樣的情況,我們就要及時進行處理,如果你的列印文件裡也出現了此類的問題,那麼就和小編一起來學習下邊的課程吧:excel列印表格框線消失怎麼辦? 1.開啟一份需要列印的文件,如下圖所示。  2、選取所有需要的內容區域,如下圖所示。  3、按滑鼠右鍵,選擇「設定儲存格格式」選項,如下圖所示。  4、點選視窗上方的「邊框」選項,如下圖所示。  5、在左側的線條樣式中選擇細實線圖樣,如下圖所示。  6、選擇“外邊框”

excel同時篩選3個以上關鍵字怎麼操作 excel同時篩選3個以上關鍵字怎麼操作 Mar 21, 2024 pm 03:16 PM

在日常辦公中經常使用Excel來處理數據,時常遇到需要使用「篩選」功能。當我們在Excel中選擇執行「篩選」時,對於同一列而言,最多只能篩選兩個條件,那麼,你知道excel同時篩選3個以上關鍵字該怎麼操作嗎?接下來,就請小編為大家示範一次。第一種方法是將條件逐步加入篩選器。如果要同時篩選出三個符合條件的明細,首先需要逐步篩選出其中一個。開始時,可以先依照條件篩選出姓「王」的員工。然後按一下【確定】,接著在篩選結果中勾選【將目前所選內容新增至篩選器】。操作步驟如下圖所示。  同樣,再次分別執行篩選

excel表格相容模式改正常模式的方法 excel表格相容模式改正常模式的方法 Mar 20, 2024 pm 08:01 PM

在我們日常的工作學習中,從他人處拷貝了Excel文件,打開進行內容添加或重新編輯後,再保存的有時候,有時會提示出現兼容性檢查的對話框,非常的麻煩,不知道Excel軟體,可不可改為正常模式呢?那麼下面就由小編為大家帶來解決這個問題的詳細步驟,讓我們一起來學習吧。最後一定記得收藏保存。 1.開啟一個工作表,在工作表的名稱中顯示多出來一個相容模式,如圖所示。 2.在這個工作表中,進行了內容的修改後保存,結果總是彈出兼容檢查器的對話框,很麻煩看見這個頁面,如圖所示。  3、點選Office按鈕,點另存為,然

excel下標怎麼打出來 excel下標怎麼打出來 Mar 20, 2024 am 11:31 AM

e我們常常會用excel來製作一些資料表之類的,有時在輸入參數數值時需要對某個數字進行上標或下標,例如數學公式就會常用到,那麼excel下標怎麼打出來呢?我們一起來看看詳細操作步驟:一、上標方法:1、先Excel中輸入a3(3為上標)。 2、選取數字“3”,右鍵選擇“設定儲存格格式”。 3、點選“上標”,然後“確定”即可。 4、看,效果就是這樣的。二、下標方法:1、與上標設定方法類似,在儲存格中輸入“ln310”(3為下標),選取數字“3”,並右鍵選擇“設定儲存格格式”。 2、勾選“下標”,點選“確定

excel上標應該如何設定 excel上標應該如何設定 Mar 20, 2024 pm 04:30 PM

在處理資料時,有時我們會遇到資料包含了倍數、溫度等等各種符號的時候,你知道excel上標應該如何設定嗎?我們在使用excel處理資料時,如果不會設定上標,這可是會讓我們的許多資料在輸入時就會比較麻煩。今天小編就為大家帶來了excel上標的具體設定方法。 1.首先,讓我們打開桌面上的MicrosoftOfficeExcel文檔,選擇需要修改為上標的文字,具體如圖所示。 2.然後,點擊右鍵,點擊後出現的選單中,選擇「設定儲存格格式」選項,具體如圖所示。 3.接下來,在系統自動彈出的「儲存格格式」對話框

excel中iif函數的用法 excel中iif函數的用法 Mar 20, 2024 pm 06:10 PM

大部分使用者使用Excel都是用來處理表格資料的,其實Excel還有vba程式編寫,這個除了專人士應該沒有多少使用者用過此功能,在vba編寫時常常會用到iif函數,它其實跟if函數的功能差不多,下面小編跟大家介紹下iif函數的用法。 Excel中SQL語句和VBA程式碼中都有iif函數。 iif函數和excel工作表中的IF函數用法相似,執行真假值判斷,根據邏輯計算的真假值,傳回不同結果。 IF函數用法是(條件,是,否)。 VBA中的IF語句和IIF函數,前者IF語句是控制語句可以依照條件執行不同的語句,後者

excel閱讀模式在哪裡設置 excel閱讀模式在哪裡設置 Mar 21, 2024 am 08:40 AM

在軟體的學習中,我們習慣用excel,不僅是因為需要方便,更因為它可以滿足多種實際工作中需要的格式,而且excel運用起來非常的靈活,有種模式是方便閱讀的,今天帶給大家的就是:excel閱讀模式在哪裡設定。 1.開啟電腦,然後再開啟Excel應用,找到目標資料。 2.要想在Excel中,設定閱讀模式,有兩種方式。第一種:Excel中,有大量的便利處理方式,分佈在Excel中佈局中。在Excel的右下角,有設定閱讀模式的快捷方式,找到十字標誌的圖案,點擊即可進入閱讀模式,在十字標誌的右邊有一個小的三

PPT幻燈片插入excel圖示的操作方法 PPT幻燈片插入excel圖示的操作方法 Mar 26, 2024 pm 05:40 PM

1.開啟PPT,翻頁至需要插入excel圖示的頁面。點選插入選項卡。 2、點選【對象】。 3、跳出以下對話框。 4.點選【由檔案建立】,點選【瀏覽】。 5、選擇需要插入的excel表格。 6.點選確定後跳出如下頁面。 7.勾選【顯示為圖示】。 8.點選確定即可。

See all articles