Realizar particiones de datos
Actualización: noviembre 2007
Partición en LINQ es la operación de dividir una secuencia de entrada en dos secciones, sin reorganizar los elementos, y devolver después una de las secciones.
La ilustración siguiente muestra los resultados de tres operaciones de partición diferentes en una secuencia de caracteres. La primera operación devuelve los tres primeros elementos de la secuencia. La segunda operación omite los tres primeros elementos y devuelve los restantes. La tercera operación omite los dos primeros elementos de la secuencia y devuelve los tres siguientes.
Los métodos de operador de consulta estándar que realizan particiones de las secuencias se enumeran en la sección siguiente.
Operadores
Nombre de operador |
Description |
Sintaxis de las expresiones de consulta de C# |
Sintaxis de las expresiones de consulta de Visual Basic |
Más información |
---|---|---|---|---|
Saltar |
Omite los elementos hasta una determinada posición de una secuencia. |
No es aplicable |
Skip |
|
SkipWhile |
Omite los elementos según una función de predicado hasta que un elemento no satisface la condición. |
No es aplicable |
Skip While |
|
Take |
Admite los elementos hasta una determinada posición de una secuencia. |
No es aplicable |
Take |
|
TakeWhile |
Admite los elementos según una función de predicado hasta que un elemento no satisface la condición. |
No es aplicable |
Take While |
Ejemplos de sintaxis de expresiones de consulta
Saltar
En el ejemplo de código siguiente se utiliza la cláusula Skip en Visual Basic para omitir las cuatro primeras cadenas de una matriz de cadenas antes de devolver las cadenas restantes de la matriz.
Dim words() As String = New String() {"an", "apple", "a", "day", "keeps", "the", "doctor", "away"}
Dim query = From word In words _
Skip 4
Dim sb As New System.Text.StringBuilder()
For Each str As String In query
sb.AppendLine(str)
Next
' Display the results.
MsgBox(sb.ToString())
' This code produces the following output:
' keeps
' the
' doctor
' away
SkipWhile
En el ejemplo de código siguiente se utiliza la cláusula Skip While en Visual Basic para omitir las cadenas de una matriz mientras la primera letra de la cadena sea una "a". Se devuelven las cadenas restantes de la matriz.
Dim words() As String = New String() {"an", "apple", "a", "day", "keeps", "the", "doctor", "away"}
Dim query = From word In words _
Skip While word.Substring(0, 1) = "a"
Dim sb As New System.Text.StringBuilder()
For Each str As String In query
sb.AppendLine(str)
Next
' Display the results.
MsgBox(sb.ToString())
' This code produces the following output:
' day
' keeps
' the
' doctor
' away
Take
En el ejemplo de código siguiente se utiliza la cláusula Take en Visual Basic para devolver las dos primeras cadenas de una matriz de cadenas.
Dim words() As String = New String() {"an", "apple", "a", "day", "keeps", "the", "doctor", "away"}
Dim query = From word In words _
Take 2
Dim sb As New System.Text.StringBuilder()
For Each str As String In query
sb.AppendLine(str)
Next
' Display the results.
MsgBox(sb.ToString())
' This code produces the following output:
' an
' apple
TakeWhile
En el ejemplo de código siguiente se utiliza la cláusula Take While en Visual Basic para devolver las cadenas de una matriz mientras la longitud de la cadena sea de cinco o menor de cinco.
Dim words() As String = New String() {"an", "apple", "a", "day", "keeps", "the", "doctor", "away"}
Dim query = From word In words _
Take While word.Length < 6
Dim sb As New System.Text.StringBuilder()
For Each str As String In query
sb.AppendLine(str)
Next
' Display the results.
MsgBox(sb.ToString())
' This code produces the following output:
' an
' apple
' a
' day
' keeps
' the
Vea también
Conceptos
Información general sobre operadores de consulta estándar
Referencia
Skip While (Cláusula, Visual Basic)