0

我正在研究 kepler.gl .... 赖特现在我正在从 api 读取数据并将该数据绘制在 keplr.gl 中,这工作正常这里是代码...

import keplerGlReducer from "kepler.gl/reducers";
import { createStore, combineReducers, applyMiddleware } from "redux";
import { taskMiddleware } from "react-palm/tasks";
import { Provider, useDispatch } from "react-redux";
import KeplerGl from "kepler.gl";
import { addDataToMap } from "kepler.gl/actions";
import useSwr from "swr";

const reducers = combineReducers({
  keplerGl: keplerGlReducer
});

const store = createStore(reducers, {}, applyMiddleware(taskMiddleware));

export default function App() {
  return (
    <Provider store={store}>
      <Map />
      <csv/>
    </Provider>
  );
}

function Map() {
  const dispatch = useDispatch();
  const { data } = useSwr("covid", async () => {
    const response = await fetch(
     "https://gist.githubusercontent.com/leighhalliday/a994915d8050e90d413515e97babd3b3/raw/a3eaaadcc784168e3845a98931780bd60afb362f/covid19.json"
     );
     const data = await response.json();
     return data;
   });

  React.useEffect(() => {
    if (data) {
      dispatch(
        addDataToMap({
          datasets: {
            info: {
              label: "COVID-19",
              id: "covid19"
            },
            data
          },
          option: {
            centerMap: true,
            readOnly: false
          },
          config: {}
        })
      );
    }
  }, [dispatch, data]);

  return (
    <KeplerGl
      id="covid"
      mapboxApiAccessToken="pk.eyJ1IjoiYWxpcmF6YTcwNSIsImEiOiJjazh5d2hjb3AwOHBqM2VsY21wOHo5eXprIn0.9G5CE4KqfbvU9HQ6WBuo3w"
      width={window.innerWidth}
      height={window.innerHeight}
    />
  );
}

现在我想从 jason 或 csv 文件中读取数据并将该数据绘制到 kepler.gl 地图中。我该怎么做有人可以帮助我吗?.....谢谢

4

2 回答 2

1

在 React 中这样做

import datajson from './yourdata.json';

const data=datajson;
于 2020-05-14T23:40:32.430 回答
1

最简单的方法是将您的jsonorcsv文件放在您的代码旁边并
导入您的 json 文件:

const dataJson = require('./data.json');

将您的数据源更改为您的 json:

const data = dataJson
// or dataJson.data depending on your json structure

或者如果您的数据是 csv 格式,那么想到的最快方法是安装csv-parse然后:

const data = parse(csvData, {
   //config based on your csv format
   columns: true,
   skip_empty_lines: true
});

希望这就是你要找的

于 2020-04-17T10:05:48.300 回答