Set-ItemProperty
Skapar eller ändrar värdet för en egenskap för ett objekt.
Syntax
Set-ItemProperty
[-Path] <String[]>
[-Name] <String>
[-Value] <Object>
[-PassThru]
[-Force]
[-Filter <String>]
[-Include <String[]>]
[-Exclude <String[]>]
[-Credential <PSCredential>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Set-ItemProperty
[-Path] <String[]>
-InputObject <PSObject>
[-PassThru]
[-Force]
[-Filter <String>]
[-Include <String[]>]
[-Exclude <String[]>]
[-Credential <PSCredential>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Set-ItemProperty
-LiteralPath <String[]>
[-Name] <String>
[-Value] <Object>
[-PassThru]
[-Force]
[-Filter <String>]
[-Include <String[]>]
[-Exclude <String[]>]
[-Credential <PSCredential>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Set-ItemProperty
-LiteralPath <String[]>
-InputObject <PSObject>
[-PassThru]
[-Force]
[-Filter <String>]
[-Include <String[]>]
[-Exclude <String[]>]
[-Credential <PSCredential>]
[-WhatIf]
[-Confirm]
[<CommonParameters>]
Description
Cmdleten Set-ItemProperty
ändrar värdet för egenskapen för det angivna objektet.
Du kan använda cmdleten för att upprätta eller ändra egenskaperna för objekt.
Du kan till exempel använda Set-ItemProperty
för att ange värdet för egenskapen IsReadOnly för ett filobjekt till $True
.
Du använder Set-ItemProperty
också för att skapa och ändra registervärden och data.
Du kan till exempel lägga till en ny registerpost i en nyckel och upprätta eller ändra dess värde.
Exempel
Exempel 1: Ange en egenskap för en fil
Det här kommandot anger värdet för egenskapen IsReadOnly för filen "final.doc" till "true". Den använder Sökväg för att ange filen, Namn för att ange namnet på egenskapen och parametern Värde för att ange det nya värdet.
Filen är ett System.IO.FileInfo-objekt och IsReadOnly är bara en av dess egenskaper.
Om du vill se alla egenskaper skriver du Get-Item C:\GroupFiles\final.doc | Get-Member -MemberType Property
.
Den $true
automatiska variabeln representerar värdet "TRUE".
Mer information finns i about_Automatic_Variables.
Set-ItemProperty -Path C:\GroupFiles\final.doc -Name IsReadOnly -Value $true
Exempel 2: Skapa en registerpost och ett värde
Det här exemplet visar hur du använder Set-ItemProperty
för att skapa en ny registerpost och tilldela ett värde till posten. Den skapar posten "NoOfEmployees" i nyckeln "ContosoCompany" i HKLM\Software
nyckeln och anger värdet till 823.
Eftersom registerposter anses vara egenskaper för registernycklarna, som är objekt, använder Set-ItemProperty
du för att skapa registerposter och för att upprätta och ändra deras värden.
Set-ItemProperty -Path "HKLM:\Software\ContosoCompany" -Name "NoOfEmployees" -Value 823
Get-ItemProperty -Path "HKLM:\Software\ContosoCompany"
PSPath : Microsoft.PowerShell.Core\Registry::HKEY_LOCAL_MACHINE\software\contosocompany
PSParentPath : Microsoft.PowerShell.Core\Registry::HKEY_LOCAL_MACHINE\software
PSChildName : contosocompany
PSDrive : HKLM
PSProvider : Microsoft.PowerShell.Core\Registry
NoOfLocations : 2
NoOfEmployees : 823
Set-ItemProperty -Path "HKLM:\Software\ContosoCompany" -Name "NoOfEmployees" -Value 824
Get-ItemProperty -Path "HKLM:\Software\ContosoCompany"
PSPath : Microsoft.PowerShell.Core\Registry::HKEY_LOCAL_MACHINE\software\contosocompany
PSParentPath : Microsoft.PowerShell.Core\Registry::HKEY_LOCAL_MACHINE\software
PSChildName : contosocompany
PSDrive : HKLM
PSProvider : Microsoft.PowerShell.Core\Registry
NoOfLocations : 2
NoOfEmployees : 824
Det första kommandot skapar registerposten.
Den använder Sökväg för att ange sökvägen HKLM:
till enheten och nyckeln "Software\MyCompany".
Kommandot använder Namn för att ange postnamnet och Värdet för att ange ett värde.
Det andra kommandot använder cmdleten Get-ItemProperty
för att se den nya registerposten.
Om du använder Get-Item
cmdletarna eller Get-ChildItem
visas inte posterna eftersom de är egenskaper för en nyckel, inte objekt eller underordnade objekt.
Det tredje kommandot ändrar värdet för posten NoOfEmployees till 824.
Du kan också använda cmdleten New-ItemProperty
för att skapa registerposten och dess värde och sedan använda Set-ItemProperty
för att ändra värdet.
Om du vill ha mer information om HKLM:
enheten skriver du Get-Help Get-PSDrive
.
Mer information om hur du använder PowerShell för att hantera registret Get-Help Registry
finns i .
Exempel 3: Ändra ett objekt med hjälp av pipelinen
Dessa kommandon visar hur du använder en pipelineoperator (|
) för att skicka ett objekt till Set-ItemProperty
.
Den första delen av kommandot använder Get-ChildItem
för att hämta ett objekt som representerar filen "Weekly.txt". Kommandot använder en pipelineoperator för att skicka filobjektet till Set-ItemProperty
.
Kommandot Set-ItemProperty
använder parametrarna Namn och Värde för att ange egenskapen och dess nya värde.
Det här kommandot motsvarar att använda parametern InputObject för att ange det objekt som Get-ChildItem
hämtas.
Get-ChildItem weekly.txt | Set-ItemProperty -Name IsReadOnly -Value $True
Parametrar
-Confirm
Uppmanar dig att bekräfta innan du kör cmdleten.
Type: | SwitchParameter |
Aliases: | cf |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Credential
Anteckning
Den här parametern stöds inte av några leverantörer som är installerade med PowerShell. Om du vill personifiera en annan användare eller höja dina autentiseringsuppgifter när du kör den här cmdleten använder du Invoke-Command.
Type: | PSCredential |
Position: | Named |
Default value: | Current user |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Exclude
Anger, som en strängmatris, ett objekt eller objekt som denna cmdlet exkluderar i åtgärden. Värdet för den här parametern kvalificerar parametern Path . Ange ett sökvägselement eller mönster, till exempel *.txt
. Jokertecken tillåts. Parametern Exkludera gäller endast när kommandot innehåller innehållet i ett objekt, till exempel C:\Windows\*
, där jokertecknet anger innehållet i C:\Windows
katalogen.
Type: | String[] |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | True |
-Filter
Anger ett filter för att kvalificera parametern Path . FileSystem-providern är den enda installerade PowerShell-providern som stöder användning av filter. Du hittar syntaxen för filterspråket FileSystem i about_Wildcards. Filter är effektivare än andra parametrar eftersom providern tillämpar dem när cmdleten hämtar objekten i stället för att PowerShell filtrerar objekten när de har hämtats.
Type: | String |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | True |
-Force
Tvingar cmdleten att ange en egenskap för objekt som annars inte kan nås av användaren. Implementeringen varierar från leverantör till leverantör. Mer information finns i about_Providers.
Type: | SwitchParameter |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Include
Anger, som en strängmatris, ett objekt eller objekt som den här cmdleten innehåller i åtgärden. Värdet för den här parametern kvalificerar parametern Path . Ange ett sökvägselement eller mönster, till exempel "*.txt"
. Jokertecken tillåts. Parametern Include gäller endast när kommandot innehåller innehållet i ett objekt, till exempel C:\Windows\*
, där jokertecknet anger innehållet i C:\Windows
katalogen.
Type: | String[] |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | True |
-InputObject
Anger det objekt som har de egenskaper som den här cmdleten ändrar. Ange en variabel som innehåller objektet eller ett kommando som hämtar objektet.
Type: | PSObject |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-LiteralPath
Anger en sökväg till en eller flera platser. Värdet för LiteralPath används exakt som det skrivs. Inga tecken tolkas som jokertecken. Om sökvägen innehåller escape-tecken omger du den inom enkla citattecken. Enkla citattecken säger till PowerShell att inte tolka några tecken som escape-sekvenser.
Mer information finns i about_Quoting_Rules.
Type: | String[] |
Aliases: | PSPath, LP |
Position: | Named |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Name
Anger namnet på egenskapen.
Type: | String |
Aliases: | PSProperty |
Position: | 1 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-PassThru
Returnerar ett objekt som representerar objektegenskapen. Som standard genererar denna cmdlet inga utdata.
Type: | SwitchParameter |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
-Path
Anger sökvägen till objekten med egenskapen som ska ändras. Jokertecken tillåts.
Type: | String[] |
Position: | 0 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | True |
-Type
Typ är en dynamisk parameter som registerprovidern lägger till i cmdleten Set-ItemProperty
.
Den här parametern fungerar bara i registerenheterna.
Anger vilken typ av egenskap som den här cmdleten lägger till. De acceptabla värdena för den här parametern är:
- Sträng: Anger en null-avslutad sträng. Motsvarar REG_SZ.
- ExpandString: Anger en null-avslutad sträng som innehåller oexpandererade referenser till miljövariabler som expanderas när värdet hämtas. Motsvarar REG_EXPAND_SZ.
- Binär: Anger binära data i valfri form. Motsvarar REG_BINARY.
- DWord: Anger ett 32-bitars binärt tal. Motsvarar REG_DWORD.
- MultiString: Anger en matris med null-avslutade strängar som avslutas med två null-tecken. Motsvarar REG_MULTI_SZ.
- Qword: Anger ett 64-bitars binärt tal. Motsvarar REG_QWORD.
- Okänd: Anger en registerdatatyp som inte stöds, till exempel REG_RESOURCE_LIST.
Type: | RegistryValueKind |
Position: | Named |
Default value: | None |
Required: | False |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-Value
Anger värdet för egenskapen.
Type: | Object |
Position: | 2 |
Default value: | None |
Required: | True |
Accept pipeline input: | True |
Accept wildcard characters: | False |
-WhatIf
Visar vad som skulle hända om cmdleten kördes. Cmdleten körs inte.
Type: | SwitchParameter |
Aliases: | wi |
Position: | Named |
Default value: | False |
Required: | False |
Accept pipeline input: | False |
Accept wildcard characters: | False |
Indata
Du kan skicka objekt till den här cmdleten.
Utdata
None, System.Management.Automation.PSCustomObject
Den här cmdleten genererar ett PSCustomObject-objekt som representerar objektet som ändrades och dess nya egenskapsvärde, om du anger parametern PassThru . Annars genererar den här cmdleten inga utdata.
Kommentarer
Set-ItemProperty
är utformat för att fungera med data som exponeras av alla leverantörer. Om du vill visa en lista över de leverantörer som är tillgängliga i sessionen skriver du Get-PSProvider
. Mer information finns i about_Providers.