Репликация разборного дерева Майка Бостока

Я хочу воспроизвести графическое дерево Майка Бостока ( http://bl.ocks.org/mbostock/4339083).

Я загрузил CSV с помощью nest функция в d3.js, Теперь данные выглядят так:

 [
  {
    "key": "Bayer HealthCare",
    "values": [
      {
        "key": "Animal Health",
        "values": [
          {
            "key": "Companion Animal",
            "values": [
              {
                "brand": "Drontal",
                "product": "Companion Animal",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              },
              {
                "brand": "Profender",
                "product": "Companion Animal",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              },
              {
                "brand": "Rompun",
                "product": "Companion Animal",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              }
            ]
          },
          {
            "key": "Companion Animal - Food Animal Product",
            "values": [
              {
                "brand": "Baytril",
                "product": "Companion Animal - Food Animal Product",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              }
            ]
          },
          {
            "key": "Companion animals",
            "values": [
              {
                "brand": "Advantage",
                "product": "Companion animals",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              },
              {
                "brand": "Advantix",
                "product": "Companion animals",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              },
              {
                "brand": "Advocate",
                "product": "Companion animals",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              }
            ]
          },
          {
            "key": "Food Animal Product",
            "values": [
              {
                "brand": "Baycox",
                "product": "Food Animal Product",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              },
              {
                "brand": "Catosal",
                "product": "Food Animal Product",
                "subgroup": "Bayer HealthCare",
                "division": "Animal Health"
              }
            ]
          }
        ]
      }
.....

(Полные данные и то, что я уже сделал, доступно здесь: http://jsfiddle.net/L3phF/9/)

К сожалению, я не знаю, как преобразовать данные в формат "FLARE JSON", как этот https://gist.github.com/mbostock/1093025. Если я прав, я должен переименовать "ключ" в "имя", "значения" в "дети", и я должен вставить "" имя: "" перед каждым объектом на самом низком уровне.

Я ценю любую помощь!

1 ответ

Решение

Это переименует "ключ" в "имя" и "значения" в "дети":

var renameKeys=function(obj){
    /*Recursively renames "key" keys to "name" and
    renames "values" keys to "children" */
    obj.name=obj.key;
    delete obj['key'];
    if(obj.values){
        obj.children=obj.values;
        delete obj.values;
        obj.children.forEach(renameKeys);
    }
    return obj;
};

Вам также нужно дать JSON "корневой" узел для работы с визуализацией сворачиваемого дерева, с которой вы связались. Это должно сделать это:

var nest = d3.nest()
    .key(function(d) { return d.subgroup; })
    .key(function(d) { return d.division; })
    .key(function(d) { return d.product; })
    .entries(parsed);

/*The visualization requires there to be a root node*/
var flareData={key:'root',values:[]};
flareData.values=nest;
renameKeys(flareData);

Вот JSFiddle, чтобы получить JSON, который вы хотите: http://jsfiddle.net/X2fxC/3/

Вот JSFiddle с получающейся визуализацией: http://jsfiddle.net/X2fxC/5/

Ваши данные выглядят следующим образом при построении с использованием расширяющейся древовидной визуализации:

введите описание изображения здесь

Другие вопросы по тегам