export async function funcBSPos(diffMarkPoint, newLineHL, cycle) { console.log(cycle, '---') let newData = [] let pos = 0 if (cycle === '1h') { // let csvdata = [] // csv('@/T/py/data/data.csvdoge-usdt.csv').then(results => { // console.log(results) // }) let filePath = '/data/csvdoge-usdt.csv' try { const data = await readCSVFileAsync(filePath); // 处理数据 console.log(data); // return data; } catch (error) { console.error(error); // return null; // 或者根据需要返回适当的值 } } } function readCSVFileAsync(filePath) { return new Promise((resolve, reject) => { readCSVFile(filePath, (error, data) => { if (error) { reject(error); } else { resolve(data); } }); }); } function readCSVFile(file, callback) { const xhr = new XMLHttpRequest(); xhr.onreadystatechange = function () { if (xhr.readyState === 4 && xhr.status === 200) { const csvData = xhr.responseText; callback(null, csvData); // 回调函数的第一个参数为null时,表示操作成功,没有产生任何错误。 } else { callback(new Error('Failed to read CSV file')); } }; xhr.open('GET', file, true); xhr.send(); } function processCSVData(csvData) { // 在这里处理CSV数据,例如解析、转换成对象数组等 let jsonData = parseCSV(csvData); // console.table(jsonData); return jsonData } function parseCSV(csvData) { const rows = csvData.split('\n'); const headers = rows[0].split(','); const data = []; for (let i = 1; i < rows.length - 1; i++) { const values = rows[i].split(','); const obj = {}; for (let j = 0; j < headers.length; j++) { obj[headers[j]] = values[j]; } data.push(obj); } return data; } 在没有用异步得时候是可以执行得,用了异步之后 就报错?
时间: 2024-04-12 14:31:41 浏览: 117
根据你提供的代码,我注意到你在`funcBSPos`函数中使用了异步操作来读取CSV文件。然而,你需要确保你的异步代码被正确地执行和处理。
在你的代码中,`funcBSPos`函数是一个异步函数,它使用了`await`关键字来等待`readCSVFileAsync`函数的结果。然而,`readCSVFileAsync`函数内部使用了`readCSVFile`函数来进行CSV文件的读取,而`readCSVFile`函数并不是一个异步函数。
为了正确处理异步逻辑,你需要将`readCSVFile`函数改造为返回一个Promise对象,以便能够在`readCSVFileAsync`函数中使用`await`关键字进行等待。
以下是修改后的代码示例:
```javascript
async function readCSVFile(file) {
return new Promise((resolve, reject) => {
const xhr = new XMLHttpRequest();
xhr.onreadystatechange = function () {
if (xhr.readyState === 4 && xhr.status === 200) {
const csvData = xhr.responseText;
resolve(csvData); // 使用resolve将获取到的CSV数据传递出去
} else {
reject(new Error('Failed to read CSV file')); // 使用reject将错误信息传递出去
}
};
xhr.open('GET', file, true);
xhr.send();
});
}
```
在这个修改后的代码中,我们将`readCSVFile`函数改造为返回一个Promise对象,并在请求成功时使用resolve传递CSV数据,请求失败时使用reject传递错误信息。
请将这个修改后的代码应用到你的项目中,然后再次尝试运行异步逻辑。如果还有其他问题,请提供更多的错误信息和代码上下文,以便我能够更好地帮助你。
阅读全文