我写了一个NodeJS应用程序,它使用eBay API从eBay获取列表。我有一个问题,即某些项目正在通过,即使它们应该用简单的if语句过滤掉。
应用程序从前端接收后期数据作为JSON,执行每次搜索,然后根据某些参数过滤掉项目。这是违规代码:
if ( items[i].listingInfo.listingType != 'Auction' ) {
//console.log( items[i].listingInfo.listingType );
if ( items[i].primaryCategory.categoryId == '9355' ) {
//console.log( items[i].primaryCategory.categoryId );
if ( price < maxPrice && price > 40 ) {
//console.log( price, maxPrice );
file = path +
items[i].itemId + '-' +
price + '-' + maxPrice + '-' +
items[i].primaryCategory.categoryId + '-' +
items[i].listingInfo.listingType;
if ( !fs.existsSync( file ) ) {
console.log(
'File ' + file + ' does not exist.',
!fs.existsSync( file ),
items[i].listingInfo.listingType,
price < maxPrice,
items[i].itemId
);
fs.writeFile( file, ' ', function(err) {
if (err) {
if (debug)
console.log('Writing ' + file + ' failed.');
}
else {
if (debug)
console.log('Writing ' + file + ' worked.');
returnData.success = true;
returnData.results[ result.itemId ] = result;
console.log( price, maxPrice, !fs.existsSync( file ) );
console.log('success');
}
})
}
else {
returnData.discard.file[ result.itemId ] = result;
delete returnData.results[ result.itemId ];
}
}
else {
returnData.discard.price[ result.itemId ] = result;
if (debug)
console.log('FAILED (price): ' + items[i].itemId + ' is ' + ( price - maxPrice ) + ' greater than maxPrice.');
}
}
else {
returnData.discard.cat[ result.itemId ] = result;
if (debug)
console.log('FAILED (categoryId): ' + items[i].itemId + ' is ' + items[i].primaryCategory.categoryId);
}
}
else {
returnData.discard.type[ result.itemId ] = result;
if (debug)
console.log('FAILED (listingType): ' + items[i].itemId + ' is a ' + items[i].listingInfo.listingType);
}
您可以看到此行if ( price < maxPrice && price > 40 )
应过滤掉任何大于maxPrice且低于40的项。但是,它不会执行此操作。我不知道为什么会发生这种情况以及这里发生了什么。看起来非常简单明了,但事实并非如此。这是返回的对象,您可以看到它无法正常工作。
111004318957:
listingType: "FixedPrice"
maxPrice: 170
price: 349
我也在使用节点集群,所以我的server.js文件包含:
function start(route, handle) {
if ( cluster.isMaster ) {
for ( var i = 0; i < numCPUs; i++ ) {
cluster.fork();
}
cluster.on('exit', function( worker, code, signal) {
console.log( 'worker ' + worker.process.pid + ' died' );
})
}
else {
function onRequest(request, response) {
var postData = "";
var pathname = url.parse(request.url).pathname;
request.setEncoding("utf8");
request.addListener("data", function(postDataChunk) {
postData += postDataChunk;
});
request.addListener("end", function() {
//console.log('Request ended.');
if ( postData != '' ) {
postData = JSON.parse(postData);
}
//console.log(postData.search.searches[0]);
route(handle, pathname, response, postData);
});
}
http.createServer(onRequest).listen(8888);
console.log("Server has started.");
}
}
感谢所有的帮助,谢谢。
编辑:我应该解释说111004318957
是eBay返回的itemId。结果对象如下所示:
results: {
itemId1: {
listingType: '',
maxPrice: '',
price: ''
},
itemId2: {
listingType: '',
maxPrice: '',
price: ''
}
}
编辑2: price
在此代码段之前设置。它在eBay的响应中返回,它的位置依赖于items [i] .listingInfo.listingType,所以有一个简单的if / else来设置它。
if ( items[i].listingInfo.listingType == 'AuctionWithBIN' ) {
price = parseInt( items[i].listingInfo.buyItNowPrice.USD );
}
else {
price = parseInt( items[i].sellingStatus.currentPrice.USD );
}
答案 0 :(得分:0)
JSON返回listingType,maxPrice,price。
尝试if (items[i].price < maxPrice && items[i].price > 40)
答案 1 :(得分:0)
作者几乎肯定不能对这个问题做出任何贡献,以澄清我的说法是否正确,就像六年前的要求一样。
但是,可以肯定的是,问题与代码的以下部分有关:
$1
fs.writeFile( file, ' ', function(err) {
if (err) {
if (debug)
console.log('Writing ' + file + ' failed.');
}
else {
if (debug)
console.log('Writing ' + file + ' worked.');
returnData.success = true;
returnData.results[ result.itemId ] = result;
console.log( price, maxPrice, !fs.existsSync( file ) );
console.log('success');
}
})
是异步的,并且如果OP循环遍历结果列表,则fs.writeFile
中的result
将始终引用循环的最后一个元素,无论是否元素是否符合条件returnData.results[ result.itemId ] = result
。