Elixir语言中 Stream.chunk_every
相关用法介绍如下。
用法:
chunk_every(enum, count, step, leftover \\ [])
(从 1.5.0 开始)
@spec chunk_every(
Enumerable.t(),
pos_integer(),
pos_integer(),
Enumerable.t() | :discard
) ::
Enumerable.t()
以块的形式流式传输可枚举,每个包含 count
元素,其中每个新块从 step
元素开始进入可枚举。
step
是可选的,如果未通过,则默认为 count
,即块不重叠。
如果最后一个块没有count
元素来填充块,则从leftover
中获取元素来填充块。如果leftover
没有足够的元素来填充块,则返回部分块,其元素少于count
。
如果 :discard
在 leftover
中给出,则最后一个块将被丢弃,除非它恰好具有 count
元素。
例子
iex> Stream.chunk_every([1, 2, 3, 4, 5, 6], 2) |> Enum.to_list()
[[1, 2], [3, 4], [5, 6]]
iex> Stream.chunk_every([1, 2, 3, 4, 5, 6], 3, 2, :discard) |> Enum.to_list()
[[1, 2, 3], [3, 4, 5]]
iex> Stream.chunk_every([1, 2, 3, 4, 5, 6], 3, 2, [7]) |> Enum.to_list()
[[1, 2, 3], [3, 4, 5], [5, 6, 7]]
iex> Stream.chunk_every([1, 2, 3, 4, 5, 6], 3, 3, []) |> Enum.to_list()
[[1, 2, 3], [4, 5, 6]]
相关用法
- Elixir Stream.chunk_while用法及代码示例
- Elixir Stream.chunk_by用法及代码示例
- Elixir Stream.concat用法及代码示例
- Elixir Stream.cycle用法及代码示例
- Elixir Stream.drop_while用法及代码示例
- Elixir Stream.map_every用法及代码示例
- Elixir Stream.iterate用法及代码示例
- Elixir Stream.dedup_by用法及代码示例
- Elixir Stream.interval用法及代码示例
- Elixir Stream.zip用法及代码示例
- Elixir Stream.reject用法及代码示例
- Elixir Stream.uniq用法及代码示例
- Elixir Stream.dedup用法及代码示例
- Elixir Stream.take_every用法及代码示例
- Elixir Stream.take用法及代码示例
- Elixir Stream.drop用法及代码示例
- Elixir Stream.zip_with用法及代码示例
- Elixir Stream.transform用法及代码示例
- Elixir Stream.with_index用法及代码示例
- Elixir Stream.flat_map用法及代码示例
- Elixir Stream.repeatedly用法及代码示例
- Elixir Stream.uniq_by用法及代码示例
- Elixir Stream.take_while用法及代码示例
- Elixir Stream.intersperse用法及代码示例
- Elixir Stream.filter用法及代码示例
注:本文由纯净天空筛选整理自elixir-lang.org大神的英文原创作品 Stream.chunk_every(enum, count, step, leftover \\ [])。非经特殊声明,原始代码版权归原作者所有,本译文未经允许或授权,请勿转载或复制。