В настоящее время я пытаюсь создать новый столбец в кадре данных Polars (df). В моем df много строк, и в этом новом столбце я хочу, чтобы мой существующий список заполнялся только там, где выполняются определенные условия.
import polars as pl
df = pl.DataFrame({
'cond1': [-1, 0, 1, 2, 2, 3, 4, 5],
'cond2': ['No', 'No', 'No', 'Yes','Yes', 'Yes', 'Yes', 'Yes']
})
Я знаю, что в pandas я мог бы сделать что-то вроде следующего (где «выход» — это мой новый столбец и предполагается, что список имеет ту же длину, что и отфильтрованный df):
df_pd = df.to_pandas()
conditions = ((df_pd['cond1']>=1) & (df_pd['cond2'] == 'Yes'))
list_new = [1,2,3,4,5]
df_pd.loc[conditions, 'output'] = list_new
# cond1 cond2 output
# 0 -1 No NaN
# 1 0 No NaN
# 2 1 No NaN
# 3 2 Yes 1.0
# 4 2 Yes 2.0
# 5 3 Yes 3.0
# 6 4 Yes 4.0
# 7 5 Yes 5.0
Как бы я сделал то же самое, но в пределах поляров? Я хочу, чтобы общее количество строк оставалось прежним, я просто хочу обновить новый столбец везде, где выполняются условия.
Я попробовал несколько вариантов следующих действий, но ничего не помогло:
df = df.with_columns(pl.when(conditions).then(list_new).alias('output')
Подробнее здесь: https://stackoverflow.com/questions/786 ... rows-match
Как создать новый столбец в Polars, используя значения из списка только в строках, соответствующих логическому условию? ⇐ Python
Программы на Python
1762257296
Anonymous
В настоящее время я пытаюсь создать новый столбец в кадре данных Polars (df). В моем df много строк, и в этом новом столбце я хочу, чтобы мой существующий список заполнялся только там, где выполняются определенные условия.
import polars as pl
df = pl.DataFrame({
'cond1': [-1, 0, 1, 2, 2, 3, 4, 5],
'cond2': ['No', 'No', 'No', 'Yes','Yes', 'Yes', 'Yes', 'Yes']
})
Я знаю, что в pandas я мог бы сделать что-то вроде следующего (где «выход» — это мой новый столбец и предполагается, что список имеет ту же длину, что и отфильтрованный df):
df_pd = df.to_pandas()
conditions = ((df_pd['cond1']>=1) & (df_pd['cond2'] == 'Yes'))
list_new = [1,2,3,4,5]
df_pd.loc[conditions, 'output'] = list_new
# cond1 cond2 output
# 0 -1 No NaN
# 1 0 No NaN
# 2 1 No NaN
# 3 2 Yes 1.0
# 4 2 Yes 2.0
# 5 3 Yes 3.0
# 6 4 Yes 4.0
# 7 5 Yes 5.0
Как бы я сделал то же самое, но в пределах поляров? Я хочу, чтобы общее количество строк оставалось прежним, я просто хочу обновить новый столбец везде, где выполняются условия.
Я попробовал несколько вариантов следующих действий, но ничего не помогло:
df = df.with_columns(pl.when(conditions).then(list_new).alias('output')
Подробнее здесь: [url]https://stackoverflow.com/questions/78620206/how-to-create-a-new-column-in-polars-using-values-from-a-list-only-on-rows-match[/url]
Ответить
1 сообщение
• Страница 1 из 1
Перейти
- Кемерово-IT
- ↳ Javascript
- ↳ C#
- ↳ JAVA
- ↳ Elasticsearch aggregation
- ↳ Python
- ↳ Php
- ↳ Android
- ↳ Html
- ↳ Jquery
- ↳ C++
- ↳ IOS
- ↳ CSS
- ↳ Excel
- ↳ Linux
- ↳ Apache
- ↳ MySql
- Детский мир
- Для души
- ↳ Музыкальные инструменты даром
- ↳ Печатная продукция даром
- Внешняя красота и здоровье
- ↳ Одежда и обувь для взрослых даром
- ↳ Товары для здоровья
- ↳ Физкультура и спорт
- Техника - даром!
- ↳ Автомобилистам
- ↳ Компьютерная техника
- ↳ Плиты: газовые и электрические
- ↳ Холодильники
- ↳ Стиральные машины
- ↳ Телевизоры
- ↳ Телефоны, смартфоны, плашеты
- ↳ Швейные машинки
- ↳ Прочая электроника и техника
- ↳ Фототехника
- Ремонт и интерьер
- ↳ Стройматериалы, инструмент
- ↳ Мебель и предметы интерьера даром
- ↳ Cантехника
- Другие темы
- ↳ Разное даром
- ↳ Давай меняться!
- ↳ Отдам\возьму за копеечку
- ↳ Работа и подработка в Кемерове
- ↳ Давай с тобой поговорим...
Мобильная версия