一些调整:
-
您访问所选行的语法有点不正确。从
data.table
documentation
dataTableOutput()
; 你在哪里写的
input$addr_rows_selected
input$addressTable_rows_selected
为了找到用
DT::dataTableOutput("addressTable")
.
-
将输出类型与渲染类型混合。如果要将地址输出为文本(按行)
textOutput("selectedAddress")
renderText()
而不是
DT::renderDataTable()
.
-
paste(...,collapse = ",")
library(shiny)
library(data.table)
addr <- as.data.table(read.csv("addresses.csv", header = T, stringsAsFactors = F))
names(addr) [1:4]<- c("STREET ADDRESS","CITY NAME","PROVINCE","POSTAL CODE")
ui <- fluidPage(
br(),
fluidRow(
column(12, div(DT::dataTableOutput("addressTable"), style="font-family:verdana", align="left"))
),
fluidRow(
column(4, div(textOutput("selectedAddress"), align="center"))
)
)
server <- function(input, output) {
output$addressTable <- DT::renderDataTable({addr}, server = T, selection = 'single')
output$selectedAddress <- renderText({
selectedrowindex <- input$addressTable_rows_selected
selectedrowindex <- as.numeric(selectedrowindex)
selectedrow <- paste(addr[selectedrowindex,],collapse = ", ")
selectedrow
})
}
shinyApp(ui, server)