Проблемы с планированием ... Использование tasksheduleR для запуска сценария R с использованием rtweet и экспорта в таблицу postgreSQL - PullRequest
0 голосов
/ 02 марта 2019

Я пытаюсь запланировать запуск сценария R, используя rtweet для запуска API Twitter, а затем с помощью RPOSTgreSQL загружать данные в таблицу один раз в день.

Мне удалось успешно использовать taskscheduleR для создания задачи.Тем не менее, когда он запускается, я получаю сообщение об ошибке ...

<credentials> oauth_token, oauth_token_secret
---
Requesting token on behalf of user...
Error: API user token required. see http://rtweet.info/articles/auth.html for instructions
Execution halted

Вот весь мой код с некоторыми масками из-за учетных данных API и информации базы данных, паролей и т. Д.

#load all packages
library(rtweet)
library(sqldf)
library(dplyr)
library("RPostgreSQL")

#connect to Twitter API
create_token(
  app = "masked for stack",
  consumer_key = "masked for stack",
  consumer_secret = "masked for stack",
  access_token = "masked for stack",
  access_secret = "masked for stack")

## get user IDs of accounts following 
followers=get_followers("masked for stack", n = 1000)

## lookup data on those accounts
followers_data=lookup_users(followers$user_id)

#add the date of the run
followers_data$date=Sys.Date()

#extract columns
twitter_followers=dplyr::select(followers_data,"date","screen_name","name","location","description","followers_count",
                                "friends_count","listed_count","statuses_count","favourites_count","verified")

# create a connection
# save the password that we can "hide" it as best as we can by collapsing it
pw <- {
  "masked for stack"
}

# loads the PostgreSQL driver
drv <- dbDriver("PostgreSQL")
# creates a connection to the postgres database
# note that "con" will be used later in each connection to the database
con <- dbConnect(drv, dbname = "masked for stack",
                 host = "localhost", port = 5432,
                 user = "postgres", password = pw)
rm(pw) # removes the password

# writes df to the PostgreSQL database
dbWriteTable(con, "twitter_followers", 
             value = twitter_followers, append = TRUE, row.names = FALSE)

Мой код работает отлично, все вручную.Кажется, что rtweet не любит запускаться планировщиком Windows.

Есть идеи?`

1 Ответ

0 голосов
/ 02 марта 2019

Так что после нескольких часов копания я понял, что с приложением scheduleR что-то не работает.Возможно, в планировщике Windows была создана задача, которая не запускалась бы, когда мой ноутбук работал от сети переменного тока. Я не уверен.В любом случае я сделал обходной путь, как это.

Создан текстовый файл и сохранен как расширение .bat в следующем формате:

"C:\Program Files\R\R-3.5.2\bin\x64\R.exe" CMD BATCH file_location.R

Оттуда я запланировал в планировщике Windows.Убедитесь, что вы прошли все варианты и не выбираете базовое задание.Если вы делаете основной, вы можете не позволить ему работать от батареи ноутбука.

...