【问题标题】:R highcharts multiple stacked bar chartR highcharts 多重堆积条形图
【发布时间】:2019-02-12 13:31:22
【问题描述】:

我想绘制一个多重堆积的条形图,但是不知道如何组合r代码。

  Closing Date Non Current Assets Current Assets Non Current Liabilities
2      2013/12           13637344       13078654                 9376243
3      2014/12           14075507       12772388                 8895126
4      2015/12           14578093       14226181                 9715914
5      2016/12           10911628       10205708                 9810157
6      2017/12           10680998       10950779                13493110
   Current Liabilities
2             5075985
3             4963856
4             5992229
5             8859263
6             4094183

我可以通过以下方式绘制多个条形图:

    highchart() %>% 
    hc_chart(type = "column") %>%
    hc_xAxis(categories = bs.table$`Closing Date`) %>%
    hc_add_series(name="Non Current Assets",data = bs.table$`Non Current 
    Assets`) %>%
  hc_add_series(name="Current Assets",data = bs.table$`Current Assets`) %>%
  hc_add_series(name="Non Current Liabilities",data = bs.table$`Non Current Liabilities`) %>%
  hc_add_series(name="Current Liabilities",data = bs.table$`Current Liabilities`) %>%
  hc_add_theme(hc_theme_ft())

只有一个这样的堆叠条:

highchart() %>% 
  hc_chart(type = "column") %>% 
  hc_title(text = "MyGraph") %>% 
  hc_plotOptions(column = list(
    dataLabels = list(enabled = FALSE),
    stacking = "normal",
    enableMouseTracking = FALSE)
  ) %>% 
  hc_series(list(name="Current Assets",data=bs.table$`Current Assets`),
            list(name="Non Current Assets",data=bs.table$`Non Current Assets`)) 

我想要的输出是这样的:

我尝试通过添加来组合代码:

%>% hc_series(list(name="Current Liabilities",data=bs.table$`Current Liabilities`),
            list(name="Non Current Liabilities",data=bs.table$`Non Current Liabilities`)) 

在第二个代码上但它不起作用,它添加了相同的条。请指教。

【问题讨论】:

    标签: r highcharts bar-chart


    【解决方案1】:

    您可以通过将stack 添加到每个系列来指定哪些条属于哪些组,如下所示:

    library(highcharter)
    
    bs.table = data.frame(
      Closing.Date = paste(2013:2017, 12, sep = "/"),
      Non.Current.Assets = c(13637344, 14075507, 14578093, 10911628, 10680998),
      Current.Assets = c(13078654, 12772388, 14226181, 10205708, 10950779),
      Non.Current.Liabilities = c(9376243, 8895126, 9715914, 9810157, 13493110),
      Current.Liabilities = c(5075985, 4963856, 5992229, 8859263, 4094183)
    )
    
    highchart() %>% 
      hc_chart(type = "column") %>%
      hc_plotOptions(column = list(stacking = "normal")) %>%
      hc_xAxis(categories = bs.table$Closing.Date) %>%
      hc_add_series(name="Non Current Assets",
                    data = bs.table$Non.Current.Assets,
                    stack = "Assets") %>%
      hc_add_series(name="Current Assets",
                    data = bs.table$Current.Assets,
                    stack = "Assets") %>%
      hc_add_series(name="Non Current Liabilities",
                    data = bs.table$Non.Current.Liabilities,
                    stack = "Liabilities") %>%
      hc_add_series(name="Current Liabilities",
                    data = bs.table$Current.Liabilities,
                    stack = "Liabilities") %>%
      hc_add_theme(hc_theme_ft())
    

    (要按流动与非流动而不是资产与负债进行分组,只需在每个系列中适当地重命名stack。)

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2020-07-17
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多