ak.count#
Defined in awkward.operations.ak_count on line 23.
- ak.count(array, axis=None, *, keepdims=False, mask_identity=False, highlevel=True, behavior=None, attrs=None)#
- Parameters:
array – Array-like data (anything
ak.to_layout
recognizes).axis (None or int) – If None, combine all values from the array into a single scalar result; if an int, group by that axis:
0
is the outermost,1
is the first level of nested lists, etc., and negativeaxis
counts from the innermost:-1
is the innermost,-2
is the next level up, etc.keepdims (bool) – If False, this reducer decreases the number of dimensions by 1; if True, the reduced values are wrapped in a new length-1 dimension so that the result of this operation may be broadcasted with the original array.
mask_identity (bool) – If True, reducing over empty lists results in None (an option type); otherwise, reducing over empty lists results in the operation’s identity.
highlevel (bool) – If True, return an
ak.Array
; otherwise, return a low-levelak.contents.Content
subclass.behavior (None or dict) – Custom
ak.behavior
for the output array, if high-level.attrs (None or dict) – Custom attributes for the output array, if high-level.
Counts elements of array
(many types supported, including all
Awkward Arrays and Records). The identity of counting is 0
and it is
usually not masked.
This function has no analog in NumPy because counting values in a rectilinear array would only result in elements of the NumPy array’s shape.
However, for nested lists of variable dimension and missing values, the result of counting is non-trivial. For example, with this
>>> array = ak.Array([[ 0.1, 0.2 ],
... [None, 10.2, None],
... None,
... [20.1, 20.2, 20.3],
... [30.1, 30.2 ]])
the result of counting over the innermost dimension is
>>> ak.count(array, axis=-1)
<Array [2, 1, None, 3, 2] type='5 * ?int64'>
the outermost dimension is
>>> ak.count(array, axis=0)
<Array [3, 4, 1] type='3 * int64'>
and all dimensions is
>>> ak.count(array, axis=None)
8
The gaps and None values are not counted, and if a None value occurs at a higher axis than the one being counted, it is kept as a placeholder so that the outer list length does not change.
See ak.sum
for a more complete description of nested list and missing
value (None) handling in reducers.
Note also that this function is different from ak.num
, which counts
the number of values at a given depth, maintaining structure: ak.num
never counts across different lists the way that reducers do (ak.num
is not a reducer; ak.count
is). For the same array
,
>>> ak.num(array, axis=0)
5
>>> ak.num(array, axis=1)
<Array [2, 3, None, 3, 2] type='5 * ?int64'>
If it is desirable to include None values in ak.count
, use ak.fill_none
to turn the None values into something that would be counted.
If it is desirable to exclude NaN (“not a number”) values from ak.count
,
use ak.nan_to_none
to turn them into None, which are not counted.