Iterator
Functions that use iterators for efficient loops.
all_distinct
all_distinct(iterable, key=None)
Check if all the elements of a key-based iterable are distinct.
:param iterable:
:param key: None or "Callable" to compare if iterable items.
:rtype: bool
Examples:
    from pymince.iterator import all_distinct
    all_distinct([1, 1]) # --> False
    all_distinct([1, 2]) # --> True
all_equal
all_equal(iterable, key=None)
Check if all the elements of a key-based iterable are equals.
:param iterable:
:param key: None or "Callable" to compare if iterable items.
:rtype: bool
Examples:
    from pymince.iterator import all_equal
    all_equal([1, 1]) # --> True
    all_equal([1, 2]) # --> False
all_equals
all_equals(*iterables, key=None)
Check if the iterables are equal.
If the "iterables" are empty, it returns True.
:param iterables:
:param key: None or "Callable" to compare if iterable items.
:rtype: bool
Examples:
    from pymince.iterator import all_equals
    all_equals() # --> True
    all_equals(range(1, 4), (1, 2, 3), {1, 2, 3}) # --> True
    all_equals((1, 2), (1, 2, 3)) # --> False
all_identical
all_identical(left, right)
Check that the items of `left` are the same objects
as those in `right`.
:param Iterable[Any] left:
:param Iterable[Any] right:
:rtype: bool
Examples:
    from pymince.iterator import all_identical
    a, b = object(), object()
    all_identical([a, b, a], [a, b, a]) # --> True
    all_identical([a, b, [a]], [a, b, [a]])  # --> False *new list object, while "equal" is not "identical"*
centroid
centroid(coordinates)
Calculate the centroid of a set of n-dimensional coordinates.
In Cartesian coordinates, the centroid is
just the mean of the components.
:param Iterable[Iterable[int]] coordinates: Iterable of n-dimensional coordinates.
:rtype: Generator[int]
 Examples:
    from pymince.iterator import centroid
    coord = (((2, 2), (4, 4)))
    tuple(centroid(coord))  # --> (3, 3)
consume
consume(iterator, n=None)
Advance *iterator* by *n* steps. If *n* is ``None``, consume it
entirely.
Examples:
    from pymince.iterator import consume
    it = iter([1, 2])
    consume(it)
    next(it) # → StopIteration
grouper
grouper(iterable, n)
Make a generator that returns each element being iterable
with "size" as the maximum number of elements.
:param iterable:
:param int n: maximum size of element groups.
:rtype: Generator
Examples:
    from pymince.iterator import grouper
    groups = grouper([1, 2, 3, 4, 5], 2)
    list(list(g) for g in groups) # → [[1, 2], [3, 4], [5]]
ibool
ibool(iterable)
Iterator class supporting ´__bool__´.
Examples:
    from pymince.iterator import ibool
    it = ibool((1, 2, 3))
    bool(it) # --> True
    list(it) # --> [1, 2, 3]
in_all
in_all(obj, iterables)
Check if the object is contained in all the given iterables.
If the "iterables" are empty, return True.
:param Any obj:
:param iterables: iterable of iterables
:rtype: bool
Examples:
    from pymince.iterator import in_all
    in_all("a", (("a", "b"), "bcd")) # --> False
    in_all("a", (("a", "b"), "abc")) # --> True
    in_all("a", ()) # --> True
in_any
in_any(obj, iterables)
Check if the object is contained in any of the given iterables.
:param Any obj:
:param iterables: iterable of iterables
:rtype: bool
Examples:
    from pymince.iterator import in_any
    in_any("a", (("a", "b"), "bcd")) # --> True
    in_any("a", (("b", "b"), "def")) # --> False
    in_any("a", ()) # --> False
ipush
ipush(iterable)
Iterator class supporting ´append´ and ´prepend´.
Examples:
    from pymince.iterator import ipush
    it = ipush(iter([2, 3])
    it.append(4)
    it.append(5)
    it.prepend(1)
    it.prepend(0)
    list(it)  # --> [0, 1, 2, 3, 4, 5]
mul
mul(iterable, start=1)
Return the multiplication of a 'start' value (default: 1)
plus an iterable of numbers.
When the iterable is empty, return the start value.
only_one
only_one(iterable)
Check if given iterable has only one element.
:param iterable:
:rtype: bool
Examples:
    from pymince.iterator import only_one
    only_one([1]) # --> True
    only_one([1, 2]) # --> False
    only_one([]) # --> False
pad_end
pad_end(iterable, length, fill_value=None)
The function adds "fill_value" at the finishing of the iterable,
until it reaches the specified length.
If the value of the "length" param is less than the length of
the given "iterable", no filling is done.
:param iterable:
:param int length: A number specifying the desired length of the resulting iterable.
:param Any fill_value: Any value to fill the given iterable.
:rtype: Generator
 Examples:
    from pymince.iterator import pad_end
    pad_end(("a", "b"), 3, fill_value="1") # --> "a" "b" "1"
    pad_end(("a", "b"), 3) # --> "a" "b" None
    pad_end(("a", "b", "c"), 3) # --> "a" "b" "c"
pad_start
pad_start(iterable, length, fill_value=None)
The function adds "fill_value" at the beginning of the iterable,
until it reaches the specified length.
If the value of the "length" param is less than the length of
the given "iterable", no filling is done.
:param iterable:
:param int length: A number specifying the desired length of the resulting iterable.
:param Any fill_value: Any value to fill the given iterable.
:rtype: Generator
 Examples:
    from pymince.iterator import pad_start
    pad_start(("a", "b"), 3, fill_value="1") # --> "1" "a" "b"
    pad_start(("a", "b"), 3) # --> None "a" "b"
    pad_start(("a", "b", "c"), 3) # --> "a" "b" "c"
partition
partition(predicate, iterable)
Split the iterable into two lists, based on the boolean return-value
of the predicate.
- (1): items that have predicate(item) == False.
- (2): items that have predicate(item) == True.
Examples:
    from pymince.iterator import partition
    is_odd = lambda x: x % 2 != 0
    even_items, odd_items = partition(is_odd, range(10))  # ([0, 2, 4, 6, 8], [1, 3, 5, 7, 9])
replacer
replacer(iterable, matcher, new_value, count=-1)
Make a generator that yields all occurrences of the old "iterable"
replaced by "new_value".
:param iterable:
:param matcher: Callable to find occurrences. It is an occurrence if the matcher returns True.
:param new_value: Any value to replace found occurrences.
:param int count:
    Maximum number of occurrences to replace.
    -1 (the default value) means replace all occurrences.
:rtype: Generator
Examples:
    from pymince.iterator import replacer
    is_one = lambda n: n == 1
    replacer([1,2,3,1,2,3], is_one, None) # → None 2 3 None 2 3
    replacer([1,2,3,1,2,3], is_one, None, count=1) # → None 2 3 1 2 3
splitter
splitter(iterable, sep, key=None, maxsplit=-1, container=None)
Splits an iterable based on a separator.
A separator will never appear in the output.
:param iterable:
:param sep: The delimiter to split the iterable.
:param key:
    A function to compare the equality of each element with the given delimiter.
    If the key function is not specified or is None, the element itself is used for compare.
:param maxsplit:
    Maximum number of splits to do.
    -1 (the default value) means no limit.
:param container: Callable to save the splits. By default tuple is used.
:return: Generator with consecutive splits of "iterable" without the delimiter item.
Examples:
    from pymince.iterator import splitter
    data = ("a", "b", "c", "d", "b", "e")
    split_n = splitter(data, "b")  # --> ("a",) ("c", "d") ("e",)
    split_1 = splitter(data, "b", maxsplit=1)  # --> ("a",) ("c", "d", "b", "e")
sub
sub(iterable)
Return the subtraction of a non-empty iterable of numbers and sets.
truediv
truediv(iterable)
Return the division of a non-empty iterable of numbers.
uniquer
uniquer(iterable, key=None)
Make a generator that returns each element from iterable only once
respecting the input order.
Examples:
    from pymince.iterator import uniquer
    uniquer([1, 2, 3, 2]) # → 1 2 3
uniques
uniques(iterable, key=None)
Check if all the elements of a key-based iterable are unique.
:param iterable:
:param key: None or "Callable" to compare if iterable items.
:rtype: bool
Examples:
    from pymince.iterator import uniques
    uniques([1,2]) # --> True
    uniques([1,1]) # --> False