亚洲在线久爱草,狠狠天天香蕉网,天天搞日日干久草,伊人亚洲日本欧美

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

請問VBA則怎么檢查文件是否存在

請問VBA則怎么檢查文件是否存在

暮色呼如 2019-11-03 08:04:56
我有這個代碼。應該檢查文件是否存在,如果存在則將其打開。如果文件存在,它確實可以工作,但是如果不存在,則每當我將文本框保留為空白并單擊提交按鈕時,它都會失敗。我想要的是,如果文本框為空,則顯示錯誤消息,就像文件不存在一樣。運行時錯誤“ 1004”Dim File As StringFile = TextBox1.ValueDim DirFile As StringDirFile = "C:\Documents and Settings\Administrator\Desktop\" & FileIf Dir(DirFile) = "" Then  MsgBox "File does not exist"Else    Workbooks.Open Filename:=DirFileEnd If
查看完整描述

3 回答

?
鴻蒙傳說

TA貢獻1865條經驗 獲得超7個贊

像這樣的東西


最好使用工作簿變量來提供對打開的工作簿的進一步控制(如果需要)


已更新以測試文件名是實際的工作簿-這也使初始檢查變得多余,除了向用戶發送消息以外,文本框為空


Dim strFile As String

Dim WB As Workbook

strFile = Trim(TextBox1.Value)

Dim DirFile As String

If Len(strFile) = 0 Then Exit Sub


DirFile = "C:\Documents and Settings\Administrator\Desktop\" & strFile

If Len(Dir(DirFile)) = 0 Then

  MsgBox "File does not exist"

Else

 On Error Resume Next

 Set WB = Workbooks.Open(DirFile)

 On Error GoTo 0

 If WB Is Nothing Then MsgBox DirFile & " is invalid", vbCritical

End If



查看完整回答
反對 回復 2019-11-04
?
梵蒂岡之花

TA貢獻1900條經驗 獲得超5個贊

我使用此功能檢查文件是否存在:


Function IsFile(ByVal fName As String) As Boolean

'Returns TRUE if the provided name points to an existing file.

'Returns FALSE if not existing, or if it's a folder

    On Error Resume Next

    IsFile = ((GetAttr(fName) And vbDirectory) <> vbDirectory)

End Function



查看完整回答
反對 回復 2019-11-04
?
揚帆大魚

TA貢獻1799條經驗 獲得超9個贊

為了檢查是否存在,還可以使用(適用于文件和文件夾):


Not Dir(DirFile, vbDirectory) = vbNullString

結果是True文件或目錄是否存在。


例:


If Not Dir("C:\Temp\test.xlsx", vbDirectory) = vbNullString Then

    MsgBox "exists"

Else

    MsgBox "does not exist"

End If



查看完整回答
反對 回復 2019-11-04
  • 3 回答
  • 0 關注
  • 625 瀏覽
慕課專欄
更多

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯系客服咨詢優惠詳情

幫助反饋 APP下載

慕課網APP
您的移動學習伙伴

公眾號

掃描二維碼
關注慕課網微信公眾號