Как получить финансовую информацию об акциях в R - PullRequest
0 голосов
/ 15 мая 2018

Я пытаюсь получить финансовую информацию, такую ​​как NAV, дивиденды, обязательства.Я пытаюсь получить всю биржевую информацию, используя пакет quantmod.Но это не работает для financials.Есть ли способ получить финансовые данные в R. Я использовал код ниже, и это дает мне ошибку.

КОД

library(quantmod)
statements <- getFinancials("AAPL", auto.assign=FALSE)

ОШИБКА:

Error: ‘getFinancials.google’ is defunct.
Google Finance stopped providing data in March, 2018.

Есть ли другой способ получить финансовую информацию?

1 Ответ

0 голосов
/ 20 июля 2018

Возможно, вам подойдет следующее:

getFin <- function(stock){
  if ("rvest" %in% installed.packages()) {
    library(rvest)
  }else{
    install.packages("rvest")
    library(rvest)
  }
  for (i in 1:length(stock)) {
    tryCatch(
      {
        url <- "https://finance.yahoo.com/quote/"
        url <- paste0(url,stock[i],"/financials?p=",stock[i])
        wahis.session <- html_session(url)                                
        p <-    wahis.session %>%
          html_nodes(xpath = '//*[@id="Col1-1-Financials-Proxy"]/section/div[3]/table')%>%
          html_table(fill = TRUE)
        IS <- p[[1]]
        colnames(IS) <- paste(IS[1,])
        IS <- IS[-c(1,5,12,20,25),]
        names_row <- paste(IS[,1])
        IS <- IS[,-1]
        IS <- apply(IS,2,function(x){gsub(",","",x)})
        IS <- as.data.frame(apply(IS,2,as.numeric))
        rownames(IS) <- paste(names_row)
        temp1 <- IS
        url <- "https://finance.yahoo.com/quote/"
        url <- paste0(url,stock[i],"/balance-sheet?p=",stock[i])
        wahis.session <- html_session(url)
        p <-    wahis.session %>%
          html_nodes(xpath = '//*[@id="Col1-1-Financials-Proxy"]/section/div[3]/table')%>%
          html_table(fill = TRUE)
        BS <- p[[1]]
        colnames(BS) <- BS[1,]
        BS <- BS[-c(1,2,17,28),]
        names_row <- BS[,1]
        BS <- BS[,-1] 
        BS <- apply(BS,2,function(x){gsub(",","",x)})
        BS <- as.data.frame(apply(BS,2,as.numeric))
        rownames(BS) <- paste(names_row)
        temp2 <- BS
        url <- "https://finance.yahoo.com/quote/"
        url <- paste0(url,stock[i],"/cash-flow?p=",stock[i])
        wahis.session <- html_session(url)
        p <-    wahis.session %>%
          html_nodes(xpath = '//*[@id="Col1-1-Financials-Proxy"]/section/div[3]/table')%>%
          html_table(fill = TRUE)
        CF <- p[[1]]
        colnames(CF) <- CF[1,]
        CF <- CF[-c(1,3,11,16),]
        names_row <- CF[,1]
        CF <- CF[,-1] 
        CF <- apply(CF,2,function(x){gsub(",","",x)})
        CF <- as.data.frame(apply(CF,2,as.numeric))
        rownames(CF) <- paste(names_row)
        temp3 <- CF
        assign(paste0(stock[i],'.f'),value = list(IS = temp1,BS = temp2,CF = temp3),envir = parent.frame())

      },
      error = function(cond){
        message(stock[i], "Give error ",cond)
      }
    )
  }
}

Тогда просто

symbols <- c("NVDA", "GOOG", "GE")
getFin(symbols)

GOOG.f$IS
GOOG.f$BS
GOOG.f$CF

Что возвращается;

> head(GOOG.f$CF)
                                12/31/2017
Net Income                        12662000
Depreciation                       6899000
Adjustments To Net Income          8284000
Changes In Accounts Receivables   -3768000
Changes In Liabilities             1121000
Changes In Inventories                  NA
                                12/31/2016
Net Income                        19478000
Depreciation                       6100000
Adjustments To Net Income          7158000
Changes In Accounts Receivables   -2578000
Changes In Liabilities              333000
Changes In Inventories                  NA
                                12/31/2015
Net Income                        16348000
Depreciation                       5024000
Adjustments To Net Income          5609000
Changes In Accounts Receivables   -2094000
Changes In Liabilities              246000
Changes In Inventories                  NA
                                12/31/2014
Net Income                        14136000
Depreciation                       4601000
Adjustments To Net Income          3615000
Changes In Accounts Receivables   -1641000
Changes In Liabilities              261000
Changes In Inventories                  NA

Кредит Эвертон Рейс

...