#iterator #product #zip #data-structures #no-alloc

no-std itertools

Extra iterator adaptors, iterator methods, free functions, and macros

130 releases

0.14.0 Dec 31, 2024
0.13.0 May 16, 2024
0.12.1 Jan 29, 2024
0.12.0 Nov 14, 2023
0.0.3 Nov 29, 2014

#4 in Rust patterns

Download history 4824821/week @ 2024-09-28 5306272/week @ 2024-10-05 5450925/week @ 2024-10-12 5117172/week @ 2024-10-19 4575584/week @ 2024-10-26 4641232/week @ 2024-11-02 4784078/week @ 2024-11-09 5046592/week @ 2024-11-16 4101672/week @ 2024-11-23 4883867/week @ 2024-11-30 5829204/week @ 2024-12-07 5088139/week @ 2024-12-14 2214064/week @ 2024-12-21 2737551/week @ 2024-12-28 5045655/week @ 2025-01-04 4736497/week @ 2025-01-11

15,510,016 downloads per month
Used in 28,345 crates (5,925 directly)

MIT/Apache

450KB
9K SLoC

Itertools

Extra iterator adaptors, functions and macros.

Please read the API documentation here.

How to use with Cargo:

[dependencies]
itertools = "0.14.0"

How to use in your crate:

use itertools::Itertools;

How to contribute

If you're not sure what to work on, try checking the help wanted label.

See our CONTRIBUTING.md for a detailed guide.

License

Dual-licensed to be compatible with the Rust project.

Licensed under the Apache License, Version 2.0 https://www.apache.org/licenses/LICENSE-2.0 or the MIT license https://opensource.org/licenses/MIT, at your option. This file may not be copied, modified, or distributed except according to those terms.


lib.rs:

Extra iterator adaptors, functions and macros.

To extend Iterator with methods in this crate, import the Itertools trait:

use itertools::Itertools;

Now, new methods like interleave are available on all iterators:

use itertools::Itertools;

let it = (1..3).interleave(vec![-1, -2]);
itertools::assert_equal(it, vec![1, -1, 2, -2]);

Most iterator methods are also provided as functions (with the benefit that they convert parameters using IntoIterator):

use itertools::interleave;

for elt in interleave(&[1, 2, 3], &[2, 3, 4]) {
    /* loop body */
    # let _ = elt;
}

Crate Features

  • use_std
    • Enabled by default.
    • Disable to compile itertools using #![no_std]. This disables any item that depend on allocations (see the use_alloc feature) and hash maps (like unique, counts, into_grouping_map and more).
  • use_alloc
    • Enabled by default.
    • Enables any item that depend on allocations (like chunk_by, kmerge, join and many more).

Rust Version

This version of itertools requires Rust 1.63.0 or later.

Dependencies