PowerShell
Los operadores
Buscar..
Introducción
Un operador es un personaje que representa una acción. Le indica al compilador / intérprete que realice operaciones matemáticas, relacionales o lógicas específicas y produzca un resultado final. PowerShell interpreta de una manera específica y clasifica en consecuencia, como los operadores aritméticos realizan operaciones principalmente en números, pero también afectan a cadenas y otros tipos de datos. Junto con los operadores básicos, PowerShell tiene una serie de operadores que ahorran tiempo y esfuerzo de codificación (por ejemplo: -like, -match, -replace, etc.).
Operadores aritméticos
1 + 2 # Addition
1 - 2 # Subtraction
-1 # Set negative value
1 * 2 # Multiplication
1 / 2 # Division
1 % 2 # Modulus
100 -shl 2 # Bitwise Shift-left
100 -shr 1 # Bitwise Shift-right
Operadores logicos
-and # Logical and
-or # Logical or
-xor # Logical exclusive or
-not # Logical not
! # Logical not
Operadores de Asignación
Aritmética simple:
$var = 1 # Assignment. Sets the value of a variable to the specified value
$var += 2 # Addition. Increases the value of a variable by the specified value
$var -= 1 # Subtraction. Decreases the value of a variable by the specified value
$var *= 2 # Multiplication. Multiplies the value of a variable by the specified value
$var /= 2 # Division. Divides the value of a variable by the specified value
$var %= 2 # Modulus. Divides the value of a variable by the specified value and then
# assigns the remainder (modulus) to the variable
Incremento y decremento:
$var++ # Increases the value of a variable, assignable property, or array element by 1
$var-- # Decreases the value of a variable, assignable property, or array element by 1
Operadores de comparación
Los operadores de comparación de PowerShell están compuestos por un guión inicial ( -
) seguido de un nombre ( eq
para equal
, gt
para greater than
, etc ...).
Los nombres pueden ir precedidos por caracteres especiales para modificar el comportamiento del operador:
i # Case-Insensitive Explicit (-ieq)
c # Case-Sensitive Explicit (-ceq)
Case-insensitive es el valor predeterminado si no se especifica, ("a" -eq "A") igual que ("a" -ieq "A").
Operadores de comparación simples:
2 -eq 2 # Equal to (==)
2 -ne 4 # Not equal to (!=)
5 -gt 2 # Greater-than (>)
5 -ge 5 # Greater-than or equal to (>=)
5 -lt 10 # Less-than (<)
5 -le 5 # Less-than or equal to (<=)
Operadores de comparación de cadenas:
"MyString" -like "*String" # Match using the wildcard character (*)
"MyString" -notlike "Other*" # Does not match using the wildcard character (*)
"MyString" -match "$String^" # Matches a string using regular expressions
"MyString" -notmatch "$Other^" # Does not match a string using regular expressions
Operadores de comparación de colecciones:
"abc", "def" -contains "def" # Returns true when the value (right) is present
# in the array (left)
"abc", "def" -notcontains "123" # Returns true when the value (right) is not present
# in the array (left)
"def" -in "abc", "def" # Returns true when the value (left) is present
# in the array (right)
"123" -notin "abc", "def" # Returns true when the value (left) is not present
# in the array (right)
Operadores de redireccionamiento
Flujo de salida de éxito:
cmdlet > file # Send success output to file, overwriting existing content
cmdlet >> file # Send success output to file, appending to existing content
cmdlet 1>&2 # Send success and error output to error stream
Corriente de salida de error:
cmdlet 2> file # Send error output to file, overwriting existing content
cmdlet 2>> file # Send error output to file, appending to existing content
cmdlet 2>&1 # Send success and error output to success output stream
Corriente de salida de advertencia: (PowerShell 3.0+)
cmdlet 3> file # Send warning output to file, overwriting existing content
cmdlet 3>> file # Send warning output to file, appending to existing content
cmdlet 3>&1 # Send success and warning output to success output stream
Secuencia de salida detallada: (PowerShell 3.0+)
cmdlet 4> file # Send verbose output to file, overwriting existing content
cmdlet 4>> file # Send verbose output to file, appending to existing content
cmdlet 4>&1 # Send success and verbose output to success output stream
Corriente de salida de depuración: (PowerShell 3.0+)
cmdlet 5> file # Send debug output to file, overwriting existing content
cmdlet 5>> file # Send debug output to file, appending to existing content
cmdlet 5>&1 # Send success and debug output to success output stream
Flujo de salida de información: (PowerShell 5.0+)
cmdlet 6> file # Send information output to file, overwriting existing content
cmdlet 6>> file # Send information output to file, appending to existing content
cmdlet 6>&1 # Send success and information output to success output stream
Todos los flujos de salida:
cmdlet *> file # Send all output streams to file, overwriting existing content
cmdlet *>> file # Send all output streams to file, appending to existing content
cmdlet *>&1 # Send all output streams to success output stream
Diferencias con el operador de la tubería ( |
)
Los operadores de redireccionamiento solo redirigen flujos a archivos o flujos a flujos. El operador de tuberías bombea un objeto por la tubería hasta un cmdlet o la salida. La forma en que funciona la canalización difiere en general de cómo funciona la redirección y se puede leer en Cómo trabajar con la tubería de PowerShell
Mezcla de tipos de operandos: el tipo del operando izquierdo dicta el comportamiento.
Para la adición
"4" + 2 # Gives "42"
4 + "2" # Gives 6
1,2,3 + "Hello" # Gives 1,2,3,"Hello"
"Hello" + 1,2,3 # Gives "Hello1 2 3"
Para la multiplicación
"3" * 2 # Gives "33"
2 * "3" # Gives 6
1,2,3 * 2 # Gives 1,2,3,1,2,3
2 * 1,2,3 # Gives an error op_Multiply is missing
El impacto puede tener consecuencias ocultas en los operadores de comparación:
$a = Read-Host "Enter a number"
Enter a number : 33
$a -gt 5
False
Operadores de manipulación de cuerdas
Reemplazar operador:
El operador -replace
reemplaza un patrón en un valor de entrada usando una expresión regular. Este operador utiliza dos argumentos (separados por una coma): un patrón de expresión regular y su valor de reemplazo (que es opcional y una cadena vacía de forma predeterminada).
"The rain in Seattle" -replace 'rain','hail' #Returns: The hail in Seattle
"[email protected]" -replace '^[\w]+@(.+)', '$1' #Returns: contoso.com
Dividir y unir los operadores:
El operador -split
divide una cadena en una matriz de -split
.
"A B C" -split " " #Returns an array string collection object containing A,B and C.
El operador -join
une una matriz de cadenas en una sola cadena.
"E","F","G" -join ":" #Returns a single string: E:F:G