闪亮:用于将数据从数据库加载到数据表(DT)的 ProgressBar
Shiny: ProgressBar for loading the data from database to datatable (DT)
我还没有找到关于 Shiny 中用于从数据库加载数据的 ProgressBar 的问题的解决方案。我的闪亮应用程序连接到数据库,用户直接从那里获取数据(因为我的 SQL 查询是反应性的,数据量会有所不同)。有时数据很大,加载需要一些时间。用户不知道是发生了什么事还是应用程序收到了 "stuck"。我在我的应用程序中(output$tabelle <- DT::renderDataTable({
...)实现了最简单的过程指示器,但似乎还不够:
progress <- shiny::Progress$new()
on.exit(progress$close())
progress$set(message = "Processing", value = 0)
用户仍然有点困惑。
我想要这样的 smthg (showing a status message in R) 使用 ?tcltk::tkProgressBar
:
pb <- tkProgressBar("test progress bar", "Some information in %",
0, 100, 50)
Sys.sleep(0.5)
u <- c(0, sort(runif(20, 0 ,100)), 100)
for(i in u) {
Sys.sleep(0.1)
info <- sprintf("%d%% done", round(i))
setTkProgressBar(pb, i, sprintf("test (%s)", info), info)
}
Sys.sleep(5)
close(pb)
用一定百分比评估从数据库加载数据的进度。
我不知道如何在我闪亮的应用程序中使用它。任何想法都会有所帮助。
提前致谢!
*一些简单的应用程序:
library("shiny")
library("DT")
shinyApp(
ui = fluidPage(DT::dataTableOutput('tbl')),
server = function(input, output) {
output$tbl = DT::renderDataTable(
iris)
}
)
可能最简单的方法是使用提供 busyIndicator
的软件包 shinysky
。您不会看到进度条,但中间的加载动画也应该有效。您还可以通过设置要显示的文本、gif 和指示器显示的时间来自定义它。 (默认情况下,一秒钟后)。
完整示例:
library("shiny")
library("DT")
library("shinysky")
shinyApp(
ui = fluidPage(
busyIndicator(),
h3("Test"),
hr(),
DT::dataTableOutput('tbl')
),
server = function(input, output) {
output$tbl = DT::renderDataTable({
data.frame(x = rnorm(7000000), y = runif(7000000))
})
}
)
我还没有找到关于 Shiny 中用于从数据库加载数据的 ProgressBar 的问题的解决方案。我的闪亮应用程序连接到数据库,用户直接从那里获取数据(因为我的 SQL 查询是反应性的,数据量会有所不同)。有时数据很大,加载需要一些时间。用户不知道是发生了什么事还是应用程序收到了 "stuck"。我在我的应用程序中(output$tabelle <- DT::renderDataTable({
...)实现了最简单的过程指示器,但似乎还不够:
progress <- shiny::Progress$new()
on.exit(progress$close())
progress$set(message = "Processing", value = 0)
用户仍然有点困惑。
我想要这样的 smthg (showing a status message in R) 使用 ?tcltk::tkProgressBar
:
pb <- tkProgressBar("test progress bar", "Some information in %",
0, 100, 50)
Sys.sleep(0.5)
u <- c(0, sort(runif(20, 0 ,100)), 100)
for(i in u) {
Sys.sleep(0.1)
info <- sprintf("%d%% done", round(i))
setTkProgressBar(pb, i, sprintf("test (%s)", info), info)
}
Sys.sleep(5)
close(pb)
用一定百分比评估从数据库加载数据的进度。
我不知道如何在我闪亮的应用程序中使用它。任何想法都会有所帮助。
提前致谢!
*一些简单的应用程序:
library("shiny")
library("DT")
shinyApp(
ui = fluidPage(DT::dataTableOutput('tbl')),
server = function(input, output) {
output$tbl = DT::renderDataTable(
iris)
}
)
可能最简单的方法是使用提供 busyIndicator
的软件包 shinysky
。您不会看到进度条,但中间的加载动画也应该有效。您还可以通过设置要显示的文本、gif 和指示器显示的时间来自定义它。 (默认情况下,一秒钟后)。
完整示例:
library("shiny")
library("DT")
library("shinysky")
shinyApp(
ui = fluidPage(
busyIndicator(),
h3("Test"),
hr(),
DT::dataTableOutput('tbl')
),
server = function(input, output) {
output$tbl = DT::renderDataTable({
data.frame(x = rnorm(7000000), y = runif(7000000))
})
}
)