我试图解析Reddit的RSS源以获取首页文章的标题,并遇到一些麻烦。源代码如下:
//var util = require('util');
//var cheerio = require('cheerio');
var fs = require('fs');
var request = require('request');
var parseString = require('xml2js').parseString;
url = 'http://www.reddit.com/.xml';
request(url, function(error, response, xml){
parseString(xml, function(err, result) {
result = result.rss.channel[0];
console.log(result.item[0]['title']); // works fine, gets first title
for(var key in result){
console.log(result[key]['title']); // returns a bunch of 'undefined'
}
//console.log(util.inspect(result,false,null));
fs.writeFile("index.html", result, function(err){
if(err) { return console.log(err); }
return console.log("File saved.");
});
});
});
答案 0 :(得分:2)
您得到undefined
,因为您应该在result.item
上而不是result
进行迭代。例如:
for(var key in result.item) {
console.log(result.item[key]['title']);
}
此外,您应该使用常规for
- 循环而不是使用for..in
,因为看起来result.item
只是一个普通数组。例如:
var items = result.item;
for (var i = 0; i < items.length; ++i) {
console.log(items[i].title);
}