D3.csv не загружает данные из локального файла csv

#reactjs #csv #d3.js

#reactjs #csv #d3.js

Вопрос:

Я создал копию файла csv в своей локальной папке, потому что хотел немного поработать с данными. Когда я избавляюсь от ссылки и заменяю ее именем моего локального файла csv, график по какой-то причине не отображается. Я добавил картинку, которая показывает мою локальную файловую структуру. он находится в той же папке. Что я делаю не так? введите описание изображения здесь

 import React, {Component, useRef, useEffect} from 'react';
import * as d3 from "d3";
import { select } from 'd3-selection'
import { extent, max, min } from "d3-array";


class Linechart extends Component {
  constructor(props){
    super(props)
    this.createBarChart = this.createBarChart.bind(this)
  }

  componentDidMount() {
    this.createBarChart()
  }

  componentDidUpdate() {
    this.createBarChart()
  }

  createBarChart() {
    var margin = {top: 30, right: 30, bottom: 30, left: 60},
        width = 960 - margin.left - margin.right,
        height = 400 - margin.top - margin.bottom;

    var node = this.node
    var divObj = select(node)
    var svgObj = divObj
                .append("svg")
                .attr("width", width   margin.left   margin.right)
                .attr("height", height   margin.top   margin.bottom)
                .append("g")
                .attr("transform","translate("   margin.left   ","   margin.top   ")");
    
    //Read the data
    // when i replace the line below wit this line of code, it doesnt read it d3.csv("5_OneCatSevNumOrdered.csv""), function(data) {
    d3.csv("https://raw.githubusercontent.com/holtzy/data_to_viz/master/Example_dataset/5_OneCatSevNumOrdered.csv", function(data) {

      // group the data: I want to draw one line per group
      var sumstat = d3.nest() // nest function allows to group the calculation per level of a factor
        .key(function(d) { return d.name;})
        .entries(data);


      // Define the div for the tooltip
      var tooltip = divObj
        .append("div")  
        .style("position", "absolute")
        .style("z-index", "10")
        .style("visibility", "hidden")
        .text("I AM A TOOLTIP BOOM SHAKALAKA!! BOOM SHAKALAKA!!");       

      // Add X axis --> it is a date format
      var x = d3.scaleLinear()
        .domain(d3.extent(data, function(d) { return d.year; }))
        .range([ 0, width ]);
      svgObj.append("g")
        .attr("transform", "translate(0,"   height   ")")
        .attr("stroke-width","0.3")
        .call(d3.axisBottom(x).tickSize(-height).tickFormat('').ticks(5));
      //ticks
      svgObj.append("g")
        .attr("transform", "translate(0,"   height   ")")
        .call(d3.axisBottom(x).ticks(5));

      // Add Y axis
      var y = d3.scaleLinear()
        .domain([0, d3.max(data, function(d) { return  d.n; })])
        .range([ height, 0 ]);
      svgObj.append("g")
        .attr("stroke-width","0.3")
        .call(d3.axisLeft(y).tickSize(-width).tickFormat('').ticks(5));
      //ticks
      svgObj.append("g")
        .call(d3.axisLeft(y).ticks(5));
        
      // color palette
      var res = sumstat.map(function(d){ return d.key }) // list of group names
      console.log(res)
      var color = d3.scaleOrdinal()
        .domain(res)
        .range(['#e41a1c','#377eb8','#4daf4a','#984ea3','#ff7f00','#ffff33','#a65628','#f781bf','#999999'])

      // Draw the line
      svgObj.selectAll(".line")
          .data(sumstat)
          .enter()
          .append("path")
            .attr("fill", "none")
            .attr("stroke", function(d){ return color(d.key) })
            .attr("stroke-width", 2.5)
            .attr("d", function(d){
              return d3.line()
                .x(function(d) { return x(d.year); })
                .y(function(d) { return y( d.n); })
                (d.values)
            })
            .on("mouseover", function(){return tooltip.style("visibility", "visible");})
            .on("mousemove", function(){return tooltip.style("top", (d3.event.pageY-10) "px").style("left",(d3.event.pageX 10) "px");})
            .on("mouseout", function(){return tooltip.style("visibility", "hidden");})
      })

    }
    render() {
      return <div ref={node => this.node = node} className="example_div"> </div>
   }
}

export default Linechart;
  

Ответ №1:

d3.csv является частью d3-fetch библиотеки. Эта библиотека использует собственный fetch метод для получения файла откуда-либо в Интернете. К сожалению, он не может работать с файлами на вашем жестком диске.

Вам нужно будет сделать файл доступным localhost:<some port> , как вы, вероятно, делаете со своим кодом react. В зависимости от того, что вы используете, вам может потребоваться изменить конфигурацию webpack / gulp / rollup. В противном случае, если у вас есть серверный API, работающий с Python / C # / Ruby, просто отправьте его оттуда как статический файл.

В любом случае имя файла / каталог никогда не будет работать, попробуйте использовать его через localhost.


Редактировать: обслуживание файла, который вы разместили на Github

 d3.csv("https://raw.githubusercontent.com/QamarFarooq/data-for-testing/main/5_OneCatSevNumOrdered.csv").then((data) => {
  console.log(data);
});  
 <script src="https://cdnjs.cloudflare.com/ajax/libs/d3/5.7.0/d3.min.js"></script>  

Комментарии:

1. Я поместил свой файл в c:inetpubwwwroot а затем сослался на него как на localhost/myfile.csv , но все же d3.js не обрабатывается. Что вы подразумеваете под localhost: <некоторый порт>. Какой порт указать?

2. По какому URL-адресу вы переходите, чтобы загрузить свою веб-страницу? В зависимости от ваших настроек у вас должен быть сервер, работающий по какому-либо адресу localhost:3060 или localhost:8080 — возможно, начинающийся с npm , gulp , или webpack