我想在excel中通过某列单元格的内容在指定文件夹中查找包含此内容的文件并将文件复制到另一个文件夹中

例如A2单元格内容是111910,我想在指定的文件夹中(D:\8029\)查找文件名包含111910的文件(里边的文件都是类似这样命名的:P-111910-O-0016-... 例如A2单元格内容是111910,我想在指定的文件夹中(D:\8029\)查找文件名包含111910的文件(里边的文件都是类似这样命名的:P-111910-O-0016-S),查找到后将文件名包含111910的文件复制到另一个文件夹(D:\123321\),谢谢!(不懂VBA,要详细点了,谢谢)
您好,如果D:\8029文件夹下还有子文件夹怎么修改代码?
展开
 我来答
mzz9060
推荐于2018-03-22 · TA获得超过1326个赞
知道小有建树答主
回答量:773
采纳率:84%
帮助的人:198万
展开全部

答:复制下面代码到模块,确保图中工作表为活动工作表,运行Demo程序。以下为运行结果截图:

代码:

Dim FindedNames() As String
Dim NumNames As Long
Sub Demo()
    Dim FilePath As String
    Dim FileName As String
    Dim Cell As Range
    
    FilePath = "D:\8029\"
    FileName = "*.*"
    Call ReDir(FilePath, FileName)
    If UBound(FindedNames) < LBound(FindedNames) Then
        MsgBox "文件夹内无文件"
        Exit Sub
    End If
    For Each Cell In Range("A2:A" & Cells(Rows.Count, 1).End(xlUp).Row)
        For i = 0 To UBound(FindedNames)
            If FindedNames(i) Like "*" & Cell & "*" Then
                FileCopy FilePath & "\" & FindedNames(i), "D:\123321\" & FindedNames(i)
                Cell.Offset(0, 1) = "复制成功"
            Else
                Cell.Offset(0, 1) = "没找到相关文件"
            End If
        Next
    Next
End Sub
Public Sub ReDir(ByVal CurrDir As String, ByVal FindName As String)
    Dim Dirs() As String
    Dim NumDirs As Long
    Dim TotalFiles, SingleFile
    Dim TotalFolders, SingleFolder
    Dim fso As Object
    Set fso = CreateObject("scripting.filesystemobject")
    Set TotalFiles = fso.GetFolder(CurrDir).Files
    Set TotalFolders = fso.GetFolder(CurrDir).SubFolders
    If TotalFiles.Count <> 0 Then
        For Each SingleFile In TotalFiles
            If fso.GetFile(SingleFile).Name Like FindName Then
                ReDim Preserve FindedNames(0 To NumNames) As String
                FindedNames(NumNames) = fso.GetFileName(SingleFile)
                NumNames = NumNames + 1
            End If
        Next
    End If
    If TotalFolders.Count <> 0 Then
        For Each SingleFolder In TotalFolders
            ReDim Preserve Dirs(0 To NumDirs) As String
            Dirs(NumDirs) = SingleFolder
            NumDirs = NumDirs + 1
        Next
    End If
    For i = 0 To NumDirs - 1
        Call ReDir(Dirs(i), FindName)
    Next i
End Sub
更多追问追答
追问
您好,如果D:\8029文件夹下还有子文件夹怎么修改代码?谢谢
追答
不用修改,程序已包含该功能。
姓王的wy451

2018-03-06 · TA获得超过48.3万个赞
知道大有可为答主
回答量:8万
采纳率:78%
帮助的人:8959万
展开全部

只有用宏代码才行。运行以下代码能满足要求:

如果一点不懂VBA代码,请分享文件来,我帮你做一个按钮,你只要按下按钮就行了

Sub 复制指定文件()
Dim Ar, I%, S$
Ar = Range("B2").CurrentRegion
For I = 2 To UBound(Ar)
   If Ar(I, 1) <> "" Then
      S = Dir(Ar(2, 4) & "\*-" & Ar(I, 1) & "-*")
      While S <> ""
         FileCopy Ar(2, 4) & "\" & S, Ar(3, 4) & "\" & S
         S = Dir
      Wend
   End If
Next
End Sub
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
百度网友49ea6d8
2018-03-22
知道答主
回答量:1
采纳率:0%
帮助的人:893
展开全部
Dim FindedNames() As String
Dim NumNames As Long
Sub Demo()
Dim FilePath As String
Dim FileName As String
Dim Cell As Range

FilePath = "D:\123\"
FileName = "*.*"
Call ReDir(FilePath, FileName)
If UBound(FindedNames) < LBound(FindedNames) Then
MsgBox "文件夹内无文件"
Exit Sub
End If
For Each Cell In Range("P2:P" & Cells(Rows.Count, 1).End(xlUp).Row)
For i = 0 To UBound(FindedNames)
If FindedNames(i) Like "*" & Cell & "*" Then
FileCopy FindedNames(i), "D:\111\" & Split(FindedNames(i), "\")(UBound(Split(FindedNames(i), "\")))
Cell.Offset(0, 1) = "复制成功"

End If
Next
Next
End Sub
Public Sub ReDir(ByVal CurrDir As String, ByVal FindName As String)
Dim Dirs() As String
Dim NumDirs As Long
Dim TotalFiles, SingleFile
Dim TotalFolders, SingleFolder
Dim fso As Object
Set fso = CreateObject("scripting.filesystemobject")
Set TotalFiles = fso.GetFolder(CurrDir).Files
Set TotalFolders = fso.GetFolder(CurrDir).SubFolders
If TotalFiles.Count <> 0 Then
For Each SingleFile In TotalFiles
If fso.GetFile(SingleFile).Name Like FindName Then
ReDim Preserve FindedNames(0 To NumNames) As String
FindedNames(NumNames) = fso.GetFileName(SingleFile)

FindedNames(NumNames) = SingleFile
'NumNames = NumNames + 1
End If
Next
End If
If TotalFolders.Count <> 0 Then
For Each SingleFolder In TotalFolders
ReDim Preserve Dirs(0 To NumDirs) As String
Dirs(NumDirs) = SingleFolder
NumDirs = NumDirs + 1
Next
End If
For i = 0 To NumDirs - 1
Call ReDir(Dirs(i), FindName)
Next i
End Sub
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式