pandas.Series.loc#
- свойство Series.loc[источник]#
Доступ к группе строк и столбцов по метке(ам) или булевому массиву.
.loc[]в основном основан на метках, но также может использоваться с логическим массивом.Допустимые входные данные:
Одна метка, например
5или'a', (обратите внимание, что5интерпретируется как метка индекса, и никогда как целочисленная позиция вдоль индекса).Список или массив меток, например.
['a', 'b', 'c'].Объект среза с метками, например.
'a':'f'.Предупреждение
Обратите внимание, что в отличие от обычных срезов Python, оба начало и конец включены
Логический массив той же длины, что и ось, по которой производится срез, например.
[True, False, True].Выравниваемый булев Series. Индекс ключа будет выровнен перед маскированием.
Выравниваемый Index. Index возвращаемой выборки будет входным.
A
callableфункция с одним аргументом (вызывающий Series или DataFrame) и возвращающая допустимый вывод для индексирования (один из вышеперечисленных)
Подробнее см. Выбор по метке.
- Вызывает:
- KeyError
Если какие-либо элементы не найдены.
- IndexingError
Если передан индексированный ключ и его индекс не может быть выровнен с индексом фрейма.
Смотрите также
DataFrame.atПолучите одно значение для пары меток строки/столбца.
DataFrame.ilocДоступ к группе строк и столбцов по целочисленной позиции(ям).
DataFrame.xsВозвращает поперечное сечение (строки или столбцы) из Series/DataFrame.
Series.locДоступ к группе значений с использованием меток.
Примеры
Получение значений
>>> df = pd.DataFrame([[1, 2], [4, 5], [7, 8]], ... index=['cobra', 'viper', 'sidewinder'], ... columns=['max_speed', 'shield']) >>> df max_speed shield cobra 1 2 viper 4 5 sidewinder 7 8
Одиночная метка. Обратите внимание, что это возвращает строку как Series.
>>> df.loc['viper'] max_speed 4 shield 5 Name: viper, dtype: int64
Список меток. Обратите внимание, что использование
[[]]возвращает DataFrame.>>> df.loc[['viper', 'sidewinder']] max_speed shield viper 4 5 sidewinder 7 8
Одиночная метка для строки и столбца
>>> df.loc['cobra', 'shield'] 2
Срез с метками для строк и одной меткой для столбца. Как упоминалось выше, обратите внимание, что и начало, и конец среза включены.
>>> df.loc['cobra':'viper', 'max_speed'] cobra 1 viper 4 Name: max_speed, dtype: int64
Булев список той же длины, что и ось строк
>>> df.loc[[False, False, True]] max_speed shield sidewinder 7 8
Выравниваемая булева серия:
>>> df.loc[pd.Series([False, True, False], ... index=['viper', 'sidewinder', 'cobra'])] max_speed shield sidewinder 7 8
Index (такое же поведение, как у
df.reindex)>>> df.loc[pd.Index(["cobra", "viper"], name="foo")] max_speed shield foo cobra 1 2 viper 4 5
Условие, возвращающее булевый Series
>>> df.loc[df['shield'] > 6] max_speed shield sidewinder 7 8
Условное выражение, возвращающее булевый Series с указанными метками столбцов
>>> df.loc[df['shield'] > 6, ['max_speed']] max_speed sidewinder 7
Множественное условие с использованием
&который возвращает булевый Series>>> df.loc[(df['max_speed'] > 1) & (df['shield'] < 8)] max_speed shield viper 4 5
Множественное условие с использованием
|который возвращает булевый Series>>> df.loc[(df['max_speed'] > 4) | (df['shield'] < 5)] max_speed shield cobra 1 2 sidewinder 7 8
Пожалуйста, убедитесь, что каждое условие заключено в скобки
(). См. руководство пользователя для получения дополнительных деталей и объяснений булевой индексации.Примечание
Если вы используете 3 или более условных операторов в
.loc[], рассмотрите использование расширенная индексация.Смотрите ниже для использования
.loc[]на MultiIndex DataFrames.Вызываемый объект, возвращающий булевый Series
>>> df.loc[lambda df: df['shield'] == 8] max_speed shield sidewinder 7 8
Установка значений
Установить значение для всех элементов, соответствующих списку меток
>>> df.loc[['viper', 'sidewinder'], ['shield']] = 50 >>> df max_speed shield cobra 1 2 viper 4 50 sidewinder 7 50
Установить значение для всей строки
>>> df.loc['cobra'] = 10 >>> df max_speed shield cobra 10 10 viper 4 50 sidewinder 7 50
Установить значение для всего столбца
>>> df.loc[:, 'max_speed'] = 30 >>> df max_speed shield cobra 30 10 viper 30 50 sidewinder 30 50
Установить значение для строк, соответствующих вызываемому условию
>>> df.loc[df['shield'] > 35] = 0 >>> df max_speed shield cobra 30 10 viper 0 0 sidewinder 0 0
Добавить значение, соответствующее местоположению
>>> df.loc["viper", "shield"] += 5 >>> df max_speed shield cobra 30 10 viper 0 5 sidewinder 0 0
Установка с использованием
SeriesилиDataFrameустанавливает значения, соответствующие меткам индекса, а не позициям индекса.>>> shuffled_df = df.loc[["viper", "cobra", "sidewinder"]] >>> df.loc[:] += shuffled_df >>> df max_speed shield cobra 60 20 viper 0 10 sidewinder 0 0
Получение значений в DataFrame с индексом, имеющим целочисленные метки
Другой пример использования целых чисел для индекса
>>> df = pd.DataFrame([[1, 2], [4, 5], [7, 8]], ... index=[7, 8, 9], columns=['max_speed', 'shield']) >>> df max_speed shield 7 1 2 8 4 5 9 7 8
Срез с целочисленными метками для строк. Как упомянуто выше, обратите внимание, что и начало, и конец среза включены.
>>> df.loc[7:9] max_speed shield 7 1 2 8 4 5 9 7 8
Получение значений с MultiIndex
Несколько примеров использования DataFrame с MultiIndex
>>> tuples = [ ... ('cobra', 'mark i'), ('cobra', 'mark ii'), ... ('sidewinder', 'mark i'), ('sidewinder', 'mark ii'), ... ('viper', 'mark ii'), ('viper', 'mark iii') ... ] >>> index = pd.MultiIndex.from_tuples(tuples) >>> values = [[12, 2], [0, 4], [10, 20], ... [1, 4], [7, 1], [16, 36]] >>> df = pd.DataFrame(values, columns=['max_speed', 'shield'], index=index) >>> df max_speed shield cobra mark i 12 2 mark ii 0 4 sidewinder mark i 10 20 mark ii 1 4 viper mark ii 7 1 mark iii 16 36
Одна метка. Обратите внимание, что это возвращает DataFrame с одним индексом.
>>> df.loc['cobra'] max_speed shield mark i 12 2 mark ii 0 4
Одиночный кортеж индекса. Обратите внимание, что возвращается Series.
>>> df.loc[('cobra', 'mark ii')] max_speed 0 shield 4 Name: (cobra, mark ii), dtype: int64
Одиночная метка для строки и столбца. Аналогично передаче кортежа, это возвращает Series.
>>> df.loc['cobra', 'mark i'] max_speed 12 shield 2 Name: (cobra, mark i), dtype: int64
Одиночный кортеж. Обратите внимание на использование
[[]]возвращает DataFrame.>>> df.loc[[('cobra', 'mark ii')]] max_speed shield cobra mark ii 0 4
Одиночный кортеж для индекса с одной меткой для столбца
>>> df.loc[('cobra', 'mark i'), 'shield'] 2
Срез из кортежа индексов в одиночную метку
>>> df.loc[('cobra', 'mark i'):'viper'] max_speed shield cobra mark i 12 2 mark ii 0 4 sidewinder mark i 10 20 mark ii 1 4 viper mark ii 7 1 mark iii 16 36
Срез от кортежа индекса до кортежа индекса
>>> df.loc[('cobra', 'mark i'):('viper', 'mark ii')] max_speed shield cobra mark i 12 2 mark ii 0 4 sidewinder mark i 10 20 mark ii 1 4 viper mark ii 7 1
Пожалуйста, ознакомьтесь с руководство пользователя для получения дополнительных сведений и объяснений расширенного индексирования.