Hot News:

Mit Unterstützung durch:

  Foren auf CAD.de (alle Foren)
  Rund um AutoCAD
  Installationspfad ACAD

Antwort erstellen  Neues Thema erstellen
CAD.de Login | Logout | Profil | Profil bearbeiten | Registrieren | Voreinstellungen | Hilfe | Suchen

Anzeige:

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen nächster neuer Beitrag | nächster älterer Beitrag
  
Gut zu wissen: Hilfreiche Tipps und Tricks aus der Praxis prägnant, und auf den Punkt gebracht für Autodesk Produkte
Autor Thema:  Installationspfad ACAD (174 mal gelesen)
megge
Mitglied
Bauingenieur


Sehen Sie sich das Profil von megge an!   Senden Sie eine Private Message an megge  Schreiben Sie einen Gästebucheintrag für megge

Beiträge: 66
Registriert: 11.09.2002

Windows 7 Professional
AutoCAD 2015 - Deu
REVIT ARCHITECTURE 2017
Intel Core i5-2500 3.30 GHz
4,00 GB Ram
AMD Radeon HD 6570

erstellt am: 17. Sep. 2002 19:09    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities

Wiess jemand unter welcher Variable in Windows der Installationspfad von AutoCad abgespeichert ist?

(So wie z.B. %ProgramFiles% für c:\Programme\ steht)

Gruss
Markus

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Bernd Cuder
Mitglied
Selbständig


Sehen Sie sich das Profil von Bernd Cuder an!   Senden Sie eine Private Message an Bernd Cuder  Schreiben Sie einen Gästebucheintrag für Bernd Cuder

Beiträge: 692
Registriert: 10.07.2002

AutoCAD 2002/2004/2005
unter Windows 2000
Professional SP3
PIV 3.4GHz 1024MB
NVIDIA GeForce FX Go5700

erstellt am: 18. Sep. 2002 00:22    Editieren oder löschen Sie diesen Beitrag!  <-- editieren / zitieren -->   Antwort mit Zitat in Fett Antwort mit kursivem Zitat    Unities abgeben: 1 Unity (wenig hilfreich, aber dennoch)2 Unities3 Unities4 Unities5 Unities6 Unities7 Unities8 Unities9 Unities10 Unities Nur für megge 10 Unities + Antwort hilfreich

Über die Registry, unter dem Schlüssel

HKEY_LOCAL_MACHINE\SOFTWARE\Autodesk\AutoCAD\R15.0\ACAD-1:407

gibt es eine Zeichenfolge AcadLocation, dort steht der Pfad,

Der letzte Eintrag (ACAD-1:407) kann variieren, aber unter

HKEY_LOCAL_MACHINE\SOFTWARE\Autodesk\AutoCAD\R15.0

Zeichenfolge CurVer steht er.

Das Auslesen in VBA kann folgendermaßen aussehen:

Public Sub ReadAcadPath()

strCurver = GetKeyValue(HKEY_LOCAL_MACHINE, "Software\Autodesk\AutoCAD\R15.0", "CurVer")

If strCurver = "" Then
    MsgBox "Keine installierte AutoCAD2000/2000i/2002 - Version gefunden.", vbCritical, "Cad&Co_Modular"
Exit Sub
Else
    On Error Resume Next
    strCurver = Left(strCurver, Len(strCurver) - 1)
    strAcadnu = GetKeyValue(HKEY_LOCAL_MACHINE, "Software\Autodesk\AutoCAD\R15.0\" & strCurver, "SerialNumber")
    strAcadnu = Left(strAcadnu, Len(strAcadnu) - 1)
    strAPath = GetKeyValue(HKEY_LOCAL_MACHINE, "Software\Autodesk\AutoCAD\R15.0\" & strCurver, "AcadLocation")
    strAPath = Left(strAPath, Len(strAPath) - 1)
    If Err.Number <> 0 Then
      MsgBox "Keine installierte AutoCAD2000/2000i/2002 - Version gefunden.", vbCritical, "Cad&Co_Modular"
      Exit Sub
    End If
  End If

End Sub


'Funktionen zum Auslesen der Registry

Option Explicit

Global Const REG_SZ As Long = 1
Global Const REG_DWORD As Long = 4

Global Const HKEY_CLASSES_ROOT = &H80000000
Global Const HKEY_CURRENT_USER = &H80000001
Global Const HKEY_LOCAL_MACHINE = &H80000002
Global Const HKEY_USERS = &H80000003

Global Const ERROR_NONE = 0
Global Const ERROR_BADDB = 1
Global Const ERROR_BADKEY = 2
Global Const ERROR_CANTOPEN = 3
Global Const ERROR_CANTREAD = 4
Global Const ERROR_CANTWRITE = 5
Global Const ERROR_OUTOFMEMORY = 6
Global Const ERROR_INVALID_PARAMETER = 7
Global Const ERROR_ACCESS_DENIED = 8
Global Const ERROR_INVALID_PARAMETERS = 87
Global Const ERROR_NO_MORE_ITEMS = 259
Global Const ERROR_SUCCESS = 0&

Global Const KEY_ALL_ACCESS = &H3F
Global Const KEY_READ = &H20019

Global Const REG_OPTION_NON_VOLATILE = 0

Declare Function RegCloseKey Lib "advapi32.dll" (ByVal hKey As Long) As Long
Declare Function RegCreateKeyEx Lib "advapi32.dll" Alias "RegCreateKeyExA" (ByVal hKey As Long, ByVal lpSubKey As String, ByVal Reserved As Long, ByVal lpClass As String, ByVal dwOptions As Long, ByVal samDesired As Long, ByVal lpSecurityAttributes As Long, phkResult As Long, lpdwDisposition As Long) As Long
Declare Function RegOpenKeyEx Lib "advapi32.dll" Alias "RegOpenKeyExA" (ByVal hKey As Long, ByVal lpSubKey As String, ByVal ulOptions As Long, ByVal samDesired As Long, phkResult As Long) As Long
Declare Function RegQueryValueExString Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, ByVal lpData As String, lpcbData As Long) As Long
Declare Function RegQueryValueExLong Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, lpData As Long, lpcbData As Long) As Long
Declare Function RegQueryValueExNULL Lib "advapi32.dll" Alias "RegQueryValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal lpReserved As Long, lpType As Long, ByVal lpData As Long, lpcbData As Long) As Long
Declare Function RegSetValueExString Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal Reserved As Long, ByVal dwType As Long, ByVal lpValue As String, ByVal cbData As Long) As Long
Declare Function RegSetValueExLong Lib "advapi32.dll" Alias "RegSetValueExA" (ByVal hKey As Long, ByVal lpValueName As String, ByVal Reserved As Long, ByVal dwType As Long, lpValue As Long, ByVal cbData As Long) As Long
Declare Function RegDeleteKey Lib "advapi32.dll" Alias "RegDeleteKeyA" (ByVal hKey As Long, ByVal lpSubKey As String) As Long

Public Function RegKeyExist(lPredefinedKey As Long, sKeyName As String) As Long

  Dim lRetVal As Long
  Dim hKey As Long
 
  lRetVal = RegOpenKeyEx(lPredefinedKey, sKeyName, 0, KEY_READ, hKey)
 
  RegKeyExist = lRetVal
 
End Function

Public Function DeleteKey(lPredefinedKey As Long, sKeyName As String)

  Dim lRetVal As Long
 
  lRetVal = RegDeleteKey(lPredefinedKey, sKeyName)

End Function

Public Function CreateNewKey(lPredefinedKey As Long, sNewKeyName As String)
 
  Dim hNewKey As Long
  Dim lRetVal As Long
   
  lRetVal = RegCreateKeyEx(lPredefinedKey, sNewKeyName, 0&, vbNullString, _
                          REG_OPTION_NON_VOLATILE, KEY_ALL_ACCESS, 0&, hNewKey, lRetVal)
           
  RegCloseKey (hNewKey)
 
End Function

Public Function SetKeyValue(lPredefinedKey As Long, sKeyName As String, sValueName As String, _
                            vValueSetting As Variant, lValueType As Long)
 
  Dim lRetVal As Long
  Dim hKey As Long
 
  lRetVal = RegOpenKeyEx(lPredefinedKey, sKeyName, 0, KEY_ALL_ACCESS, hKey)
  lRetVal = SetValueEx(hKey, sValueName, lValueType, vValueSetting)
  RegCloseKey (hKey)

End Function

Public Function GetKeyValue(lPredefinedKey As Long, sKeyName As String, sValueName As String)

  Dim lRetVal As Long
  Dim hKey As Long
  Dim vValue As Variant

  lRetVal = RegOpenKeyEx(lPredefinedKey, sKeyName, 0, KEY_READ, hKey)
  lRetVal = QueryValueEx(hKey, sValueName, vValue)
  GetKeyValue = vValue
  RegCloseKey (hKey)
     
End Function

Public Function SetValueEx(ByVal hKey As Long, sValueName As String, lType As Long, vValue As Variant) As Long

  Dim lValue As Long
  Dim sValue As String

  Select Case lType
    Case REG_SZ
      sValue = vValue
      SetValueEx = RegSetValueExString(hKey, sValueName, 0&, lType, sValue, Len(sValue))
    Case REG_DWORD
      lValue = vValue
      SetValueEx = RegSetValueExLong(hKey, sValueName, 0&, lType, lValue, 4)
    End Select
   
End Function

Function QueryValueEx(ByVal lhKey As Long, ByVal szValueName As String, vValue As Variant) As Long

  Dim cch As Long
  Dim lrc As Long
  Dim lType As Long
  Dim lValue As Long
  Dim sValue As String

  On Error GoTo QueryValueExError

  lrc = RegQueryValueExNULL(lhKey, szValueName, 0&, lType, 0&, cch)
  If lrc <> ERROR_NONE Then Error 5

  Select Case lType
  Case REG_SZ:
    sValue = String(cch, 0)
    lrc = RegQueryValueExString(lhKey, szValueName, 0&, lType, sValue, cch)
    If lrc = ERROR_NONE Then
      vValue = Left$(sValue, cch)
    Else
      vValue = Empty
    End If
  Case REG_DWORD:
    lrc = RegQueryValueExLong(lhKey, szValueName, 0&, lType, lValue, cch)
    If lrc = ERROR_NONE Then vValue = lValue
  Case Else
    lrc = -1
  End Select

QueryValueExExit:

  QueryValueEx = lrc
 
  Exit Function

QueryValueExError:

  Resume QueryValueExExit

End Function

------------------
Ing. Bernd Cuder
Cad&Co makes CAD easy

Eine Antwort auf diesen Beitrag verfassen (mit Zitat/Zitat des Beitrags) IP

Anzeige.:

Anzeige: (Infos zum Werbeplatz >>)

Darstellung des Themas zum Ausdrucken. Bitte dann die Druckfunktion des Browsers verwenden. | Suche nach Beiträgen

nächster neuerer Beitrag | nächster älterer Beitrag
Antwort erstellen


Diesen Beitrag mit Lesezeichen versehen ... | Nach anderen Beiträgen suchen | CAD.de-Newsletter

Administrative Optionen: Beitrag schliessen | Archivieren/Bewegen | Beitrag melden!

Fragen und Anregungen: Kritik-Forum | Neues aus der Community: Community-Forum

(c)2023 CAD.de | Impressum | Datenschutz