#javascript #html #csv #web #fetch
#javascript #csv #выборка-api
Вопрос:
Я создал статический веб-сайт, размещенный в корзине AWS s3.
Я не знаком с инструментами и технологиями веб-разработки, но я взял пример 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-адреса.
Вы могли бы убедиться, что сервер при запросе ./
возвращает список URL-адресов, а затем анализирует и фильтрует его с помощью JS на стороне клиента, а затем запрашивает каждый из этих URL-адресов (вероятно, используя Promise.all
, чтобы определить, когда у вас был ответ на каждый из этих запросов).
Вы также могли бы написать серверный код для объединения всех CSV-данных, чтобы вам нужно было сделать только один запрос.
Комментарии:
1. Это то, чего я боялся… Спасибо тебе @Quentin