Wie kann ich alle Schlüssel löschen, die ProgramName enthalten?

Wie kann ich alle Schlüssel löschen, die ProgramName enthalten?

Wie lösche ich alle Ordner (Pfade), die Schlüssel mit einem Namen enthalten, der „ProgramName1“ enthält? CCleaner und ähnliche Programme helfen nicht. Ich google nach Bat- und VBS-Skripten, aber sie scannen nur HKEY_LOCAL_MACHINE, aber ich muss alle Register scannen. Außerdem brauche ich dies, um unter Windows XP, 7 und 10 zu arbeiten. Wo kann ich ein solches Programm oder Skript finden? Wenn es keine verfügbaren Skripte wie dieses gibt, muss ich zumindest Schlüssel löschen, die „ProgramName1“ in allen Registern enthalten. Alle Skripte, die ich gefunden habe, scannen nur nach LOCAL_MACHINE

Antwort1

Sie können es mit diesem VB-Skript versuchen, um in der gesamten Registrierung nach einer Zeichenfolge zu suchen:

'RegSrch.vbs - Search Registry for input string and display results.
'© Bill James - [email protected]
' revised 20 Apr 2001 (parses regfile ~3X faster)
' revised 13 Dec 2001 (added Regedit command line switch for Win2K/WindXP)
' Added a waiting bar in HTA because the search can take a while to end by Hackoo on 22/09/2019
Option Explicit
Dim oWS : Set oWS = CreateObject("WScript.Shell")
Dim oFSO : Set oFSO = CreateObject("Scripting.FileSystemObject")
Dim Temp : Temp = oWS.ExpandEnvironmentStrings("%Temp%")

Dim sSearchFor
sSearchFor = InputBox("This script will search your Registry and find all " & _
             "instances of the search string you input."  & vbcrlf & vbcrlf & _
             "This search could take several minutes, so please be patient." & _
             vbcrlf & vbcrlf & "Enter search string (case insensitive) and " & _
             "click OK...", WScript.ScriptName & " " & Chr(169) & " Bill James")

If sSearchFor = "" Then Cleanup()

Dim StartTime : StartTime = Timer
Dim sRegTmp, eRegLine, iCnt, sRegKey, aRegFileLines, sOutAdd, sOutRemove, OutAdd, OutRemove
Dim TitreWaitBar,MsgAttente,oExec,Duration
TitreWaitBar = "Please be patient... Scanning the registry for the string " & DblQuote(sSearchFor)
MsgAttente = "Searching for this string " & DblQuote(sSearchFor) &_
" on the whole of the registry"
Call CreateProgressBar(TitreWaitBar,MsgAttente)
Call LancerProgressBar()

sRegTmp = oWS.Environment("Process")("Temp") & "\RegTmp.tmp"
sOutAdd = oWS.Environment("Process")("Temp") & "\sOutAdd" & Hour(Now) & Minute(Now) & Second(Now) & ".reg"
sOutRemove = oWS.Environment("Process")("Temp") & "\sOutRemove" & Hour(Now) & Minute(Now) & Second(Now) & ".reg"

oWS.Run "regedit /e /a " & sRegTmp, , True '/a enables export as Ansi for WinXP

set OutAdd = oFSO.OpenTextFile(sOutAdd, 8, True)
set OutRemove = oFSO.OpenTextFile(sOutRemove, 8, True)

OutAdd.WriteLine("REGEDIT4" & vbcrlf & "; " & WScript.ScriptName & " " & _
    Chr(169) & " Bill James" & vbcrlf & vbcrlf & "; Registry search " & _
    "results for string " & Chr(34) & sSearchFor & Chr(34) & " " & Now & _
    vbcrlf & vbcrlf & "; NOTE: This file will be deleted when you close " & _
    "WordPad." & vbcrlf & "; You must manually save this file to a new " & _
    "location if you want to refer to it again later." & vbcrlf & "; (If " & _
    "you save the file with a .reg extension, you can use it to restore " & _
    "any Registry changes you make to these values.)" & vbcrlf)

OutRemove.WriteLine("REGEDIT4" & vbcrlf & "; " & WScript.ScriptName & " " & _
    Chr(169) & " Bill James" & vbcrlf & vbcrlf & "; Registry search " & _
    "results for string " & Chr(34) & sSearchFor & Chr(34) & " " & Now & _
    vbcrlf & vbcrlf & "; NOTE: This file will be deleted when you close " & _
    "WordPad." & vbcrlf & "; You must manually save this file to a new " & _
    "location if you want to refer to it again later." & vbcrlf & "; (If " & _
    "you save the file with a .reg extension, you can use it to restore " & _
    "any Registry changes you make to these values.)" & vbcrlf)

With oFSO.GetFile(sRegTmp)
  aRegFileLines = Split(.OpenAsTextStream(1, 0).Read(.Size), vbcrlf)
End With

oFSO.DeleteFile(sRegTmp)

For Each eRegLine in aRegFileLines
  If InStr(1, eRegLine, "[", 1) > 0 Then sRegKey = eRegLine
  If InStr(1, eRegLine, sSearchFor, 1) >  0 Then
    If sRegKey <> eRegLine Then
      OutAdd.WriteLine(vbcrlf & sRegKey) & vbcrlf & eRegLine
      OutRemove.WriteLine(vbcrlf & "[-" & mid(sRegKey,2)) & vbcrlf & eRegLine
    Else
      OutAdd.WriteLine(vbcrlf & sRegKey)
      OutRemove.WriteLine(vbcrlf & "[-" & mid(sRegKey,2))
    End If
    iCnt = iCnt + 1
  End If
Next

Erase aRegFileLines
Duration = FormatNumber(Timer - StartTime, 0)

If iCnt < 1 Then
  oWS.Popup "Search completed in " & convertTime(Duration) & _
            vbcrlf & vbcrlf & "No instances of " & chr(34) & sSearchFor & chr(34) & _
            " found.",, WScript.ScriptName & " " & Chr(169) & " Bill James", 4096
  .Close
  oFSO.DeleteFile(sOutTmp)
  Cleanup()
End If

OutAdd.Close
OutRemove.Close
Call FermerProgressBar()

oWS.Popup "Search completed in " & convertTime(Duration) & _
          vbcrlf & vbcrlf & iCnt & " instances of " & chr(34) & sSearchFor & chr(34) & _
          " found." & vbcrlf & vbcrlf & "Click OK to open Results in WordPad.",, _
          WScript.ScriptName & " " & Chr(169) & " Bill James", 4096

oWS.Run "WordPad " & sOutAdd, 3, True
oWS.Run "WordPad " & sOutRemove, 3, True

Cleanup()

Sub Cleanup()
  Set oWS = Nothing
  Set oFSO = Nothing
  WScript.Quit
End Sub
'***********************************************************************************************************
Sub CreateProgressBar(Titre,MsgAttente)
    Dim ws,fso,f,f2,ts,ts2,Ligne,i,fread,LireTout,NbLigneTotal,Temp,PathOutPutHTML,fhta,oExec
    Set ws = CreateObject("wscript.Shell")
    Set fso = CreateObject("Scripting.FileSystemObject")
    Temp = WS.ExpandEnvironmentStrings("%Temp%")
    PathOutPutHTML = Temp & "\Barre.hta"
    Set fhta = fso.OpenTextFile(PathOutPutHTML,2,True)
    fhta.WriteLine "<HTML>"
    fhta.WriteLine "<HEAD>"
    fhta.WriteLine "<Title>  " & Titre & "</Title>"
    fhta.WriteLine "<HTA:APPLICATION"
    fhta.WriteLine "ICON = ""magnify.exe"" "
    fhta.WriteLine "BORDER=""THIN"" "
    fhta.WriteLine "INNERBORDER=""NO"" "
    fhta.WriteLine "MAXIMIZEBUTTON=""NO"" "
    fhta.WriteLine "MINIMIZEBUTTON=""NO"" "
    fhta.WriteLine "SCROLL=""NO"" "
    fhta.WriteLine "SYSMENU=""NO"" "
    fhta.WriteLine "SELECTION=""NO"" "
    fhta.WriteLine "SINGLEINSTANCE=""YES"">"
    fhta.WriteLine "</HEAD>"
    fhta.WriteLine "<BODY text=""white""><CENTER>"
    fhta.WriteLine "<marquee DIRECTION=""LEFT"" SCROLLAMOUNT=""3"" BEHAVIOR=ALTERNATE><font face=""Comic sans MS"">" & MsgAttente &"</font></marquee>"
    fhta.WriteLine "<img src="""" />"
    fhta.WriteLine "</CENTER></BODY></HTML>"
    fhta.WriteLine "<SCRIPT LANGUAGE=""VBScript""> "
    fhta.WriteLine "Set ws = CreateObject(""wscript.Shell"")"
    fhta.WriteLine "Temp = WS.ExpandEnvironmentStrings(""%Temp%"")"
    fhta.WriteLine "Sub window_onload()"
    fhta.WriteLine "    CenterWindow 490,110"
    fhta.WriteLine "    Self.document.bgColor = ""DarkOrange"" "
    fhta.WriteLine " End Sub"
    fhta.WriteLine " Sub CenterWindow(x,y)"
    fhta.WriteLine "    Dim iLeft,itop"
    fhta.WriteLine "    window.resizeTo x,y"
    fhta.WriteLine "    iLeft = window.screen.availWidth/2 - x/2"
    fhta.WriteLine "    itop = window.screen.availHeight/2 - y/2"
    fhta.WriteLine "    window.moveTo ileft,itop"
    fhta.WriteLine "End Sub"
    fhta.WriteLine "</script>"
    fhta.close
End Sub
'**********************************************************************************************
Sub LancerProgressBar()
    Set oExec = oWS.Exec("mshta.exe " & Temp & "\Barre.hta")
End Sub
'**********************************************************************************************
Sub FermerProgressBar()
    oExec.Terminate
End Sub
'**********************************************************************************************
Function DblQuote(Str)
    DblQuote = Chr(34) & Str & Chr(34)
End Function
'**********************************************************************************************
Function convertTime(seconds)
    Dim ConvSec,ConvHour,ConvMin
   ConvSec = seconds Mod 60
   If Len(ConvSec) = 1 Then
         ConvSec = "0" & ConvSec
   End If
   ConvMin = (seconds Mod 3600) \ 60
   If Len(ConvMin) = 1 Then
         ConvMin = "0" & ConvMin
   End If
   ConvHour =  seconds \ 3600
   If Len(ConvHour) = 1 Then
         ConvHour = "0" & ConvHour
   End If
   convertTime = ConvHour & ":" & ConvMin & ":" & ConvSec
End Function
'**********************************************************************************************

verwandte Informationen