この関数は、「書き込み」モードで目的のファイルにアクセスできるかどうかを決定します。これは、ファイルがプロセスによってロックされているかどうかを判断することとまったく同じではありません。それでも、あなたの状況に適していることがわかります。 (少なくとも何かがうまくいくまで)
この機能は、ファイルが別のプロセスによってロックされているときに「書き込み」アクセスができないことを示します。ただし、その条件を「書き込み」アクセスを禁止する他の条件と区別することはできません。たとえば、ファイルに読み取り専用ビットが設定されている場合や、制限付きNTFSアクセス許可を持っている場合は、「書き込み」アクセスもできません。これらの条件はすべて、「書き込み」アクセス試行が行われたときに「許可が拒否されました」となります。
ファイルが別のプロセスによってロックされている場合、この関数が返す応答は、その関数が実行された時点でのみ信頼できることにも注意してください。したがって、並行性の問題は可能です。
「ファイルが見つかりません」、「パスが見つかりません」、または「不正なファイル名」(「ファイル名または番号が正しくありません」)のいずれかが検出された場合、例外がスローされます。
Function IsWriteAccessible(sFilePath)
' Strategy: Attempt to open the specified file in 'append' mode.
' Does not appear to change the 'modified' date on the file.
' Works with binary files as well as text files.
' Only 'ForAppending' is needed here. Define these constants
' outside of this function if you need them elsewhere in
' your source file.
Const ForReading = 1, ForWriting = 2, ForAppending = 8
IsWriteAccessible = False
Dim oFso : Set oFso = CreateObject("Scripting.FileSystemObject")
On Error Resume Next
Dim nErr : nErr = 0
Dim sDesc : sDesc = ""
Dim oFile : Set oFile = oFso.OpenTextFile(sFilePath, ForAppending)
If Err.Number = 0 Then
oFile.Close
If Err Then
nErr = Err.Number
sDesc = Err.Description
Else
IsWriteAccessible = True
End if
Else
Select Case Err.Number
Case 70
' Permission denied because:
' - file is open by another process
' - read-only bit is set on file, *or*
' - NTFS Access Control List settings (ACLs) on file
' prevents access
Case Else
' 52 - Bad file name or number
' 53 - File not found
' 76 - Path not found
nErr = Err.Number
sDesc = Err.Description
End Select
End If
' The following two statements are superfluous. The VB6 garbage
' collector will free 'oFile' and 'oFso' when this function completes
' and they go out of scope. See Eric Lippert's article for more:
' http://blogs.msdn.com/b/ericlippert/archive/2004/04/28/when-are-you-required-to-set-objects-to-nothing.aspx
'Set oFile = Nothing
'Set oFso = Nothing
On Error GoTo 0
If nErr Then
Err.Raise nErr, , sDesc
End If
End Function
ダーリンノートこのモジュールが含まれなければならないこと(他の回答で): 'のConst ForReading = 1、ForWriting = 2、ForAppending = 8' – Smandoli
@Smandoli - 私の注意には、この省略を持っていただき、ありがとうございます。私はそれに応じてコードを更新しました。また、関数の最後に 'oFile'と' oFso'を 'Nothing'に設定する前の私のコメントに注目してください。 – DavidRR