Set-Item

Ändrar värdet för ett objekt till det värde som anges i kommandot .

Syntax

Set-Item
   [-Path] <String[]>
   [[-Value] <Object>]
   [-Force]
   [-PassThru]
   [-Filter <String>]
   [-Include <String[]>]
   [-Exclude <String[]>]
   [-Credential <PSCredential>]
   [-WhatIf]
   [-Confirm]
   [<CommonParameters>]
Set-Item
   -LiteralPath <String[]>
   [[-Value] <Object>]
   [-Force]
   [-PassThru]
   [-Filter <String>]
   [-Include <String[]>]
   [-Exclude <String[]>]
   [-Credential <PSCredential>]
   [-WhatIf]
   [-Confirm]
   [<CommonParameters>]

Description

Cmdleten Set-Item ändrar värdet för ett objekt, till exempel en variabel eller registernyckel, till det värde som anges i kommandot .

Exempel

Exempel 1: Skapa ett alias

Det här kommandot skapar ett alias för np för Anteckningar.

Set-Item -Path alias:np -Value "c:\windows\notepad.exe"

Exempel 2: Ändra värdet för en miljövariabel

Det här kommandot ändrar värdet för miljövariabeln UserRole till Administratör.

Set-Item -Path env:UserRole -Value "Administrator"

Exempel 3: Ändra promptfunktionen

Det här kommandot ändrar promptfunktionen så att den visar tiden före sökvägen.

Set-Item -Path function:prompt -Value {'PS '+ (Get-Date -Format t) + " " + (Get-Location) + '> '}

Exempel 4: Ange alternativ för promptfunktionen

Det här kommandot anger alternativen AllScope och ReadOnly för promptfunktionen. Det här kommandot använder den dynamiska parametern Alternativ för Set-Item. Parametern Alternativ är endast tillgänglig i Set-Item när du använder den med alias - eller funktionsprovidern .

Set-Item -Path function:prompt -Options "AllScope,ReadOnly"

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 providers 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 Undanta 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 mer effektiva än andra parametrar, eftersom providern tillämpar dem när cmdleten hämtar objekten i stället för att PowerShell filtrerar objekten efter att 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 objekt som annars inte kan ändras, till exempel skrivskyddade alias eller variabler. Cmdleten kan inte ändra konstanta alias eller variabler. Implementeringen varierar från leverantör till leverantör. Mer information finns i about_Providers. Även om du använder force-parametern kan cmdleten inte åsidosätta säkerhetsbegränsningar.

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 denna cmdlet 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

-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 med enkla citattecken. Enkla citattecken instruerar 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

-PassThru

Skickar ett objekt som representerar objektet till pipelinen. Som standard genererar denna cmdlet inga utdata.

Type:SwitchParameter
Position:Named
Default value:False
Required:False
Accept pipeline input:False
Accept wildcard characters:False

-Path

Anger en sökväg till objektens plats. Jokertecken tillåts.

Type:String[]
Position:0
Default value:None
Required:True
Accept pipeline input:True
Accept wildcard characters:True

-Value

Anger ett nytt värde för objektet.

Type:Object
Position:1
Default value:None
Required:False
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

Object

Du kan skicka ett objekt som representerar det nya värdet för objektet till den här cmdleten.

Utdata

None or an object representing the new or changed item.

Den här cmdleten genererar ett objekt som representerar objektet, om du anger parametern PassThru . Annars genererar denna cmdlet inga utdata.

Kommentarer

  • Set-Item stöds inte av PowerShell FileSystem-providern. Om du vill ändra värdena för objekt i filsystemet använder du cmdleten Set-Content .
  • I registerenheterna, HKLM: och HKCU:, Set-Item ändras data i värdet (Standard) för en registernyckel.
    • Om du vill skapa och ändra namnen på registernycklarna använder du cmdleten New-Item och Rename-Item .
    • Om du vill ändra namn och data i registervärden använder du New-ItemPropertycmdletarna , Set-ItemPropertyoch Rename-ItemProperty .
  • Set-Item är utformad för att fungera med data som exponeras av alla leverantörer. Om du vill visa en lista över de providrar som är tillgängliga i sessionen skriver du Get-PsProvider. Mer information finns i about_Providers.