返回列表 上一主題 發帖

VBA 抓取ListBox中的內容

回復 36# samwang
測試過了,沒問題
非常感謝大大,一直麻煩你,辛苦了

TOP

回復 36# samwang
大大,抱歉,我又有麻煩了
如果開啟表單後要直接把機1,機2叫出來在ListBox上呢,等於不要有選擇資料夾這步驟

TOP

回復 40# samwang
那如果直接把機1、機2那個資料夾當預設的資料夾呢?

TOP

回復 42# samwang
因為機1,機2是我抓出來當範例用,之後如果完成還會加入更多
那如果資料夾的路徑是固定的,檔案也都固定放在資料夾裏的話呢?

TOP

回復 44# samwang
Application.ScreenUpdating = False
Application.DisplayAlerts = False
Application.AskToUpdateLinks = False
fileorg = ActiveWorkbook.Name
Set xD = CreateObject("Scripting.Dictionary")
For i1 = 1 To n1
    If Not xD.Exists(Ar(i1, 1) & "") Then
        xD(Ar(i1, 1) & "") = ""
        For i = 1 To n
            If Arr(i, 2) = Ar(i1, 1) Then n2 = n2 + 1: Ar1(n2, 1) = Arr(i, 1)
        Next
    End If
Next
R = 1: Sheets("6月份數據").Select
With Sheets("6月份數據")
    If .FilterMode Then .ShowAllData
    .Range("a1:AA" & .[a65536].End(3).Row).Delete
    Tm = Timer
    For i1 = 1 To n2
        Set WB = Workbooks.Open(Ar1(i1, 1))
        With Sheets("6月份數據")
            If .FilterMode Then .ShowAllData
            fn = Split(ActiveWorkbook.Name, ".")(0)
            .Range("a1:z" & .[a65536].End(3).Row).Copy Workbooks(fileorg).Sheets("6月份數據").Range("a" & R)
        End With
        WB.Close
        .Range("U" & R & ":U" & .[a65536].End(xlUp).Row) = fn
        R = .[a65536].End(xlUp).Row + 1
    Next
End With
MsgBox "資料複製完成" & Timer - Tm & "秒"
Erase Arr: Erase Ar
Unload Me

Application.ScreenUpdating = True
Application.DisplayAlerts = True
Application.AskToUpdateLinks = True

複製資料的時候
Set WB = Workbooks.Open(Ar1(i1, 1))
這行出現了錯誤

TOP

回復 45# wang077
找到錯誤了,剛剛把程式檔放再同一個資料夾,所以出現錯誤
以解決這錯誤

TOP

本帖最後由 wang077 於 2021-7-7 10:40 編輯

回復 44# samwang
Private Sub ListBox1_DblClick(ByVal Cancel As MSForms.ReturnBoolean)
Application.ScreenUpdating = False
Application.DisplayAlerts = False
Application.AskToUpdateLinks = False
fileorg = ActiveWorkbook.Name
Set xD = CreateObject("Scripting.Dictionary")
For i1 = 1 To n1
    If Not xD.Exists(Ar(i1, 1) & "") Then
        xD(Ar(i1, 1) & "") = ""
        For i = 1 To n
            If Arr(i, 2) = Ar(i1, 1) Then n2 = n2 + 1: Ar1(n2, 1) = Arr(i, 1)
        Next
    End If
Next
R = 1: Sheets("6月份數據").Select
With Sheets("6月份數據")
    If .FilterMode Then .ShowAllData
    .Range("a1:AA" & .[a65536].End(3).Row).Delete
    Tm = Timer
    For i1 = 1 To n2
        Set WB = Workbooks.Open(Ar1(i1, 1))
        With Sheets("6月份數據")
            If .FilterMode Then .ShowAllData
            fn = Split(ActiveWorkbook.Name, ".")(0)
            .Range("a1:z" & .[a65536].End(3).Row).Copy Workbooks(fileorg).Sheets("6月份數據").Range("a" & R)
        End With
        WB.Close
        .Range("U" & R & ":U" & .[a65536].End(xlUp).Row) = fn
        R = .[a65536].End(xlUp).Row + 1
    Next
End With
MsgBox "資料複製完成" & Timer - Tm & "秒"
Erase Arr: Erase Ar

Application.ScreenUpdating = True
Application.DisplayAlerts = True
Application.AskToUpdateLinks = True
End Sub

   


大大,我把複製資料的程式碼丟進去ListBox1_DblClick裡面
可以直接選取ListBox來叫出資料,但我如果第一次點擊機1可以叫出機1的資料,我第二次點擊機2的時候
他又顯示這錯誤了
求解!

TOP

回復 47# s3526369
此問題已解決
感謝分享

TOP

回復 50# samwang
彙整_0707.zip (117.42 KB)
新增資料夾.zip (407.42 KB)
麻煩大大了

TOP

回復 52# samwang
我後來直接在dbl_Click
下了Unload
再下show
把form重新show一次
就可以了
可以一次多選,選完2個機台後在listbox裡的空白處點兩下就好了

TOP

        靜思自在 : 君子為目標,小人為目的。
返回列表 上一主題