TypeError:即使在使用JSON.Parse之后也无法在字符串上创建属性'_id'? (MongoDB /Node.js / Twitter API)

时间:2018-09-24 03:54:42

标签: node.js mongodb twitter

编辑-顺便说一句,我正试图在MongoDB数据库中插入100条推文。

我试图将Tweets的文本(使用Twitter API)插入MongoDB数据库中,即使在解析后也得到TypeError: Cannot create property _id on string。我敢打赌,修复它可能是一个简单而愚蠢的错误。我的代码如下:

编辑2-我编辑了代码以得到我仍然遇到的相同错误。

var Twitter = require('twitter');
var fs = require("fs");
var request = require("request");

var client = new Twitter({
  consumer_key: ' ',
  consumer_secret: ' ',
  access_token_key: ' ',
  access_token_secret: ' '});

var MongoClient = require('mongodb').MongoClient;
var url = "mongodb://localhost:27017/mydb";
var parser = { useNewUrlParser: true };

    MongoClient.connect(url, parser, function(err, db) {
      if (err) throw err;
      console.log("Database created!");
      var dbo = db.db("mydb");
      dbo.createCollection("datos_sentimiento", function(err, res) {
        if (err) throw err;
        console.log("Collection created!");
        db.close();
      });
    });

MongoClient.connect(url, parser, function(err, db) {
  if (err) throw err;
  var dbo = db.db("mydb");
  var cont = 0;

  var params = {q: '@Avengers', count: 100, include_rts: 0, tweet_mode: 'extended', retweeted_status: 'extended'};
  client.get('search/tweets', params, function(error, tweets, response) {
  if (!error) {
      //console.log(tweets);
      for(var i=0; i < params.count; i++){

        if(tweets.retweeted_status){
          tweets = tweets.retweeted_status;
          var tweet = (JSON.stringify(tweets.statuses[i])+"\n");
          var string = tweet.replace(/[&\/\\#,+()$~%.'":*?<>{}]/g, '');
          console.log('hi');
        }
        else{

          //console.log('hi2');
        }

        var tweet = (JSON.stringify(tweets.statuses[i].full_text));
        var string = tweet.replace(/[&\/\\#,+()$~%.'":*?<>{}]/g, '');
        var string2 = (JSON.stringify(string)+"\n");

        fs.appendFile("tweet.txt", string2, function (err) {
          if (err) throw err;
            //console.log('Saved!');
        }); 

        /*console.log(cont);
        cont++;*/

        var myobj = JSON.parse(string2);

        console.log("hi "+myobj);
        dbo.collection("datos_sentimiento").insertOne(myobj, function(err, res) {
          if (err) throw err;
          console.log("1 document inserted");
          db.close();
        });
        //console.log(i+'fdfdfdfdf');

        }
      }
  });
}); 

该错误显示以下消息:

TypeError: Cannot create property '_id' on string 'RT @RobertDowneyJr Brace yourselves @Avengers InfinityWar hits the interwebs today httpstcoqvBQ3W8jvc'

2 个答案:

答案 0 :(得分:2)

变量myobj在上面的情况下是字符串,因此,请使其像这样{myobj}成为对象:

上一个:dbo.collection("datos_sentimiento").insertOne(myobj, function(err, res) {

修改为:dbo.collection("datos_sentimiento").insertOne({myobj}, function(err, res) {

答案 1 :(得分:1)

我找到了解决方案。 MongoDB需要(必须具备!)才能拥有文档(例如,text = {screen_name:name,text:text})。我的更正如下:

var text = JSON.parse(string2);
var myobj = {texto: text};

console.log("hi "+text);
dbo.collection("datos_sentimiento").insertOne(myobj, function(err, res) {
    if (err) throw err;
        console.log("1 document inserted");
    db.close();
});