TypeError: Невозможно создать свойство '_id' для строки ... даже после использования JSON.Parse ??(MongoDB /Node.js / Twitter API) - PullRequest
0 голосов
/ 24 сентября 2018

РЕДАКТИРОВАТЬ - Кстати, я пытаюсь вставить 100 твитов в базу данных MongoDB.

Я пытаюсь вставить текст твитов (используя 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 голосов
/ 24 сентября 2018

Переменная myobj в указанном выше случае является строкой, поэтому, пожалуйста, сделайте так, чтобы объект был таким {myobj}:

Предыдущий: dbo.collection("datos_sentimiento").insertOne(myobj, function(err, res) {

Изменить на: dbo.collection("datos_sentimiento").insertOne({myobj}, function(err, res) {

0 голосов
/ 24 сентября 2018

Я нашел решение.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();
});
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...