Leer en inglés

Compartir a través de


Queryable.Zip Método

Definición

Sobrecargas

Zip<TFirst,TSecond,TResult>(IQueryable<TFirst>, IEnumerable<TSecond>, Expression<Func<TFirst,TSecond,TResult>>)

Combina dos secuencias utilizando la función de predicado especificada.

Zip<TFirst,TSecond,TThird>(IQueryable<TFirst>, IEnumerable<TSecond>, IEnumerable<TThird>)

Genera una secuencia de tuplas con elementos de las tres secuencias especificadas.

Zip<TFirst,TSecond>(IQueryable<TFirst>, IEnumerable<TSecond>)

Genera una secuencia de tuplas con elementos a partir de las dos secuencias especificadas.

Zip<TFirst,TSecond,TResult>(IQueryable<TFirst>, IEnumerable<TSecond>, Expression<Func<TFirst,TSecond,TResult>>)

Source:
Queryable.cs
Source:
Queryable.cs
Source:
Queryable.cs

Combina dos secuencias utilizando la función de predicado especificada.

C#
public static System.Linq.IQueryable<TResult> Zip<TFirst,TSecond,TResult> (this System.Linq.IQueryable<TFirst> source1, System.Collections.Generic.IEnumerable<TSecond> source2, System.Linq.Expressions.Expression<Func<TFirst,TSecond,TResult>> resultSelector);

Parámetros de tipo

TFirst

Tipo de los elementos de la primera secuencia de entrada.

TSecond

Tipo de los elementos de la segunda secuencia de entrada.

TResult

Tipo de los elementos de la secuencia de resultados.

Parámetros

source1
IQueryable<TFirst>

Primera secuencia que se va a combinar.

source2
IEnumerable<TSecond>

Segunda secuencia que se va a combinar.

resultSelector
Expression<Func<TFirst,TSecond,TResult>>

Función que especifica cómo combinar los elementos de las dos secuencias.

Devoluciones

IQueryable<TResult>

IQueryable<T> que contiene elementos combinados de las dos secuencias de entrada.

Excepciones

source1 o source2 es null.

Ejemplos

En el ejemplo de código siguiente se muestra cómo usar el Zip método para combinar dos secuencias.

C#
int[] numbers = { 1, 2, 3, 4 };
string[] words = { "one", "two", "three" };

var numbersAndWords = numbers.AsQueryable().Zip(words, (first, second) => first + " " + second);

foreach (var item in numbersAndWords)
    Console.WriteLine(item);

// This code produces the following output:

// 1 one
// 2 two
// 3 three

Comentarios

El Zip método genera un MethodCallExpression objeto que representa llamarse Zip a sí mismo como un método genérico construido. A continuación, pasa al MethodCallExpressionCreateQuery<TElement>(Expression) método del IQueryProvider representado por la Provider propiedad del source1 parámetro .

El método combina cada elemento de la primera secuencia con un elemento que tiene el mismo índice en la segunda secuencia. Si las secuencias no tienen el mismo número de elementos, el método combina secuencias hasta que llega al final de una de ellas. Por ejemplo, si una secuencia tiene tres elementos y la otra tiene cuatro, la secuencia resultante tendrá solo tres elementos.

Se aplica a

.NET 9 y otras versiones
Producto Versiones
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 2.0, 2.1
UWP 10.0

Zip<TFirst,TSecond,TThird>(IQueryable<TFirst>, IEnumerable<TSecond>, IEnumerable<TThird>)

Source:
Queryable.cs
Source:
Queryable.cs
Source:
Queryable.cs

Genera una secuencia de tuplas con elementos de las tres secuencias especificadas.

C#
public static System.Linq.IQueryable<(TFirst First, TSecond Second, TThird Third)> Zip<TFirst,TSecond,TThird> (this System.Linq.IQueryable<TFirst> source1, System.Collections.Generic.IEnumerable<TSecond> source2, System.Collections.Generic.IEnumerable<TThird> source3);

Parámetros de tipo

TFirst

Tipo de los elementos de la primera secuencia de entrada.

TSecond

Tipo de los elementos de la segunda secuencia de entrada.

TThird

Tipo de los elementos de la tercera secuencia de entrada.

Parámetros

source1
IQueryable<TFirst>

Primera secuencia que se va a combinar.

source2
IEnumerable<TSecond>

Segunda secuencia que se va a combinar.

source3
IEnumerable<TThird>

Tercera secuencia que se va a combinar.

Devoluciones

IQueryable<ValueTuple<TFirst,TSecond,TThird>>

Secuencia de tuplas con elementos tomados de la primera, segunda y tercera secuencia, en ese orden.

Se aplica a

.NET 9 y otras versiones
Producto Versiones
.NET 6, 7, 8, 9

Zip<TFirst,TSecond>(IQueryable<TFirst>, IEnumerable<TSecond>)

Source:
Queryable.cs
Source:
Queryable.cs
Source:
Queryable.cs

Genera una secuencia de tuplas con elementos a partir de las dos secuencias especificadas.

C#
public static System.Linq.IQueryable<(TFirst First, TSecond Second)> Zip<TFirst,TSecond> (this System.Linq.IQueryable<TFirst> source1, System.Collections.Generic.IEnumerable<TSecond> source2);

Parámetros de tipo

TFirst

Tipo de los elementos de la primera secuencia de entrada.

TSecond

Tipo de los elementos de la segunda secuencia de entrada.

Parámetros

source1
IQueryable<TFirst>

Primera secuencia que se va a combinar.

source2
IEnumerable<TSecond>

Segunda secuencia que se va a combinar.

Devoluciones

IQueryable<ValueTuple<TFirst,TSecond>>

Secuencia de tuplas con elementos tomados de la primera y la segunda secuencia, en ese orden.

Se aplica a

.NET 9 y otras versiones
Producto Versiones
.NET Core 3.0, Core 3.1, 5, 6, 7, 8, 9