unix - help - ¿Equivalente al comando*Nix ''which'' en Powershell?
powershell ayuda (12)
Aquí hay un equivalente real de * nix, es decir, da una salida de estilo * nix.
Get-Command <your command> | Select-Object -ExpandProperty Definition
Simplemente reemplaza con lo que estés buscando.
PS C:/> Get-Command notepad.exe | Select-Object -ExpandProperty Definition
C:/Windows/system32/notepad.exe
Cuando lo agregue a su perfil, deseará usar una función en lugar de un alias porque no puede usar alias con canalizaciones:
function which($name)
{
Get-Command $name | Select-Object -ExpandProperty Definition
}
Ahora, cuando recargas tu perfil puedes hacer esto:
PS C:/> which notepad
C:/Windows/system32/notepad.exe
¿Alguien sabe cómo preguntar a powershell dónde está algo?
Por ejemplo, "qué bloc de notas" y devuelve el directorio desde donde se ejecuta notepad.exe de acuerdo con las rutas actuales.
Compruebe este Powershell que
El código provisto allí sugiere esto
($Env:Path).Split(";") | Get-ChildItem -filter notepad.exe
El primer alias que hice una vez que comencé a personalizar mi perfil en powershell fue "cuál".
New-Alias which get-command
Para agregar esto a su perfil, escriba esto:
"`nNew-Alias which get-command" | add-content $profile
El `n es asegurar que comience como una nueva línea.
Esto parece hacer lo que quieres (lo encontré en http://huddledmasses.org/powershell-find-path/ )
Function Find-Path($Path, [switch]$All=$false, [Microsoft.PowerShell.Commands.TestPathType]$type="Any")
## You could comment out the function stuff and use it as a script instead, with this line:
# param($Path, [switch]$All=$false, [Microsoft.PowerShell.Commands.TestPathType]$type="Any")
if($(Test-Path $Path -Type $type)) {
return $path
} else {
[string[]]$paths = @($pwd);
$paths += "$pwd;$env:path".split(";")
$paths = Join-Path $paths $(Split-Path $Path -leaf) | ? { Test-Path $_ -Type $type }
if($paths.Length -gt 0) {
if($All) {
return $paths;
} else {
return $paths[0]
}
}
}
throw "Couldn''t find a matching path of type $type"
}
Set-Alias find Find-Path
Me gusta get-command | lista de formatos, o
gcm powershell | fl
Puedes encontrar alias como este:
alias -definition format-list
La terminación de pestañas funciona con gcm.
Mi propuesta para la función Qué:
function which($cmd) { get-command $cmd | % { $_.Path } }
PS C:/> which devcon
C:/local/code/bin/devcon.exe
Normalmente solo escribo
gcm notepad
o
gcm note*
gcm es el alias predeterminado para Get-Command.
En mi sistema, gcm note * produce:
[27] » gcm note*
CommandType Name Definition
----------- ---- ----------
Application notepad.exe C:/WINDOWS/notepad.exe
Application notepad.exe C:/WINDOWS/system32/notepad.exe
Application Notepad2.exe C:/Utils/Notepad2.exe
Application Notepad2.ini C:/Utils/Notepad2.ini
Obtiene el directorio y el comando que coinciden con lo que está buscando.
Pruebe el comando where
en Windows 2003 o posterior (o en Windows 2000 / XP si ha instalado un Kit de recursos): http://ss64.com/nt/where.html
Por cierto, esto recibió más respuestas en otros hilos:
Tengo esta función avanzada en mi perfil de PowerShell:
function which {
<#
.SYNOPSIS
Identifies the source of a PowerShell command.
.DESCRIPTION
Identifies the source of a PowerShell command. External commands (Applications) are identified by the path to the executable
(which must be in the system PATH); cmdlets and functions are identified as such and the name of the module they are defined in
provided; aliases are expanded and the source of the alias definition is returned.
.INPUTS
No inputs; you cannot pipe data to this function.
.OUTPUTS
.PARAMETER Name
The name of the command to be identified.
.EXAMPLE
PS C:/Users/Smith/Documents> which Get-Command
Get-Command: Cmdlet in module Microsoft.PowerShell.Core
(Identifies type and source of command)
.EXAMPLE
PS C:/Users/Smith/Documents> which notepad
C:/WINDOWS/SYSTEM32/notepad.exe
(Indicates the full path of the executable)
#>
param(
[String]$name
)
$cmd = Get-Command $name
$redirect = $null
switch ($cmd.CommandType) {
"Alias" { "{0}: Alias for ({1})" -f $cmd.Name, (. { which cmd.Definition } ) }
"Application" { $cmd.Source }
"Cmdlet" { "{0}: {1} {2}" -f $cmd.Name, $cmd.CommandType, (. { if ($cmd.Source.Length) { "in module {0}" -f $cmd.Source} else { "from unspecified source" } } ) }
"Function" { "{0}: {1} {2}" -f $cmd.Name, $cmd.CommandType, (. { if ($cmd.Source.Length) { "in module {0}" -f $cmd.Source} else { "from unspecified source" } } ) }
"Workflow" { "{0}: {1} {2}" -f $cmd.Name, $cmd.CommandType, (. { if ($cmd.Source.Length) { "in module {0}" -f $cmd.Source} else { "from unspecified source" } } ) }
"ExternalScript" { $cmd.Source }
default { $cmd }
}
}
Un partido rápido a Unix which
es
New-Alias which where.exe
Pero devuelve múltiples líneas si existen, entonces se convierte en
$(where.exe command | select -first 1)
Prueba este ejemplo:
(Get-Command notepad.exe).Path
function Which([string] $cmd) {
$path = (($Env:Path).Split(";") | Select -uniq | Where { $_.Length } | Where { Test-Path $_ } | Get-ChildItem -filter $cmd).FullName
if ($path) { $path.ToString() }
}
# check if Chocolatey is installed
if (Which(''cinst.bat'')) {
Write-Host "yes"
} else {
Write-Host "no"
}
O esta versión, llamando al original donde comando. Esta versión también funciona mejor, ya que no se limita a archivos bat
function which([string] $cmd) {
$where = iex $(Join-Path $env:SystemRoot "System32/where.exe $cmd 2>&1")
$first = $($where -split ''[/r/n]'')
if ($first.getType().BaseType.Name -eq ''Array'') {
$first = $first[0]
}
if (Test-Path $first) {
$first
}
}
# check if Curl is installed
if (which(''curl'')) {
echo ''yes''
} else {
echo ''no''
}