當前位置: 首頁>>代碼示例 >>用法及示例精選 >>正文


Elixir Enum.zip_with用法及代碼示例


Elixir語言中 Enum.zip_with 相關用法介紹如下。

用法一

zip_with(enumerables, zip_fun)
(自 1.12.0 起)
@spec zip_with(t(), ([term()] -> term())) :: [term()]

將有限可枚舉集合中的相應元素壓縮到列表中,並使用zip_fun 函數對其進行轉換。

enumerables 中每個枚舉的第一個元素將被放入一個列表中,然後將其傳遞給 1-arity zip_fun 函數。然後,將每個枚舉中的第二個元素放入一個列表並傳遞給 zip_fun ,依此類推,直到 enumerables 中的任何一個枚舉用完元素。

返回一個列表,其中包含調用 zip_fun 的所有結果。

例子

iex> Enum.zip_with([[1, 2], [3, 4], [5, 6]], fn [x, y, z] -> x + y + z end)
[9, 12]

iex> Enum.zip_with([[1, 2], [3, 4]], fn [x, y] -> x + y end)
[4, 6]

用法二

zip_with(enumerable1, enumerable2, zip_fun)
(自 1.12.0 起)
@spec zip_with(t(), t(), (enum1_elem :: term(), enum2_elem :: term() -> term())) :: [
  term()
]

將兩個可枚舉中的相應元素壓縮到一個列表中,並使用zip_fun 函數對其進行轉換。

每個集合中的相應元素依次傳遞給提供的 2-arity zip_fun 函數。返回一個列表,其中包含為每對元素調用 zip_fun 的結果。

隻要任一可枚舉的元素用完,壓縮就會結束。

壓縮Map

重要的是要記住,拉鏈本質上依賴於順序。如果您壓縮兩個列表,您將依次從每個列表中獲取索引處的元素。如果我們將兩個 map 壓縮在一起,很容易認為您將在左側 map 中獲得給定的 key,在右側 map 中獲得匹配的 key,但沒有這樣的保證,因為 map 的 key 不是有序的!考慮以下:

left =  %{:a => 1, 1 => 3}
right = %{:a => 1, :b => :c}
Enum.zip(left, right)
# [{{1, 3}, {:a, 1}}, {{:a, 1}, {:b, :c}}]

如您所見, :a 沒有與 :a 配對。如果這是您想要的,您應該使用 Map.merge/3

例子

iex> Enum.zip_with([1, 2], [3, 4], fn x, y -> x + y end)
[4, 6]

iex> Enum.zip_with([1, 2], [3, 4, 5, 6], fn x, y -> x + y end)
[4, 6]

iex> Enum.zip_with([1, 2, 5, 6], [3, 4], fn x, y -> x + y end)
[4, 6]

相關用法


注:本文由純淨天空篩選整理自elixir-lang.org大神的英文原創作品 Enum.zip_with(enumerables, zip_fun)。非經特殊聲明,原始代碼版權歸原作者所有,本譯文未經允許或授權,請勿轉載或複製。