返回列表 上一主題 發帖

[發問] 利用下拉式選單選取資料,並進行進階篩選

[發問] 利用下拉式選單選取資料,並進行進階篩選

各位大大們:

想請問一下,我想用工作表1的這些資料,利用"醫師代碼"這個欄位做出下拉式選單,
選出之後希望呈現狀態如工作表2一樣,並且B欄位與E欄位進行進階篩選(不重複),選取在G與I欄位上,第J欄位是計算公式,這些作法如何用VBA呈現?

由於實際資料較為龐大,如用手動篩選工程浩大,故希望直接用VBA的語法去執行它,希望各位高手們幫忙!!! 感激不盡~~~

上傳用.zip (8.95 KB)

本帖最後由 Hsieh 於 2014-7-25 10:59 編輯

回復 1# Duck

不重複定義是否B&D不重複?
play.gif
2014-7-25 10:54

如果是的話
插入自訂表單,布置一個下拉清單
表單模組中程式碼如下
  1. Private Sub ComboBox1_Change()
  2. Set d = CreateObject("Scripting.Dictionary")
  3. With 工作表2
  4. Set Rng = 工作表2.[A1]
  5. .[A:E].Clear
  6. With 工作表1
  7.    With .Range("A1").CurrentRegion
  8.       .AutoFilter 4, ComboBox1
  9.       .SpecialCells(xlCellTypeVisible).Copy Rng
  10.       .AutoFilter
  11.    End With
  12. End With
  13. mystr = "=COUNTIF(C5,RC9)/(COUNTA(C7)-1)"
  14. For Each a In .Range(.[B2], .[B1].End(xlDown))
  15.     d(a & a.Offset(, 3)) = Array(a, "", a.Offset(, 3))
  16. Next
  17. .Range("G1").CurrentRegion.Offset(1).ClearContents
  18. .[G2].Resize(d.Count, 3) = Application.Transpose(Application.Transpose(d.items))
  19. .[J2].Resize(d.Count, 1).FormulaR1C1 = mystr
  20. .[H2] = d.Count
  21. End With
  22. Unload Me
  23. End Sub

  24. Private Sub UserForm_Initialize()
  25. Set d = CreateObject("Scripting.Dictionary")
  26. With 工作表1
  27.    For Each a In .Range(.[D2], .[D2].End(xlDown))
  28.       d(a.Text) = ""
  29.    Next
  30. End With
  31. ComboBox1.List = d.keys
  32. End Sub
複製代碼
上傳用.zip (28.34 KB)
學海無涯_不恥下問

TOP

感謝高手的襄助,但不好意思我沒把問題說清楚,我是希望第B欄位選取不重復至G欄位,第E欄位選取不重復至J欄位,是它們各自選取不重複,抱歉~ 語意沒說好....

另外,我想再請教一下,不知道語法是否可以執行說,我想先在A欄位選取不重複至L欄位,則M欄位可以去自動計算出,L欄位的每個一項目他們在B欄位不重複出現的次數是幾次?!

如下圖所示,我可以在L欄位裡的"19168"這個項目中計算出他分別有2013061011226和2013061011470這兩筆紀錄,故是在M欄位計算出現了2次,不知是否可以執行?



煩請高手能解救在下...感激不盡~~
未命名.png

TOP

回復 2# Hsieh

抱歉~由於忘記案回覆,故在重新發一篇~


感謝高手的襄助,但不好意思我沒把問題說清楚,我是希望第B欄位選取不重復至G欄位,第E欄位選取不重復至J欄位,是它們各自選取不重複,抱歉~ 語意沒說好....


另外,我想再請教一下,不知道語法是否可以執行說,我想先在A欄位選取不重複至L欄位,則M欄位可以去自動計算出,L欄位的每個一項目他們在B欄位不重複出現的次數是幾次?!

如下圖所示,我可以在L欄位裡的"19168"這個項目中計算出他分別有2013061011226和2013061011470這兩筆紀錄,故是在M欄位計算出現了2次,不知是否可以執行?



煩請高手能解救在下...感激不盡~~
未命名.png

TOP

回復 2# Hsieh


    Hsieh 您好:

不知我的問題是否描述有讓你不清楚的地方嗎? 哪個部分不瞭解,我可以再加以說明,希望你能幫幫我這個vba初學者~ 萬分感激 :)

TOP

回復 2# Hsieh


您好,這個程式跑出來工作表2的G欄位與I欄位還是"各自"還是會出現重複的情形,請問語法要如何修改,才會它們欄位是出現各自不重複的情況??


跪求大師幫忙~~~~:dizzy:

TOP

回復 6# Duck
  1. Private Sub ComboBox1_Change()
  2. Set d = CreateObject("Scripting.Dictionary")
  3. Set d1 = CreateObject("Scripting.Dictionary")
  4. Set d2 = CreateObject("Scripting.Dictionary")
  5. Set d3 = CreateObject("Scripting.Dictionary")
  6. d2("CHT_IDX") = "B欄不重複數" 'L:M的欄位名稱"
  7. d3("CHT_IDX") = "B欄不重複數"
  8. With 工作表2
  9. Set Rng = 工作表2.[A1]
  10. .[A:E].ClearContents '清除之前篩選結果
  11. With 工作表1
  12.    With .Range("A1").CurrentRegion
  13.       .AutoFilter 4, ComboBox1 '依據下拉選單篩選資料
  14.       .SpecialCells(xlCellTypeVisible).Copy Rng '將篩選結果複製到第二工作表
  15.       .AutoFilter '取消篩選
  16.    End With
  17. End With
  18. mystr = "=COUNTIF(C5,RC9)/(COUNTA(C7)-1)" 'J欄公式
  19. For Each a In .Range(.[B2], .[B1].End(xlDown)) 'B欄資料做迴圈
  20.     d(a.Value) = "" '儲存DATESEQ不重複清單
  21.     d1(a.Offset(, 3).Value) = "" '儲存PRICE_NAME不重複清單
  22.     d3(a.Offset(, -1).Value) = _
  23.     IIf(InStr(d3(a.Offset(, -1).Value), a) = 0, d3(a.Offset(, -1).Value) & ";" & a, d3(a.Offset(, -1).Value)) '以A欄為索引,若未含B欄字串,則以分號;連結B欄字串
  24.     d2(a.Offset(, -1).Value) = UBound(Split(d3(a.Offset(, -1).Value), ";")) '以分號切割字串,計算出陣列元素數量,即為同CHT_IDX的不重複B欄數量
  25. Next
  26. .Range("G1").CurrentRegion.Offset(1).ClearContents
  27. .[L:M].ClearContents '清除L:M欄
  28. '寫入G:M欄
  29. .[G2].Resize(d.Count, 1) = Application.Transpose(d.Keys)
  30. .[I2].Resize(d1.Count, 1) = Application.Transpose(d1.Keys)
  31. .[L1].Resize(d3.Count, 1) = Application.Transpose(d3.Keys)
  32. .[M1].Resize(d2.Count, 1) = Application.Transpose(d2.items)
  33. .[J2].Resize(d1.Count, 1).FormulaR1C1 = mystr
  34. .[H2] = d.Count
  35. End With
  36. Unload Me '卸載表單
  37. End Sub
複製代碼
學海無涯_不恥下問

TOP

回復 7# Hsieh


    感謝高手的襄助! 可以成功執行了~~~ 謝謝!!!

TOP

thanks ,又學習到了

TOP

謝謝版主,這份資料也讓我解決我的問題並且學到很多!!!!

TOP

        靜思自在 : 欣賞別人就是莊嚴自己。
返回列表 上一主題