vba怎么判断文件夹是否存在?

如题所述

VBA中有时要判断文件或文件夹是否存在,为打开文件作准备,这里采用错误机制来判断

代码如下:

Function 文件或文件夹是否存在(全路径 As String) As Boolean

On Error GoTo

EarlyExit

If Not Dir(全路径, vbDirectory) = vbNullString Then

文件或文件夹是否存在 = True

End If

Exit Function

EarlyExit:

文件或文件夹是否存在 = False

End Function

需在说明的是,参数“全路径”要有盘符之类的,呵呵

使用方法与其它函数一样

VBA的操作中,有时要打开一个文件,但要是文件已打开,再次通过程序打开时,会出现错误,因此,在打开文件之前,需在先判断文件是否已打开,下面是判断代码:

Function 文件是否打开(文件名 As

String) As Boolean

On Error Resume Next

文件是否打开 = True

If StrComp(Workbooks(文件名).Name, 文件名, vbTextCompare)  0 Then

文件是否打开 = False

End If

End Function

需要说明的是,参数“文件名”是短文件名(不带路径的文件名)

Function 特殊文件夹路径(文件夹名

As String) As String

Dim WSHShell As Object

Dim lj As String

Set WSHShell =

CreateObject("Wscript.Shell") 

lj = WSHShell.SpecialFolders(文件夹名)

Set WSHShell = Nothing

特殊文件夹路径 = lj

End Function

文件夹名有:

AllUsersDesktop 

AllUsersStartMenu 

AllUsersPrograms 

AllUsersStartup 

Desktop 

Favorites 

Fonts 

MyDocuments 

NetHood 

PrintHood 

Programs 

Recent 

SendTo 

StartMenu 

Startup 

Templates

温馨提示:答案为网友推荐,仅供参考
第1个回答  2019-12-09
如果需要判断的是已知目录和文件名的文件是否打开用Dir函数即可
if Dir("带全路径的文件名") <> "" then
MsgBox "文件存在"
else
MsgBox "文件不存在"
End if

相关了解……

你可能感兴趣的内容

本站内容来自于网友发表,不代表本站立场,仅表示其个人看法,不对其真实性、正确性、有效性作任何的担保
相关事宜请发邮件给我们
© 非常风气网