【发布时间】:2020-12-24 13:08:26
【问题描述】:
我想创建一个闪亮的应用程序,用户必须在其中编辑数据表。 有代码包含可复现的例子:
library(shiny)
library(dplyr)
library(DT)
line<-c(1,1,1,1,1)
op<-c(155,155,155,156,156)
batch<-c(1,2,3,1,2)
voile<-c(1,NA,NA,NA,NA)
depot<-c(2,NA,2,NA,NA)
boe<-data.frame(line,op,batch)
ui <- fluidPage(
# Application title
titlePanel("test dust"),
actionButton("refresh", label = "refresh"),
DT::dataTableOutput("mytable"),
actionButton("save", label = "save"),
)
# Define server logic required to draw a histogram
server <- function(input, output) {
DTdust<- eventReactive(input$refresh, {
DTdust <-data.frame(line,op,batch,voile,depot)
})
merged<-reactive({
merged<-merge(boe,DTdust(),all.x = TRUE)
})
mergedfiltred<-reactive({
mergedfiltred<- filter(merged(),is.na(voile)|is.na(depot) )
})
output$mytable = DT::renderDataTable( mergedfiltred(),editable = list(target = 'cell',
disable = list(columns = c(1:3))),selection = 'none'
)
}
# Run the application
shinyApp(ui = ui, server = server)
我希望这样工作——>
当用户点击刷新按钮时。读取 Dtdust.csv(此处为模拟),然后将其与 boe.csv(也模拟)合并为过滤器,以仅获取没有结果的行,用于 voile 和 depot col。 并显示这个合并的过滤 ino 可编辑数据表。
这部分有效。
在我想从已编辑的数据表中提取数据以对其进行一些处理之后(提取完成的行,在 dtdust 上 rbind 并保存为 dtdust.csv。但我认为没关系。) 我无法提取已编辑的数据表。 我看到了一些使用经典数据框的示例,但它不适用于响应式数据框。
我是初学者,所以如果你能对你的答案发表很多评论,我可以学习如何而不只是 ctrl+c ctrl+v 你的代码:)
谢谢
【问题讨论】:
标签: r shiny datatables