Arhn - архитектура программирования

Заполнение последней записью группы

Скажем, у меня есть следующий кадр данных:

> df
                   C         D  E
A    B                           
bar  one   -1.350006  0.260339  2
     three -0.236451 -0.056614  0
flux six   -0.515571 -0.155078  1
     three -0.365032  1.055669  2
foo  five   1.145811  1.514191  0
     one   -0.108427 -0.643262  2
     two    0.286897  0.405798  2
     two   -1.452286  1.149264  2

If I do:

df.groupby(level='A').apply(lambda x: x[-1])

Я получил:

KeyError: -1

Почему? Я думал, что могу передать любую функцию apply в группе.

Я хочу следующее (получить последнюю запись в каждой группе):

> df
                   C         D  E
A    B                           
bar  one   -0.236451 -0.056614  2
     three -0.236451 -0.056614  2
flux six   -0.365032  1.055669  2
     three -0.365032  1.055669  2
foo  five  -1.452286  1.149264  2
     one   -1.452286  1.149264  2
     two   -1.452286  1.149264  2
     two   -1.452286  1.149264  2
30.07.2014

  • df.groupby(level='A').last() не работает? 31.07.2014
  • Спасибо @EdChum. Не совсем. Я хочу заполнить фрейм данных чем-то с таким же точным индексом 31.07.2014
  • df.groupby(level='A').transform(pd.Series.last) это работает? 31.07.2014
  • @EdChum Я только что попробовал, но получаю: TypeError: last() missing 1 required positional argument: 'offset' 31.07.2014
  • как насчет last = lambda x: x.iloc[-1] df.groupby(level='A').transform(last)? 31.07.2014
  • Спасибо @EdChum. Это не выдает ошибку, а просто возвращает исходный фрейм данных. Странный 31.07.2014
  • Я смотрел на это: stackoverflow.com/questions/15001237/ и документы: pandas.pydata.org/pandas-docs/stable/. По моему мнению, вы определенно хотите использовать преобразование 31.07.2014
  • @EdCHum Я согласен с transform, хотя я думал, что вы можете имитировать поведение transform с помощью применения (что является более общим) 31.07.2014
  • @EdChum Оказывается, это ошибка: github.com/pydata/pandas/issues/7883 Я только что создал тикет. 31.07.2014
  • Ах, это хорошо. Надеюсь, это будет исправлено в следующем выпуске, возможно, есть обходной путь, который я думаю. 31.07.2014
  • Для справки в будущем: если вы вставите свой фрейм данных, вставьте его как df.reset_index(), иначе pd.read_clipboard() не будет работать должным образом. 31.07.2014
  • Спасибо @FooBar Приятно знать. 31.07.2014

Новые материалы

Коллекции публикаций по глубокому обучению
Последние пару месяцев я создавал коллекции последних академических публикаций по различным подполям глубокого обучения в моем блоге https://amundtveit.com - эта публикация дает обзор 25..

Представляем: Pepita
Фреймворк JavaScript с открытым исходным кодом Я знаю, что недостатка в фреймворках JavaScript нет. Но я просто не мог остановиться. Я хотел написать что-то сам, со своими собственными..

Советы по коду Laravel #2
1-) Найти // You can specify the columns you need // in when you use the find method on a model User::find(‘id’, [‘email’,’name’]); // You can increment or decrement // a field in..

Работа с временными рядами спутниковых изображений, часть 3 (аналитика данных)
Анализ временных рядов спутниковых изображений для данных наблюдений за большой Землей (arXiv) Автор: Рольф Симоэс , Жильберто Камара , Жильберто Кейрос , Фелипе Соуза , Педро Р. Андраде ,..

3 способа решить квадратное уравнение (3-й мой любимый) -
1. Методом факторизации — 2. Используя квадратичную формулу — 3. Заполнив квадрат — Давайте поймем это, решив это простое уравнение: Мы пытаемся сделать LHS,..

Создание VR-миров с A-Frame
Виртуальная реальность (и дополненная реальность) стали главными модными терминами в образовательных технологиях. С недорогими VR-гарнитурами, такими как Google Cardboard , и использованием..

Демистификация рекурсии
КОДЕКС Демистификация рекурсии Упрощенная концепция ошеломляющей О чем весь этот шум? Рекурсия, кажется, единственная тема, от которой у каждого начинающего студента-информатика..