0

代码:

setwd(dirname(rstudioapi::getActiveDocumentContext()$path)) 
options(stringsAsFactors = FALSE)
rm(list = ls()) 
if (!require("pacman")) install.packages("pacman")
pacman::p_load("dplyr","tidyr","highcharter")

raw_data <- read.csv("results.csv")
DT <- data.table(raw_data)

cols <- c('Person','ABC_Capability','ABC_Sub.capability','Leadership.Facet','Facet.Score')
DT <- DT[, cols, with = FALSE]
names(DT) <- c('Person','Capability','Sub_Capability','SVL','Facet_Score')

DT <- dcast(DT, Capability + Sub_Capability + SVL ~ Person, 
            value.var = c('Facet_Score'))

DT1 <- DT %>% 
  group_by(name = Sub_Capability) %>% 
  do(categories = .$SVL) %>% 
  list_parse()


highchart() %>% 
  hc_chart(type = "bar") %>% 
  hc_title(text = "Some Title") %>%
  hc_add_series(name="A", data = DT$Joan) %>% 
  hc_add_series(name="B", data = DT$Shane) %>%
  hc_add_series(name="C", data = DT$Simon) %>%
  hc_xAxis(categories = DT1)

输出:

在此处输入图像描述

我尝试使用较小的数据集,并意识到每次组中只有一个值。标签被截断。例如:培养人才 > 赋权

任何帮助,将不胜感激。

4

1 回答 1

0

就像 Kamil Kulig 提到的那样,您可以尝试将类别设为数组而不是向量,这对我有用。使用您提供的示例代码,它将是:

DT1 <- DT %>% 
  group_by(name = Sub_Capability) %>% 
  # store SVL as array
  do(categories = array(.$SVL)) %>% 
  list_parse()

新更新

array()即使您没有使用分组类别而只是想重命名刻度标签,也需要使用该函数将向量转换为数组,即

highcharter::hchart(mtcars[1, ],
                    "column", name = "MPG",
                    highcharter::hcaes(x = 0, y = mpg),
                    showInLegend = F) %>%
    # x axis format
    highcharter::hc_xAxis(title = list(text ="Car Name"),
                          # relabel x axis tick to the name of the cars
                          categories = array(rownames(mtcars)[1]))

然后轴刻度标签将显示汽车的名称。

当车名向量转换为数组时

如果您简单地使用categories = rownames(mtcars)[1])而不是将其转换为数组,则 x 轴标签将无法正确显示:

当车名向量按原样输入时

这里的刻度标签只是M而不是Mazada RX4

于 2019-03-18T22:12:10.160 回答