Board logo

標題: [發問] 如何用函數依條件篩選出不重複的資料 [打印本頁]

作者: zheng211016    時間: 2017-11-26 21:36     標題: 如何用函數依條件篩選出不重複的資料

本帖最後由 zheng211016 於 2017-11-26 21:38 編輯

如題
[attach]28031[/attach]
想要有類似圖片上這種功能
請問各位大大有什麼辦法
[attach]28030[/attach][attach]28030[/attach]
作者: joblyc017    時間: 2017-11-27 10:55

回復 1# zheng211016


    陣列公式,故完成輸入後,請按下組合鍵CTRL+SHIFT+ENTER
[attach]28033[/attach]
作者: zheng211016    時間: 2017-11-27 15:38

回復 2# joblyc017

感謝 高手相助
作者: hcm19522    時間: 2017-11-27 16:23

http://blog.xuite.net/hcm19522/twblog/548342617
作者: zheng211016    時間: 2017-11-28 19:22

回復 4# hcm19522


  感謝大大 您的方法也很好 感謝用心指教
作者: Andy2483    時間: 2023-6-8 15:59

本帖最後由 Andy2483 於 2023-6-8 16:16 編輯

謝謝論壇,謝謝各位前輩
後學藉此帖練習陣列與字典,學習方案如下,請各位前輩指教

執行前:
[attach]36557[/attach]

執行結果:
[attach]36558[/attach]


Option Explicit
Sub TEST()
Dim Brr, Crr, Z, i&, R&, C%, M&, T$
'↑宣告變數
Set Z = CreateObject("Scripting.Dictionary")
'↑令Z變數是 字典
Brr = Range([C2], [A65536].End(3))
'↑令Brr變數是 二維陣列,以A~C欄儲存格值帶入
ReDim Crr(1 To UBound(Brr), 1 To 100)
'↑令Crr變數是 二維空陣列,縱向範圍同Brr陣列,橫向範圍1~100
For i = 1 To UBound(Brr)
'↑設順迴圈
   T = Brr(i, 3)
   '↑令T變數裝入第3欄迴圈陣列值,一方面定義為字串,另一好處是縮短後方程式碼
   If Z(T) = "" Then C = C + 1: Z(T) = C: Crr(1, C) = T: Z(T & "|r") = 1
   '↑將首次納入Z字典的 站點key依序佈在Crr陣列第1列,
   '並令Z字典記住 這站點key是在Crr陣列的哪個欄位,
   'Z(T & "|r") = 1是為了標題列讓出1列

   R = Z(T & "|r") + 1: Z(T & "|r") = R
   Crr(R, Z(T)) = Brr(i, 1)
   '↑不管 站點key是不是首次納入Z字典,都應該將 批號寫入Crr對應key的欄位下
   If M < R Then M = R
   '↑這是要判定Crr陣列要寫入儲存格時,需要多少列數
Next
[E:IV].ClearContents
'↑清除結果欄內容
[E1].Resize(M, C) = Crr
'↑從[E1]開始的範圍寫入Crr陣列值
Set Z = Nothing: Erase Brr
'↑令釋放變數
End Sub
作者: Andy2483    時間: 2023-6-8 16:16

謝謝論壇,謝謝各位前輩
後學延伸學習統計各站點物品數量合計,學習方案如下,請各位前輩指教

執行結果:
[attach]36559[/attach]


Option Explicit
Sub TEST_1()
Dim Brr, Crr, Z, i&, R&, C%, M&, T$
'↑宣告變數
Set Z = CreateObject("Scripting.Dictionary")
'↑令Z變數是 字典
Brr = Range([C2], [A65536].End(3))
'↑令Brr變數是 二維陣列,以A~C欄儲存格值帶入
ReDim Crr(1 To 2, 1 To 100)
'↑令Crr變數是 二維空陣列,縱向範圍1~2,橫向範圍1~100
For i = 1 To UBound(Brr)
'↑設順迴圈
   T = Brr(i, 3)
   '↑令T變數裝入第3欄迴圈陣列值
   If Z(T) = "" Then C = C + 1: Z(T) = C: Crr(1, C) = T
   '↑將首次納入Z字典的 站點key依序佈在Crr陣列第1列,
   '並令Z字典記住 這站點key是在Crr陣列的哪個欄位

   Crr(2, Z(T)) = Crr(2, Z(T)) + Brr(i, 2)
   '↑不管 站點key是不是首次納入Z字典,都應該將數量 加入Crr對應key的欄位下
Next
[E1:IV2].ClearContents
'↑清除結果欄內容
[E1].Resize(2, C) = Crr
'↑從[E1]開始的範圍寫入Crr陣列值
Set Z = Nothing: Erase Brr
'↑令釋放變數
End Sub




歡迎光臨 麻辣家族討論版版 (http://forum.twbts.com/)