У меня есть фрейм данных с такими столбцами:
x y z
1 10 20
2 10 18
3 11 16.5
4 11 12
5 12 23
6 11 21
7 10 19
8 10 26
.
.
Каждый раз, когда z_n+1 больше z_n, я хочу сократить это z_n.
Результат будет:
x y z
1 10 20
2 10 18
3 11 16.5
5 12 23
6 11 21
8 10 26
.
.
Это не происходит каждый x-много раз - индекс каждого изменения от меньшего к большему z_n не является «регулярным».
Есть простой способ сделать это?






Пытаться:
df[~(df.z.diff(-1) < 0)]
Выход:
x y z
0 1 10 20.0
1 2 10 18.0
2 3 11 16.5
4 5 12 23.0
5 6 11 21.0
7 8 10 26.0
Мы можем использовать shift, чтобы вернуться на одну строку назад и перейти в обратном направлении с помощью ~:
df[~(df['z'].shift() < df['z'])]
x y z
0 1 10 20.0
1 2 10 18.0
2 3 11 16.5
3 4 11 12.0
5 6 11 21.0
6 7 10 19.0
Проверьте свой вывод. Я думаю, что 19 должны быть исключены.
df.drop(df.z.diff().le(0))?