Je souhaite que mes utilisateurs créent une nouvelle variable et l'ajoutent à un bloc de données existant. Les utilisateurs doivent entrer le nom et la définition via textInput. Note: J'ai essayé toutes les suggestions postées dans Getting strings recognized as variable names in RDemander aux utilisateurs de spécifier un nouveau nom de variable et une nouvelle définition à l'aide de textInput
Pourtant, je ne suis pas capable de le faire fonctionner. Toutes les suggestions seront grandement appréciées. Je vous remercie!
Voici mon code:
rawdata:
colA <- c('1','2','3','3','2')
colB <- c('1','1','3','3','2')
colC <- c('14','12','33','33','26')
colD <- c('Value','Mainstream','Value','Premium','Premium')
colE <- c(1,2,3,4,5)
rawdata <- as.data.frame(cbind(colA, colB, colC, colD, colE))
ui.R:
fluidPage(
sidebarLayout(
sidebarPanel(
textInput("NewVar_Name", "New attribute's name"),
textInput("NewVar_Def", "New attribute's definition",
"ifelse(rawdata$price_tiers_new == 'Value', 1, 0)"),
br(),
actionButton("addButton", strong("Done!")),
width = 3
),
mainPanel(
verticalLayout(
br()
#Will display a summary of new variable
)
)
)
)
server.R:
function(input, output, session) {
temp <- reactiveValues()
observe(
if(input$addButton == 0) {
temp$df <- rawdata
} else {
temp$df <- mydata()
}
)
mydata <- eventReactive(input$addButton, {
if(input$addButton == 0) {
rawdata
} else {
tempname <- eval(as.name(input$NewVar_Name))
do.call("<-",list(tempname, eval(parse(text=input$NewVar_Def))))
cbind(temp$df, tempname)
}
})
}
Cela devrait fonctionner pour vous: https://stackoverflow.com/questions/44598544/allow-users-to-add-new-variables-to-a-dataset-in-shiny-app/44599073#44599073 – BigDataScientist
Ce fonctionne parfaitement pour ajouter de nouvelles variables (merci!). Cependant, dans cet exemple, nous n'obtenons pas les noms de variables des utilisateurs. – Ketty