提问者:小点点

从多个csv文件绘制网站中的数据


我做了一个静态网站托管在一个AWS3桶。

我不了解web开发的工具和技术,但我以index.html代码为例,允许我从一个名为“my_data_file1.csv”的文件中绘制数据。

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <meta http-equiv="X-UA-Compatible" content="ie=edge" />
    <title>Coding Train: Data and APIs Project 1</title>
    <script src="https://cdn.jsdelivr.net/npm/chart.js@2.8.0"></script>
  </head>
  <body>
    <h1>Global Temperatures</h1>
    <canvas id="myChart" width="400" height="200"></canvas>

    <script>

      window.addEventListener('load', setup);

      async function setup() {
        const ctx = document.getElementById('myChart').getContext('2d');
        const globalTemps = await getData();
        const myChart = new Chart(ctx, {
          type: 'line',
          data: {
            labels: globalTemps.years,
            datasets: [
              {
                label: 'Temperature in °C',
                data: globalTemps.temps,
                fill: false,
                borderColor: 'rgba(255, 99, 132, 1)',
                backgroundColor: 'rgba(255, 99, 132, 0.5)',
                borderWidth: 1
              }
            ]
          },
          options: {}
        });
      }

      async function getData() {
        const response = await fetch('my_data_file1.csv');
        const data = await response.text();
        const years = [];
        const temps = [];
        const rows = data.split('\n').slice(1);
        rows.forEach(row => {
          const cols = row.split(',');
          years.push(cols[0]);
          temps.push(parseFloat(cols[2]));
        });
        return { years, temps };
      }
    </script>
  </body>
</html>

我的所有数据都被拆分成多个文件,所以我希望能够在一个目录中解释所有CSV文件,而不仅仅是一个。我的文件的名称是可变的,所以我不能一一列出它们。是否可以将过滤器或正则表达式用作“*.csv”?先谢谢你,


共1个答案

匿名用户

是否可以将过滤器或正则表达式用作“*.csv”?

不。

虽然URL可以通过将文件系统中的文件和目录映射到URL来生成,但URL不是目录。

没有办法对URL进行glob。

您可以确保当请求./时,服务器返回一个URL列表,然后使用客户端JS对其进行解析和过滤,然后请求每个URL(可能使用promise.all来确定每个请求的响应时间)。

您还可以编写服务器端代码来连接所有CSV数据,因此您只需发出一个请求。