如何解决从多个csv文件中绘制网站中的数据
我在AWS s3存储桶中托管了static website。
我不知道有关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,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文件,而不只是一个。我的文件名是可变的,因此我不能一一列出。 是否可以将过滤器或RegEx用作“ * .csv ”? 预先感谢,
解决方法
是否可以将过滤器或RegEx用作“ * .csv”?
否。
虽然可以通过将文件系统中的文件和目录映射到URL来生成,但URL不是目录。
无法访问glob URL。
您可以确保服务器在被要求提供./
时返回URL列表,然后使用客户端JS对其进行解析和过滤,然后请求每个URL(可能使用Promise.all
以确定您何时对这些请求中的每一个都有响应。
您还可以编写服务器端代码来连接所有CSV数据,因此您只需要发出一个请求即可。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。