- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是第一次使用 shinydashboard,它很棒。但是我陷入了一个奇怪的问题。我有以下代码在我的浏览器上运行。然而,当部署在 shinyapps.io 上时,它只是拒绝工作。我提供了下面的代码。仪表板旨在做 3 件事:
1.可视化因变量
2.自动用红色垂直线在图表上用日期虚拟标记尖峰
3.查看选择的自变量和虚拟变量
这是 shinyapps.io 中应用程序的链接 http://rajarshibhadra.shinyapps.io/Test_Doubts
代码如下
ui.R
library(shiny)
library(shinydashboard)
library(dygraphs)
dashboardPage(
dashboardHeader(title="Dashboard"),
dashboardSidebar(
sidebarMenu(
menuItem("Dashboard",tabName="dashboard",icon=icon("dashboard"))
)
),
dashboardBody(
tabItems(
tabItem(tabName = "dashboard",
fluidRow(
column(12,
box(title = "Plot Dependant", status = "primary", solidHeader = TRUE,
collapsible = TRUE,
dygraphOutput("final_plot",width = "100%", height = "300px"),width=8),
box(title="Model Specifications",status="warning",solidHeader= TRUE,
collapsible= TRUE,
uiOutput("mg"),width=4
)),
column(12,
tabBox(title="Independants and Dummies",
tabPanel("Independants",verbatimTextOutput("modelvars")),
tabPanel("Dummies",verbatimTextOutput("modeldummies")),width=8
),
box(title = "Inputs", status = "warning", solidHeader = TRUE,
collapsible = TRUE,
uiOutput("dependant"),
uiOutput("independant"),
uiOutput("dummies"),
sliderInput("spikes","Magnitude of strictness of crtiteria for spike",min=1,max=5,value=3,step=1),
sliderInput("dips","Magnitude of strictness of crtiteria for dips",min=1,max=5,value=3,step=1),width=4)
))
)
)
))
server.R
library(shiny)
library(stats)
library(dplyr)
library(dygraphs)
##
library(shinydashboard)
function(input, output) {
raw_init<-data.frame(wek_end_fri=c("06Jul2012","13Jul2012","20Jul2012","27Jul2012","03Aug2012","06Jul2012","13Jul2012","20Jul2012","27Jul2012","03Aug2012"),
Var1=c(468.9,507.1,447.1,477.1,452.6,883113.7,814778.0,780691.2,793416.6,833959.6),
Var2=c(538672.6,628451.4,628451.4,628451.4,359115.8,54508.8,56036.1,57481.0,58510.0,59016.7),
MG= c("Cat1","Cat1","Cat1","Cat1","Cat1","Cat1","Cat1","Cat1","Cat1","Cat1","Cat2","Cat2","Cat2","Cat2","Cat2","Cat2","Cat2","Cat2","Cat2","Cat2")
)
#Select Category
output$mg<-renderUI({
selectInput("Category","Select Category",c("Cat1","Cat2"))
})
raw_init_filter<-reactive({
filter(raw_init,MG == input$Category)
})
#Interpret Date
raw_init_date<-reactive({
mutate(raw_init_filter(),wek_end_fri=as.Date(wek_end_fri,"%d%b%Y"))
})
#Get variable Names
Variable_list<-reactive({
colnames(raw_init_date())
})
#Get potential dummy list
Dummy_List<-reactive({
raw_init_date()$wek_end_fri
})
#Load dependant
output$dependant<-renderUI({
selectInput("deplist","Select Dependant Variable",Variable_list(),selected="Var1")
})
#load independant
output$independant<-renderUI({
selectInput("indeplist","Select Independant Variable",Variable_list(),multiple=TRUE)
})
#Sepereate out Dependant
dep<-reactive({
raw_init_date()[input$deplist]
})
#Spike detection
plot_data<-reactive({
data.frame(Time=raw_init_date()$wek_end_fri,dep())
})
plot_data_mut<-reactive({
f <- plot_data()
colnames(f)[colnames(f)==input$deplist] <- "Volume"
f
})
dep_vec<-reactive({
as.vector(plot_data_mut()$Volume)
})
#Calculating mean
dep_mean<-reactive({
mean(dep_vec())
})
dep_sd<-reactive({
sd(dep_vec())
})
transformed_column<-reactive({
(dep_vec()-dep_mean())/dep_sd()
})
detected_index_spike<-reactive({
which(transformed_column()>input$spikes/2)
})
detected_index_trough<-reactive({
which(transformed_column()<(input$dips/(-2)))
})
detected_index<-reactive({
c(detected_index_spike(),detected_index_trough())
})
detected_dates<-reactive({
raw_init_date()$wek_end_fri[detected_index()]
})
output$dummies<-renderUI({
validate(
need(raw_init, 'Upload Data to see controls and results')
)
selectInput("dummies","Suggested Dummy Variable",as.character(Dummy_List()),selected=as.character(detected_dates()),multiple=TRUE)
})
indlist<-reactive({
data.frame(Independant_Variables=input$indeplist)
})
output$modelvars<-renderPrint({
indlist()
})
dumlist<-reactive({
data.frame(Dummies=paste("Dummy_",as.character(format(as.Date(input$dummies,"%Y-%b-%d"),"%d%b%y")),sep=""))
})
output$modeldummies<-renderPrint({
dumlist()
})
#-----------------------------------------------------------------------------------------#
library(xts)
plot_data_xts<-reactive({
xts(dep(),order.by=as.Date(raw_init_filter()$wek_end_fri,"%d%b%Y"))
})
##
getDates <- reactive({
as.character(input$dummies)
})
addEvent <- function(x,y) {
dyEvent(
dygraph=x,
date=y,
"",
labelLoc = "bottom",
color = "red",
strokePattern = "dashed")
}
basePlot <- reactive({
if (length(getDates()) < 1) {
dygraph(
plot_data_xts(),
main="Initial Visualization and dummy detection") %>%
dyAxis(
"y",
label = "Volume") %>%
dyOptions(
axisLabelColor = "Black",
digitsAfterDecimal = 2,
drawGrid = FALSE)
} else {
dygraph(
plot_data_xts(),
main="Initial Visualization and dummy detection") %>%
dyAxis(
"y",
label = "Volume") %>%
dyOptions(
axisLabelColor = "Black",
digitsAfterDecimal = 2,
drawGrid = FALSE) %>%
dyEvent(
dygraph=.,
date=getDates()[1],
"",
labelLoc = "bottom",
color = "red",
strokePattern = "dashed")
}
})
##
output$final_plot <- renderDygraph({
res <- basePlot()
more_dates <- getDates()
if (length(more_dates) < 2) {
res
} else {
Reduce(function(i,z){
i %>% addEvent(x=.,y=z)
}, more_dates[-1], init=res)
}
})
}
最佳答案
您的应用 https://rajarshibhadra.shinyapps.io/Test_Doubts/在“Plot Dependant”框中显示以下错误消息:
Error: can not calculate periodicity of 1 observation
我已加载您的脚本并在本地运行应用程序:我能够重现它并获得相同的错误消息。
这是由于 as.Date 转换:%b 未转换导致 xts 和 dygraph 包中的 NA。这是由于语言环境(请参阅 here 和 here )。
通过使用更常见的日期规范(例如“%d/%m/%Y”)可以轻松修复:
raw_init<-data.frame(wek_end_fri=c("06/07/2012","13/07/2012","20/07/2012","27/07/2012","03/08/2012","06/07/2012","13/07/2012","20/07/2012","27/07/2012","03/08/2012"),
和
#Interpret Date
raw_init_date<-reactive({
mutate(raw_init_filter(),wek_end_fri=as.Date(wek_end_fri,"%d/%m/%Y"))
})
和
dumlist<-reactive({
data.frame(Dummies=paste("Dummy_",as.character(format(as.Date(input$dummies,"%d/%m/%Y"),"%d/%m/%Y")),sep=""))
})
output$modeldummies<-renderPrint({
dumlist()
})
#-----------------------------------------------------------------------------------------#
library(xts)
plot_data_xts<-reactive({
xts(dep(),order.by=as.Date(raw_init_filter()$wek_end_fri,"%d/%m/%Y"))
})
关于r - shinydashboard 中的仪表板,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28627285/
我想根据盒子是否折叠在服务器端做一些操作。是否有可能在服务器端知道 Shiny 仪表板中的框是否折叠? [编辑]: 在通过 warmoverflow 提供的链接并通过以下 link 之后我想出了以下代
我正在使用 highcharter,我希望能够在我点击一个栏(无论是顶层还是下钻)时向我的图表添加一个 click 事件 , 它过滤它下面的数据表以包含相同的信息。 我已经检查了这个 SO 问题,它显
所以我的问题与这个非常相关:R shinyDashboard customize box status color 然而,问题在于所提供的解决方案并没有添加可用的颜色,而只是替换了现有的颜色。因此,我
如何修复这个简单示例中的下载按钮? library(shiny) library(shinydashboard) library(shinyjs) header 0) { Sys.sle
我在 R Shinydashboard 中创建了动态 sibebar 菜单。即使我使用 selected = TRUE ,在此动态模式下启动时不会选择与菜单关联的菜单项。 如何确保我可以控制在此动态模
我正在使用 shinyjs R 中的包以允许 onclick键入事件以在选项卡集中的选项卡之间导航。每个选项卡都有一个特定的侧边栏,并且在每个选项卡之间有多种(两种)方式(即通过单击选项卡本身或单击
我是第一次使用 shinydashboard,它很棒。但是我陷入了一个奇怪的问题。我有以下代码在我的浏览器上运行。然而,当部署在 shinyapps.io 上时,它只是拒绝工作。我提供了下面的代码。仪
是否可以在dashboardHeader旁边的水平栏中放置一些项目?我知道您可以像在this example中一样将notificationItem放在最右边。但是我想使用与dashboardSide
我正在尝试在zoom上实现ShinyDashboard,因为当Web浏览器的缩放比例为80%时,布局看起来更好。 我在Shiny应用中找到了关于SO的文章,但是,对于Shinydashboard而言,
有了这个基本的 Shiny 应用程序:我想将我的标题放在标题中,如下图中红色所示: 已经有一些解决方案Add text on right of shinydashboard header但我想知道是否
我正在尝试动态生成多个 menuItem s,可能很简单,但我没有得到正确的想法。 library(shiny) library(shinydashboard) port_tables<-c("tab
有了这个基本的 Shiny 应用程序:我想将我的标题放在标题中,如下图中红色所示: 已经有一些解决方案Add text on right of shinydashboard header但我想知道是否
我正在使用 shinydashboard,我的 ui 代码是这种格式: ui = dashboardPage(skin="black", dashboardHea
我正在使用 Shinydashboard 包创建一个仪表板,我需要根据所选选项卡更改背景颜色。我已经尝试了以下代码,但它没有按预期工作。 library(shiny) library(shinydas
我正在尝试创建一个跨越整个 mainPanel 的 tabBox。我能够获得横跨整个屏幕的宽度,但我无法获得相同的高度。我不希望使用以像素(或其他一些单位)为单位的绝对值,因为我希望该应用程序可以跨不
与其让侧边栏打开并挤压正文,不如通过越过正文打开侧边栏,这样就不会弄乱我的输出大小。 如果可能的话,我怎样才能做到这一点? 当前行为: 期望的行为: 示例中使用的代码: library(shinyda
有什么方法可以让 shinydashboard 上的某种文本自动换行吗?默认行为似乎是溢出到 body 区域。 我想避免直接修改 css,但是如果有一种解决方法涉及将 CSS 作为服务器/ui 代码本
我想构建一个 Shiny 的应用程序,允许用户选择一些列来过滤 data.table 。 我的真实数据有 ~110 列,列是 numeric 、 character 、 factor 、 intege
如何在仪表板标题侧边栏图标的右侧添加文本?似乎以前的类似解决方案在 dashboardHeader() 的更新下不再起作用。 . 这就是我在基本的 Shinydashboard 设置中尝试做的事情:
我正在制作 Shiny 的仪表板,并希望皮肤上的颜色与 Shiny 文档 ( skins available in shiny ) 中可用的颜色不同 我想要 ('#2666cc','rgb(38, 1
我是一名优秀的程序员,十分优秀!