On this page
pandas.arrays.IntegerArray.take
- IntegerArray.take(indexer, allow_fill=False, fill_value=None)[source]
- 
    Take elements from an array. Parameters: - 
           indices : sequence of integers
- 
           Indices to be taken. 
- 
           allow_fill : bool, default False
- 
           How to handle negative values in indices.- False: negative values in indicesindicate positional indices from the right (the default). This is similar tonumpy.take().
- True: negative values in indicesindicate missing values. These values are set tofill_value. Any other other negative values raise aValueError.
 
- False: negative values in 
- 
           fill_value : any, optional
- 
           Fill value to use for NA-indices when allow_fillis True. This may beNone, in which case the default NA value for the type,self.dtype.na_value, is used.For many ExtensionArrays, there will be two representations of fill_value: a user-facing “boxed” scalar, and a low-level physical NA value.fill_valueshould be the user-facing version, and the implementation should handle translating that to the physical version for processing the take if necessary.
 Returns: - ExtensionArray
 Raises: - IndexError
- 
           When the indices are out of bounds for the array. 
- ValueError
- 
           When indicescontains negative values other than-1andallow_fillis True.
 See also numpy.take,pandas.api.extensions.takeNotesExtensionArray.take is called by Series.__getitem__,.loc,iloc, whenindicesis a sequence of values. Additionally, it’s called bySeries.reindex(), or any other method that causes realignment, with afill_value.ExamplesHere’s an example implementation, which relies on casting the extension array to object dtype. This uses the helper method pandas.api.extensions.take().def take(self, indices, allow_fill=False, fill_value=None): from pandas.core.algorithms import take # If the ExtensionArray is backed by an ndarray, then # just pass that here instead of coercing to object. data = self.astype(object) if allow_fill and fill_value is None: fill_value = self.dtype.na_value # fill value should always be translated from the scalar # type for the array, to the physical storage type for # the data, before passing to take. result = take(data, indices, fill_value=fill_value, allow_fill=allow_fill) return self._from_sequence(result, dtype=self.dtype)
- 
           
© 2008–2012, AQR Capital Management, LLC, Lambda Foundry, Inc. and PyData Development Team
Licensed under the 3-clause BSD License.
 https://pandas.pydata.org/pandas-docs/version/0.24.2/reference/api/pandas.arrays.IntegerArray.take.html