R Plotly-添加按组求和的_跟踪
试图构建一个按绘图方式分组的条形图,该条形图通过分组列来添加一条求和值的线 下面是一个例子:R Plotly-添加按组求和的_跟踪,r,shiny,plotly,R,Shiny,Plotly,试图构建一个按绘图方式分组的条形图,该条形图通过分组列来添加一条求和值的线 下面是一个例子: if (interactive()) { library(plotly) year <- c("2020", "2020", "2021", "2021", "2022", "2022", "2023", "2023", &q
if (interactive()) {
library(plotly)
year <- c("2020", "2020", "2021", "2021", "2022", "2022", "2023", "2023", "2024", "2024", "2025", "2025")
foodType <- c("Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit")
foodQty <- c(10, 10, 11, 17, 21, 23, 3, 4, 16, 2, 7, 43)
data <- data.frame(year, foodType, foodQty)
ui <- fluidPage(
plotlyOutput("foodPlot")
)
server <- function(input, output, session) {
output$foodPlot <- renderPlotly({
plot_ly(data, x = ~year, y = ~foodQty, type = 'bar', color = ~foodType,
hoverinfo = 'text',
hovertext = ~paste0(foodType, ' ', foodQty)) %>%
add_trace(x = ~year, y = ~foodQty,
type = 'scatter', mode = 'lines', name = 'Total Qty',
line = list(color = 'red'),
hoverinfo = "text",
hovertext = ~paste(foodQty),
transforms = list(list(type = 'aggregate', groups = ~year,
aggregations = list(list(target = 'y', func = 'sum', enabled = T))))) %>%
layout(xaxis = list(title = "", tickangle = -90), yaxis = list(title = ""),
barmode = 'group') %>%
config(displaylogo = FALSE, collaborate = FALSE,
modeBarButtonsToRemove =
list("sendDataToCloud","zoom2d","pan2d","select2d","lasso2d",
"zoomIn2d","zoomOut2d","autoScale2d","hoverClosestCartesian",
"hoverCompareCartesian"))
})
}
shinyApp(ui, server)
}
还是不走运。谢谢你的帮助 您可以使用
inherit=FALSE
避免将属性从plot\u ly()
传递到add\u trace
并通过aggregate
创建新的数据集-请检查以下内容:
library(shiny)
library(plotly)
year <- c("2020", "2020", "2021", "2021", "2022", "2022", "2023", "2023", "2024", "2024", "2025", "2025")
foodType <- c("Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit")
foodQty <- c(10, 10, 11, 17, 21, 23, 3, 4, 16, 2, 7, 43)
data <- data.frame(year, foodType, foodQty)
ui <- fluidPage(
plotlyOutput("foodPlot")
)
server <- function(input, output, session) {
output$foodPlot <- renderPlotly({
plot_ly(data, x = ~year, y = ~foodQty, type = 'bar', color = ~foodType,
hoverinfo = 'text',
hovertext = ~paste0(foodType, ' ', foodQty)) %>%
add_trace(data = aggregate(foodQty ~ year, data = data, sum), x = ~year, y = ~foodQty,
type = 'scatter', mode = 'lines', name = 'Total Qty',
line = list(color = 'red'),
hoverinfo = "text",
hovertext = ~paste(foodQty), inherit = FALSE) %>%
layout(xaxis = list(title = "", tickangle = -90), yaxis = list(title = ""),
barmode = 'group') %>%
config(displaylogo = FALSE, collaborate = FALSE,
modeBarButtonsToRemove =
list("sendDataToCloud","zoom2d","pan2d","select2d","lasso2d",
"zoomIn2d","zoomOut2d","autoScale2d","hoverClosestCartesian",
"hoverCompareCartesian"))
})
}
shinyApp(ui, server)
库(闪亮)
图书馆(绘本)
年份您可以使用inherit=FALSE
避免将属性从plot\u ly()
传递到add\u trace
,并通过aggregate
创建新的数据集-请检查以下内容:
library(shiny)
library(plotly)
year <- c("2020", "2020", "2021", "2021", "2022", "2022", "2023", "2023", "2024", "2024", "2025", "2025")
foodType <- c("Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit", "Vegetable", "Fruit")
foodQty <- c(10, 10, 11, 17, 21, 23, 3, 4, 16, 2, 7, 43)
data <- data.frame(year, foodType, foodQty)
ui <- fluidPage(
plotlyOutput("foodPlot")
)
server <- function(input, output, session) {
output$foodPlot <- renderPlotly({
plot_ly(data, x = ~year, y = ~foodQty, type = 'bar', color = ~foodType,
hoverinfo = 'text',
hovertext = ~paste0(foodType, ' ', foodQty)) %>%
add_trace(data = aggregate(foodQty ~ year, data = data, sum), x = ~year, y = ~foodQty,
type = 'scatter', mode = 'lines', name = 'Total Qty',
line = list(color = 'red'),
hoverinfo = "text",
hovertext = ~paste(foodQty), inherit = FALSE) %>%
layout(xaxis = list(title = "", tickangle = -90), yaxis = list(title = ""),
barmode = 'group') %>%
config(displaylogo = FALSE, collaborate = FALSE,
modeBarButtonsToRemove =
list("sendDataToCloud","zoom2d","pan2d","select2d","lasso2d",
"zoomIn2d","zoomOut2d","autoScale2d","hoverClosestCartesian",
"hoverCompareCartesian"))
})
}
shinyApp(ui, server)
库(闪亮)
图书馆(绘本)
年啊,非常感谢。我不知道继承的财产。啊,非常感谢。我不知道inherit
属性。