Создание вложенного списка в R - PullRequest
1 голос
/ 20 февраля 2020

У меня есть фрейм данных, как показано ниже:

df <- data.frame(child = c('item3-1-1','item3-1-2','item3-2','item3-1','item2-1','item2-2','item1'),parent = c('item3-1','item3-1','item3','item3','item2','item2',''))

Я хочу преобразовать этот фрейм данных в следующий формат:

choices <- 

list(
list(id = 1, title = "item1"),

list(id = 2, title = "item2", 

   subs = list(
     list(id = 21, title = "item2-1"), 
     list(id = 22, title = "item2-2")
   )
), 

list(id = 3, title = "item3",
   subs = list(
     list(id = 31, title = "item3-1", isSelectable = FALSE,
          subs = list(
            list(id = 311, title = "item3-1-1"),
            list(id = 312, title = "item3-1-2")
          )
     ),
     list(id = 32, title = "item3-2")
   )
 )
 )

Мне нужен вложенный список с опцией 'subs' пройти по раскрывающемуся списку дерева.

Существует ли какая-либо функция или метод, с помощью которых я могу добиться этого, поскольку у меня огромный набор данных.

1 Ответ

0 голосов
/ 20 февраля 2020

Вот функция, которая генерирует вложенный список. id - это не одно и то же, но в любом случае мы не используем их в ComboTree (но они необходимы).

dat <- data.frame(
  item = c("item1", "item2", "item2-1", "item2-2", "item3", "item3-1", 
           "item3-1-1", "item3-1-2", "item3-2"), 
  parent = c("root", "root", "item2", "item2", "root", "item3", 
             "item3-1", "item3-1", "item3"),
  stringsAsFactors = FALSE
)

makeChoices <- function(dat){
  f <- function(parent, id = "id"){
    i <- match(parent, dat$item)
    title <- dat$item[i]
    subs <- dat$item[dat$parent==title]
    if(length(subs)){
      list(
        title = title, 
        id = paste0(id,"-",i), 
        subs = lapply(subs, f, id = paste0(id,"-",i))
      )
    }else{
      list(title = title, id = paste0(id,"-",i))
    }
  }
  lapply(dat$item[dat$parent == "root"], f)
}

choices <- makeChoices(dat)

> jsonlite::toJSON(choices, auto_unbox = TRUE, pretty = TRUE)
[
  {
    "title": "item1",
    "id": "id-1"
  },
  {
    "title": "item2",
    "id": "id-2",
    "subs": [
      {
        "title": "item2-1",
        "id": "id-2-3"
      },
      {
        "title": "item2-2",
        "id": "id-2-4"
      }
    ]
  },
  {
    "title": "item3",
    "id": "id-5",
    "subs": [
      {
        "title": "item3-1",
        "id": "id-5-6",
        "subs": [
          {
            "title": "item3-1-1",
            "id": "id-5-6-7"
          },
          {
            "title": "item3-1-2",
            "id": "id-5-6-8"
          }
        ]
      },
      {
        "title": "item3-2",
        "id": "id-5-9"
      }
    ]
  }
] 
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...