pandas.MultiIndex.get_loc_level#

MultiIndex.get_loc_level(key, level=0, drop_level=True)[source]#

Get location and sliced index for requested label(s)/level(s).

The get_loc_level method is a more advanced form of get_loc, allowing users to specify not just a label or sequence of labels, but also the level(s) in which to search. This method is useful when you need to isolate particular sections of a MultiIndex, either for further analysis or for slicing and dicing the data. The method provides flexibility in terms of maintaining or dropping levels from the resulting index based on the drop_level parameter.

Parameters:
keylabel or sequence of labels

The label(s) for which to get the location.

levelint/level name or list thereof, optional

The level(s) in the MultiIndex to consider. If not provided, defaults to the first level.

drop_levelbool, default True

If False, the resulting index will not drop any level.

Returns:
tuple

A 2-tuple where the elements :

Element 0: int, slice object or boolean array.

Element 1: The resulting sliced multiindex/index. If the key contains all levels, this will be None.

See also

MultiIndex.get_loc

Get location for a label or a tuple of labels.

MultiIndex.get_locs

Get location for a label/slice/list/mask or a sequence of such.

Examples

>>> mi = pd.MultiIndex.from_arrays([list("abb"), list("def")], names=["A", "B"])
>>> mi.get_loc_level("b")
(slice(1, 3, None), Index(['e', 'f'], dtype='object', name='B'))
>>> mi.get_loc_level("e", level="B")
(array([False,  True, False]), Index(['b'], dtype='object', name='A'))
>>> mi.get_loc_level(["b", "e"])
(1, None)