#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