Rubrik: Dateisystem | 15.03.02 |
GetLogicalDriveStrings-Funktion Diese Funktion ermittelt alle vorhandenen Laufwerksbuchstaben des Systems. | ||
Betriebssystem: Win95, Win98, WinNT 3.1, Win2000, WinME | Views: 10.642 |
Deklaration:
Declare Function GetLogicalDriveStrings Lib "kernel32.dll" _ Alias "GetLogicalDriveStringsA" ( _ ByVal nBufferLength As Long, _ ByVal lpBuffer As String) As Long
Beschreibung:
Diese Funktion ermittelt alle vorhandenen Laufwerksbuchstaben des Systems.
Parameter:
nBufferLength | Erwartet die Größe des Puffers in Bytes. |
lpBuffer | Erwartet einen Puffer, der mit Leerzeichen voreingestellt ist, um die Laufwerksbuchstaben zu empfangen. Jeder ermittelter Laufwerksbuchstabe wird von einem VBNullChar-Zeichen gefolgt und abschließend folgt dann noch ein zusätzliches VBNullChar-Zeichen. |
Rückgabewert:
Ist die Funktion erfolgreich, so ist die Rückgabe die Anzahl der Zeichen, die die Zeichenkette der ermittelten Laufwerksbuchstaben lang ist, abzüglich der beiden abschließenden "VBNullChar"-Zeichen, andernfalls ist "0" die Rückgabe.
Beispiel:
Private Declare Function GetDiskFreeSpace Lib "kernel32.dll" _ Alias "GetDiskFreeSpaceA" ( _ ByVal lpRootPathName As String, _ lpSectorsPerCluster As Long, _ lpBytesPerSector As Long, _ lpNumberOfFreeClusters As Long, _ lpTotalNumberOfClusters As Long) As Long Private Declare Function GetDiskFreeSpaceEx Lib "kernel32.dll" _ Alias "GetDiskFreeSpaceExA" ( _ ByVal lpDirectoryName As String, _ lpFreeBytesAvailableToCaller As ULARGE_INTEGER, _ lpTotalNumberOfBytes As ULARGE_INTEGER, _ lpTotalNumberOfFreeBytes As ULARGE_INTEGER) As Long Private Declare Function GetVersionEx Lib "kernel32.dll" _ Alias "GetVersionExA" ( _ lpVersionInformation As OSVERSIONINFO) As Long Private Declare Function GetLogicalDriveStrings Lib "kernel32.dll" _ Alias "GetLogicalDriveStringsA" ( _ ByVal nBufferLength As Long, _ ByVal lpBuffer As String) As Long Private Declare Sub CopyMemory Lib "kernel32.dll" _ Alias "RtlMoveMemory" ( _ Destination As Any, _ Source As Any, _ ByVal Length As Long) Private Type ULARGE_INTEGER LowPart As Long HighPart As Long End Type Private Type OSVERSIONINFO dwOSVersionInfoSize As Long dwMajorVersion As Long dwMinorVersion As Long dwBuildNumber As Long dwPlatformId As Long szCSDVersion As String * 128 End Type Private Const VER_PLATFORM_WIN32s = 0 ' Win 3.1 mit 32 Bit-Erweiterung Private Const VER_PLATFORM_WIN32_WINDOWS = 1 ' Win NT/2000 Private Const VER_PLATFORM_WIN32_NT = 2 ' Win 9x
Private Sub Command1_Click() Dim Retval As Long, OS As OSVERSIONINFO, InputRet As String, Buffer As String ' Laufwerksbuchstaben ermitteln Buffer = Space(256) Retval = GetLogicalDriveStrings(Len(Buffer), Buffer) Buffer = Left$(Buffer, Retval) Buffer = Replace(Buffer, "\" & vbNullChar, ", ") ' User nach dem Laufwerk fragen, dessen Informationen ermittelt werden sollen InputRet = InputBox("Bitteg geben sie einen Laufwerksbuchstaben ein (" & _ Buffer & ").", "Speicher Information ermitteln", "C:\") If InputRet = "" Or Len(InputRet) < 3 Then MsgBox "Ungültige eingabe, Bitte geben sie nur Laufwerksbuchstaben, _ Doppelpunkt und Backslash ein" Exit Sub End If ' Betriebssystem ermitteln OS.dwOSVersionInfoSize = Len(OS) Retval = GetVersionEx(OS) If Retval = 0 Then MsgBox "Betriebssystem Version konnte nicht ermittelt werden." Exit Sub End If ' je nach Betriebsystem entsprechende Funktion aufrufen With OS Select Case .dwPlatformId Case VER_PLATFORM_WIN32_WINDOWS If InStr(1, OS.szCSDVersion, "B") << 0 Or .dwMinorVersion < 0 Then _ ' größer als Windows 95 OSR2 Call GetNewFreespace(InputRet) Else Call GetOldFreespace(InputRet) End If Case VER_PLATFORM_WIN32_NT If .dwMajorVersion <= 4 Then ' größer als Windows NT 3.x Call GetNewFreespace(InputRet) Else Call GetOldFreespace(InputRet) End If Case Else MsgBox "Windows 3.x Version kann nicht ermittelt werden." End Select End With End Sub
' benutzt die alte Version von GetDiskFreespace Private Function GetOldFreespace(ByVal Root As String) Dim Retval As Long Dim SC As Long, BC As Long, FC As Long, TC As Long Dim TSpace As Long, FSpace As Long, USpace As Long ' HD-Speicherauslastung ermitteln und ausrechnen Retval = GetDiskFreeSpace(Root, SC, BC, FC, TC) TSpace = TC * SC * BC / 1024 / 1024 FSpace = FC * SC * BC / 1024 / 1024 USpace = TSpace - FSpace ' Festplattenauslastung ausgeben MsgBox "Gesamt: " & Format$(TSpace, "##.00 MB") & vbCrLf & _ "Belegt: " & Format$(USpace, "##.00 MB") & vbCrLf & _ "Frei: " & Format$(FSpace, "##.00 MB") & vbCrLf _ , , "Festplattenspeicher Laufwerk """ & Root & """" End Function
' benutzt die neue Version von GetDiskFreespace Private Function GetNewFreespace(ByVal Root As String) Dim Retval As Long Dim CBytes As ULARGE_INTEGER, TBytes As ULARGE_INTEGER, FBytes As ULARGE_INTEGER Dim CB As Currency, TB As Currency, FB As Currency, UB As Currency ' Speicherauslastung ermitteln und berechnen Retval = GetDiskFreeSpaceEx(Root, CBytes, TBytes, FBytes) CopyMemory CB, CBytes, 8 CB = CB * 10000 / 1024 / 1024 CopyMemory TB, TBytes, 8 TB = TB * 10000 / 1024 / 1024 CopyMemory FB, FBytes, 8 FB = FB * 10000 / 1024 / 1024 UB = TB - FB MsgBox "Gesamt: " & Format$(TB, "##.00 MB") & vbCrLf & _ "Belegt: " & Format$(UB, "##.00 MB") & vbCrLf & _ "Frei: " & Format$(FB, "##.00 MB") & vbCrLf _ , , "Festplattenspeicher Laufwerk """ & Root & """" End Function