R:如何访问tibble中的tibble?

时间:2017-11-24 19:50:58

标签: r financial tidyquant

我正在读哈德利:http://r4ds.had.co.nz/tibbles.html

但是,我仍然难以在一个元组中引用一个元素。

> library(tidyquant)
> f <- tq_get("F", get="key.ratios")
> f
# A tibble: 7 x 2
            section               data
              <chr>             <list>
1        Financials <tibble [150 x 5]>
2     Profitability <tibble [170 x 5]>
3            Growth <tibble [160 x 5]>
4         Cash Flow  <tibble [50 x 5]>
5  Financial Health <tibble [240 x 5]>
6 Efficiency Ratios  <tibble [80 x 5]>
7  Valuation Ratios  <tibble [40 x 5]>

> f["Financials"]
Error: Column `Financials` not found

> f[["Financials"]]
NULL

> f$Financials
NULL
Warning message:
Unknown or uninitialised column: 'Financials'. 

> f$data[[f$section == 'Financials']]
Error in f$data[[f$section == "Financials"]] : 
  attempt to select less than one element in integerOneIndex

> f$data[[1]]$Financials
NULL
Warning message:
Unknown or uninitialised column: 'Financials'. 

1 个答案:

答案 0 :(得分:1)

来自 tidyquant &#39; documentation,使用tq_get(symbol, get = "key.ratios")返回嵌套的tibble。在tibble&#34;数据&#34;列是包含列的其他表:section,sub.section,group,category和date。

您最初试图访问名为&#34; Financials&#34;在主数据框中,但不存在这样的列(它只有&#34;部分&#34;和&#34;数据&#34;)。 &#34;财务&#34;相反,是&#34;部分&#34;的一个元素(行)。柱。我想你想要:

filter(f, section == "Financials") %>% unnest()