Использовать новый возвращаемый столбец DataFrames.combine в качестве аргумента в Julia

Я пытаюсь использовать DataFrames.combine для цепочки нескольких преобразований. Желаемый окончательный DataFrame приведен ниже.

using DataFrames, Statistics

df = DataFrame(x = repeat([1], 4))

df_2 = combine(df, 
        :x => sum => :sum_x)

df_2.sqrt_sum_x .= sqrt.(df_2.sum_x)

println(df_2)
#1×2 DataFrame
# Row │ sum_x  sqrt_sum_x 
#     │ Int64  Float64
#─────┼───────────────────
#   1 │     4         2.0

Мне было интересно, есть ли способ достичь предыдущего результата с помощью одного вызова combine. Например. используя новый target_cols:sum_x в качестве столбца в аргументе (см. код ниже). Однако это, кажется, выдает ArgumentError, так как не может найти недавно вычисленный столбец :sum_x.

combine(df, 
        :x => sum => :sum_x,
        :sum_x => sqrt => :sqrt_sum_x)
# ERROR: ArgumentError: column name :sum_x not found in the data frame
Формы c голосовым вводом в React с помощью Speechly
Формы c голосовым вводом в React с помощью Speechly
Пытались ли вы когда-нибудь заполнить веб-форму в области электронной коммерции, которая требует много кликов и выбора? Вас попросят заполнить дату,...
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Стилизация и валидация html-формы без использования JavaScript (только HTML/CSS)
Будучи разработчиком веб-приложений, легко впасть в заблуждение, считая, что приложение без JavaScript не имеет права на жизнь. Нам становится удобно...
Flatpickr: простой модуль календаря для вашего приложения на React
Flatpickr: простой модуль календаря для вашего приложения на React
Если вы ищете пакет для быстрой интеграции календаря с выбором даты в ваше приложения, то библиотека Flatpickr отлично справится с этой задачей....
В чем разница между Promise и Observable?
В чем разница между Promise и Observable?
Разберитесь в этом вопросе, и вы значительно повысите уровень своей компетенции.
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Что такое cURL в PHP? Встроенные функции и пример GET запроса
Клиент для URL-адресов, cURL, позволяет взаимодействовать с множеством различных серверов по множеству различных протоколов с синтаксисом URL.
Четыре эффективных способа центрирования блочных элементов в CSS
Четыре эффективных способа центрирования блочных элементов в CSS
У каждого из нас бывали случаи, когда нам нужно отцентрировать блочный элемент, но мы не знаем, как это сделать. Даже если мы реализуем какой-то...
2
0
15
1
Перейти к ответу Данный вопрос помечен как решенный

Ответы 1

Ответ принят как подходящий

В настоящее время это не разрешено. Причина в том, что порядок выполнения преобразований в combine не определен. В частности, в некоторых ситуациях эти операции выполняются параллельно с использованием многопоточности (для повышения производительности).

Кроме того, такая операция потенциально может быть проблематичной при интерпретации, например, если вы написали бы:

combine(df, 
        :x => sum => :sum_x,
        [:x, :sum_x] => (+) => :x_plus_sum_x)

затем в преобразовании:

[:x, :sum_x] => + => :x_plus_sum_x

:x будет поступать из исходного фрейма данных df (и иметь 4 элемента), а :sum_x будет поступать из «еще не существующего» целевого фрейма данных (и иметь 1 элемент). Технически это можно было бы заставить работать, но мы посчитали, что это может сбивать с толку.

Другие вопросы по теме