如何保存在 d3.js 脚本中构建的 JSON 数据

Posted

技术标签:

【中文标题】如何保存在 d3.js 脚本中构建的 JSON 数据【英文标题】:How to save JSON data built in a d3.js script 【发布时间】:2017-09-25 06:55:33 【问题描述】:

我 大家好,我是 javascript/D3.js 编程的新手。我需要调整一个代码,我觉得有点失落。

主要问题是:如何在javascript中保存JSON数据集

当前代码正在加载一个大的 csv 文件,对其进行解析和格式化。 我想将文件管理部分移到另一个程序中,但是为了直接获取格式良好的文件,我想通过运行此代码并保存输出来直接保存它(即:@987654321 @)。

感谢您的帮助!

d3.text("myfile.csv", function(text) 
  var csv = d3.csv.parseRows(text);
  var json = buildHierarchy(csv);  //-- THIS IS WHAT I NEED TO SAVE (OR SEE)
);

// function to adjust data

function buildHierarchy(csv) 
  var root = "name": "root", "children": [];
  for (var i = 0; i < csv.length; i++) 
    var sequence = csv[i][0];
    var size = +csv[i][1];
    if (isNaN(size))  // e.g. if this is a header row
      continue;
    
    var parts = sequence.split("-");
    var currentNode = root;
    for (var j = 0; j < parts.length; j++) 
      var children = currentNode["children"];
      var nodeName = parts[j];
      var childNode;
      if (j + 1 < parts.length) 
   // Not yet at the end of the sequence; move down the tree.
 	var foundChild = false;
 	for (var k = 0; k < children.length; k++) 
 	  if (children[k]["name"] == nodeName) 
 	    childNode = children[k];
 	    foundChild = true;
 	    break;
 	  
 	
  // If we don't already have a child node for this branch, create it.
 	if (!foundChild) 
 	  childNode = "name": nodeName, "children": [];
 	  children.push(childNode);
 	
 	currentNode = childNode;
       else 
 	// Reached the end of the sequence; create a leaf node.
 	childNode = "name": nodeName, "size": size;
 	children.push(childNode);
      
    
  
  return root;
;

【问题讨论】:

请定义“见”。如果您只是想查看对象,只需执行console.log(json) 感谢 Gerardo:我的目标是将对象保存在 .JSON 文件中。最初我也试图看看它,但同时我设法使用console.log(JSON.stringify(json)) 【参考方案1】:

我终于设法使用来自https://github.com/eligrey/FileSaver.js/ 的saveAs 函数保存了我的文件

var blob = new Blob([JSON.stringify(json)], type: "text/plain;charset=utf-8");  
saveAs(blob, "sequence_dl.JSON");

【讨论】:

以上是关于如何保存在 d3.js 脚本中构建的 JSON 数据的主要内容,如果未能解决你的问题,请参考以下文章

如何检查没有链接的节点的d3 js力图并删除它们?

d3 js - 在没有 http get 的情况下加载 json

pandas to_json , django 和 d3.js 用于可视化

d3.js & json - 简单的示例代码?

如何通过D3.js中的JSON文件解析按键对对象进行排序[重复]

同一页面上的多个版本的脚本 (d3.js)