返回列表 上一主題 發帖

[發問] 請問如何在"文字方塊"輸入條件後再去搜尋資料

回復 6# 蝕光迴狼
對話框 試試看
  1. Sub Ex()
  2.     With Application.FileDialog(msoFileDialogFolderPicker) '開啟資料夾的對話框
  3.         If .Show = True Then
  4.          If MsgBox(.SelectedItems(1) & "  中搜尋 *" & TextBox3, vbYesNo) = vbYes Then
  5.             If Dir("D:\自創資料夾", vbDirectory) = "" Then MkDir ("D:\自創資料夾") '自創資料夾不存在則建立
  6.             TextBox1 = .SelectedItems(1)
  7.             副程式 .SelectedItems(1)
  8.          End If
  9.        End If
  10.     End With
  11. End Sub
  12. Private Sub 副程式(資料夾 As String)
  13.     Dim Fs As Object, F As Object
  14.     Set Fs = CreateObject("Scripting.FileSystemObject")
  15.     If Dir(資料夾 & "\*" & TextBox3 & "*") <> "" Then '測試關鍵字檔名是否存在
  16.         Fs.copyfile 資料夾 & "\*" & TextBox3 & "*", "D:\自創資料夾"
  17.     End If
  18.    
  19.     '*** 如資料夾下有子資料夾 再呼叫這副.程式 ***
  20.     '呼叫 程式的迴圈
  21.     For Each F In Fs.GetFolder(資料夾).SUBFolderS
  22.         Debug.Print F  '可看一下 子資料夾名稱
  23.         副程式 F & ""
  24.     Next
  25. End Sub
複製代碼
感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

回復 8# 蝕光迴狼
   
3. 有個地方不明白,執行後並不會依關鍵字去複製檔案,反而複製資料夾底下全部的檔案。
  1. 10.fs = Dir(fd & "*" & ML3 & "*") '測試關鍵字檔名是否存在
  2. 11.  If fs <> "" Then    '這裡判斷有關鍵字檔名的檔案
  3. '*** 不會複製資料夾底下全部的檔案 ****
複製代碼
ML3 = Range("E7") '搜尋檔案關鍵字
會是Range("E7")中沒有字串,???造成的嗎?
  1. Option Explicit
  2. '模組上端的 Dim (宣告變數為這模組的私用變數),僅這模組的程序可使用
  3. Dim gb As String, fsd As Object, ML3 As String
  4. Private Sub CommandButton1_Click()
  5. '程序中的 Dim (宣告變數為這程序的私用變數,僅這程序中可使用)
  6. Dim fd As String, dm As String, ML1 As String, ML2 As String
  7.     dm = "D:\測試用\" '搜尋主路徑
  8.     ML1 = Range("E3") '搜尋檔案資料夾目錄一
  9.     ML2 = Range("E5") '搜尋檔案資料夾目錄二
  10.     ML3 = Range("E7") '搜尋檔案關鍵字
  11.     gb = "D:\" & ML3 & "\" '存檔位置
  12.     Set fsd = CreateObject("Scripting.FileSystemObject")
  13.     fd = dm & ML1 & "\" & ML2 & "\" '檔案資料夾位置
  14.     If fsd.folderexists(gb) = False Then fsd.createfolder gb '自創資料夾不存在則建立
  15.     副程式 fd
  16. End Sub
  17. Private Sub 副程式(資料夾 As String)
  18.     Dim F As Object
  19.     Debug.Print 資料夾  '可看一下 子資料夾名稱
  20.     If Dir(資料夾 & "\*" & ML3 & "*") <> "" Then '測試關鍵字檔名是否存在
  21.         fsd.copyfile 資料夾 & "\*" & ML3 & "*", gb
  22.     End If
  23.     '*** 如資料夾下有子資料夾 再呼叫這副.程式 ***
  24.     '呼叫 程式的迴圈
  25.     For Each F In fsd.GetFolder(資料夾).SUBFolderS
  26.         副程式 F & ""
  27.     Next
  28. End Sub
複製代碼
感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

回復 11# 蝕光迴狼


   
但不知道怎麼運用
你要做何事?
感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

本帖最後由 GBKEE 於 2014-10-3 19:33 編輯

回復 13# 蝕光迴狼
是這樣嗎?
  1. '//**********************************//
  2.     ChDir gb   '改變目前的目錄或檔案夾
  3.     With Application.FileDialog(msoFileDialogFilePicker)
  4.         .Show
  5.     End With
  6.    '//**********************************//
複製代碼
還是如此
  1. '//**********************************//
  2.     Dim e As Variant
  3.     ChDir gb   '改變目前的目錄或檔案夾
  4.     With Application.FileDialog(msoFileDialogFilePicker)
  5.         If .Show = True Then
  6.             For Each e In .SelectedItems
  7.                 Workbooks.Open e
  8.             Next
  9.         End If
  10.     End With
  11.    '//**********************************//
複製代碼
感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

回復 15# 蝕光迴狼
  1. Option Explicit
  2. Sub Ex()
  3.     Dim gb As String
  4.     gb = "D:\關鍵字"  '存檔位置
  5.     Shell "explorer  " & gb, vbMaximizedFocus
  6.     '"explorer  "空一格 + (連接上)要開啟的資料夾 或 檔案
  7.     '參數:vbMaximizedFocus,請參考 Shell 函數的說明
  8. End Sub
複製代碼
感恩的心......(在麻辣家族討論區.用心學習會有進步的)
但資源無限,後援有限,  一天1元的贊助,人人有能力.

TOP

        靜思自在 : 謊言像一朵盛開的鮮花,外表美麗,生命短暫。
返回列表 上一主題