【发布时间】:2026-01-28 07:45:01
【问题描述】:
我正在 Node.js 中创建我的第一个应用程序,它应该按顺序执行这些操作:
- 连接到 PostgreSQL 数据库
- 创建一个表(如果它已经存在,做任何事情)
- 对两个网站进行网页抓取并将信息保存在数据库中
- 使用 D3.js 和数据库中的数据创建可视化效果
- 它与数据库断开连接。
我发布了一个关于插入操作的previous question。现在问题是异步/等待。
我知道 Node.js 是异步的,而我应该同步执行操作。 我使用的是 Node.js v8.9.4,所以我使用 async/await 构造。
我读了一点“如何异步/等待,但我发现很难正确使用它。
这是我的应用程序的方案(app.js 文件):
const postgreSQLlib = require('./middlewares/postgreSQLlib.js')
const scraperCovIt = require('./routers/scraperCovIt.js');
const scraperCov = require('./routers/scraperCov.js');
const start = async function() {
// STEP 0 - Start
await console.log('\nSTART');
// STEP 1 - Connect to db
await postgreSQLlib.connect();
// STEP 2 - Create tables
var queryCreateCoverages = {
text: 'CREATE TABLE IF NOT EXISTS coverages ('+
'id SERIAL PRIMARY KEY,' +
'vaccine VARCHAR(64) NOT NULL,' +
'country VARCHAR(255) NOT NULL,' +
'region VARCHAR(255),' +
'year VARCHAR(4) NOT NULL,' +
'value VARCHAR(12) NOT NULL);'
};
var queryRes = await postgreSQLlib.query(queryCreateCoverages, '[CREATE TABLE coverages]');
// STEP 3 - Get data
await scraperCovIt.download();
await scraperCov.download();
// STEP 4 - Disconnect from db
await postgreSQLlib.disconnect();
// STEP 5 - End
return '\nFINISH';
}
// start application
start()
.then(function(res) {
console.log(res);
})
.catch(function(err) {
console.log(err);
});
postgreSQLlib.js:
const {Client} = require('pg');
const connectionString = 'postgres://admin:admin@localhost:5432/db';
let client;
var methods = {};
methods.connect = async function() {
client = new Client({connectionString});
return await client.connect()
.then(async function() {
await console.log('\nConnected to ' + client.database + ' at ' + client.host + ':' + client.port + ' as ' + client.user + ' (pass: ' + client.password + ')');
})
.catch(function(err) {
console.log('\nError during connection to PostgreSQL');
throw err;
});
}
methods.query = async function(query, print) {
return await client.query(query)
.then(function(res) {
console.log(print, 'OK query');
return res;
})
.catch(function(err) {
console.log(print, 'ERR query');
});
}
methods.disconnect = async function() {
return await client.end()
.then(function() {
console.log('\nConnection has ended');
})
.catch(function(err) {
console.log('\nError during clossing connection');
throw err;
});
}
module.exports = methods;
scraperCov.js:
var cheerio = require('cheerio');
var request = require('request-promise');
var postgreSQLlib = require('../middlewares/postgreSQLlib.js');
var methods = {};
var countries = {
'Albania': 'ALB',
'Austria': 'AUT',
'Belgium': 'BEL'
};
methods.download = async function(req, res) {
for(country in countries) {
console.log('\nCOUNTRY:', country);
var url = 'http://apps.who.int/immunization_monitoring/globalsummary/coverages?c=' + countries[country];
let res = await request(url);
insert(res);
}
}
module.exports = methods;
let insert = async function(html) {
$ = cheerio.load(html);
var years = [];
var vaccines = [];
var coverages = [];
$('.ts .year').each(function() {
years.push($(this).text().trim());
});
$('.ts .odd td a, .ts .even td a').each(function() {
vaccines.push($(this).text().trim());
});
$('.ts .odd .statistics_small, .ts .even .statistics_small').each(function() {
coverages.push($(this).text().trim());
});
const numYears = years.length;
const numVaccines = vaccines.length;
for(var vaccineIdx = 0; vaccineIdx < numVaccines; vaccineIdx++) {
for(var yearIdx = 0; yearIdx < numYears; yearIdx++) {
let obj = {
year: years[yearIdx],
country: country,
region: '',
vaccine: vaccines[vaccineIdx],
coverage: coverages[vaccineIdx*numYears + yearIdx]
}
// save on db
const queryInsert = {
text: 'INSERT INTO coverages (vaccine, country, region, year, value) VALUES ($1, $2, $3, $4, $5);',
values: [vaccines[vaccineIdx], country, '', years[yearIdx], coverages[vaccineIdx*numYears + yearIdx]]
}
var printText = '[INSERT ' + country + ' IN coverages]';
var queryRes = await postgreSQLlib.query(queryInsert, printText);
}
}
}
scraperCovIt.js:
var textract = require('textract');
var postgreSQLlib = require('../middlewares/postgreSQLlib.js');
var methods = {};
var jsons = [];
var mainUrl = 'http://www.salute.gov.it/portale/documentazione/p6_2_8_3_1.jsp?id=20';
var urls = [
{year: '2013', link: 'http://www.salute.gov.it/imgs/C_17_tavole_20_allegati_iitemAllegati_0_fileAllegati_itemFile_1_file.pdf'},
{year: '2012', link: 'http://www.salute.gov.it/imgs/C_17_tavole_20_allegati_iitemAllegati_5_fileAllegati_itemFile_0_file.pdf'},
{year: '2011', link: 'http://www.salute.gov.it/imgs/C_17_tavole_20_allegati_iitemAllegati_6_fileAllegati_itemFile_0_file.pdf'}
];
methods.download = async function(req, res) {
await extractText();
}
async function extractText() {
var config = {
preserveLineBreaks: true
};
urls.forEach(function(url) {
textract.fromUrl(url.link, config, async function(error, text) {
if(error) {
throw error;
}
switch(url.year) {
case '2011':
case '2012':
await extractTextType1(url, text);
break;
case '2013':
await extractTextType2(url, text);
break;
default:
await console.log('Error: no case');
}
});
});
}
async function extractTextType1(url, text) {
var matrix = [];
var map = [];
var vaccines = [];
var regionsTemp = [];
var regions = [];
var regionLength = [1, 2, 1, 2, 3, 1, 1, 1, 2, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1];
var textArray = text.split('\n');
for(var i = 0; i < 23; i++) {
matrix[i] = textArray[i].split(' ');
}
matrix[0].shift();
vaccines = matrix[0];
map[0] = vaccines;
for(var i = 0; i < regionLength.length; i++) {
var j = i + 1;
var indexToRemove = 0;
var numberToRemove = regionLength[i];
var region = matrix[j].splice(indexToRemove, numberToRemove);
regionsTemp.push(region);
map[j+1] = matrix[j];
}
for(var i = 0; i < regionsTemp.length; i++) {
var region = '';
if(regionLength[i] > 1) {
region = regionsTemp[i].join(' ');
}
else {
region = regionsTemp[i].join('');
}
regions.push(region);
}
map[1] = regions;
for(var i = 0; i < map.length; i++) {
for(var j = 0; j < map[i].length; j++) {
map[i][j] = map[i][j].replace(/\r/g, '');
}
}
vaccines = map.shift();
regions = map.shift();
var thisJson = map.reduce(function(result, v, i) {
v.forEach(async function(o, k) {
var obj = createJsonObjectCoverage(url.year, 'Italy', vaccines[k], regions[i], o);
// save on db
const queryInsertDoNothing = {
text: 'INSERT INTO coverages (vaccine, country, region, year, value) VALUES ($1, $2, $3, $4, $5) ON CONFLICT (vaccine, country, region, year, value) DO NOTHING;',
values: [vaccines[k], 'Italy', regions[i], url.year, o]
};
var printText = '[INSERT Italy IN coverages]';
var queryRes = await postgreSQLlib.query(queryInsertDoNothing, printText);
});
return result;
}, jsons);
}
async function extractTextType2(url, text) {
// similar code to extractTextType1(url, text)
}
function createJsonObjectCoverage(year, country, vaccine, region, coverage) {
return {
year: year,
country: country,
region: region,
vaccine: vaccine,
coverage: coverage
};
}
module.exports = methods;
问题是数据库中的插入不能正常工作。
用 scraperCov.js 运行 app.js 的结果是:
START
Connected to db at localhost:5432 as admin (pass: admin)
[CREATE TABLE coverages] OK query
COUNTRY: Albania
COUNTRY: Austria
[INSERT Albania IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
COUNTRY: Belgium
[INSERT Austria IN coverages] OK query
[INSERT Austria IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
[INSERT Belgium IN coverages] OK query
Connection has ended
FINISH
[INSERT Belgium IN coverages] ERR query
从打印中可以看出,最后出现错误,因为在插入结束之前连接已关闭。
另外,插入的顺序不正确(COUNTRY: Albania这个词下什么都没有,而COUNTRY: Austria这个词下有一些与阿尔巴尼亚相关的查询结果等)。
使用 scraperCovIt.js 运行 app.js 的结果是:
START
Connected to db at localhost:5432 as admin (pass: admin)
[CREATE TABLE coverages] OK query
Connection has ended
FINISH
在这种情况下,插入并没有完全执行。
我该如何解决?
这些天我试图解决这个问题,但我不知道该怎么做。这是我第一次使用async/await,遇到了很多麻烦。
感谢任何想帮助我的人
【问题讨论】:
-
您似乎对
await的作用有些困惑。像await console.log(...)这样的语句与console.log(...)完全没有什么不同。await做了一些有用的事情,等待与异步操作相关的承诺。我的猜测是您在一个或多个不返回承诺的函数上使用await,并期望它实际上等待异步完成,但除非函数返回与异步操作。 -
此外,
return await fn()与return fn()没有什么不同。如果fn()返回一个promise,那么你可以直接返回这个promise。 -
我不知道你正在使用的库(特别是数据库),但你应该访问
await的每一次使用,并确保你等待的是一个承诺。如果没有,您要么需要更改要调用的函数以返回承诺,要么需要与使用await不同的设计。 -
这是一个明显错误的:
await extractText();。如果您查看extractText(),它确实返回了一个promise(只是因为它被声明为async),但是该promise 根本没有连接到函数内部的异步操作。整个extractText()函数必须重新设计,以便在实际完成时通过 Promise 进行通信。你不能成功地混合回调和承诺,这是extractText()在其实现中所做的。 -
@jfriend00 那么,scraperCovIt.js 中的问题在于
v.forEach(async function(o, k) {,因为我将回调函数称为async?在 scraperCov.js 我有dowload即async但不返回任何承诺,对吧?然后是await request它应该返回一个承诺,但实际上它没有,对吧?我有点困惑
标签: node.js postgresql async-await