Zvážte nasledujúci kód R dplyr:
lahmanNames %>%
bind_rows(.id = "dataframe") %>% # Bind the data frames
filter(var == "playerID") %>% # Filter the results
`$`(dataframe) # <---- WHAT DOES $ MEAN?
Čo sa v tomto prípade týka operátora $?
odpovede:
7 pre odpoveď č. 1Je to ako robiť mtcars$dataframe
, existuje veľa spôsobov, ako to urobiť. v dplyr
0.7.0 funkcie pull
bolo pridané, čo robí to spôsobom, ktorý funguje s potrubím (%>%
).
library(dplyr)
mtcars %>% `$`(mpg)
#> [1] 21.0 21.0 22.8 21.4 18.7 18.1 14.3 24.4 22.8 19.2 17.8 16.4 17.3 15.2
#> [15] 10.4 10.4 14.7 32.4 30.4 33.9 21.5 15.5 15.2 13.3 19.2 27.3 26.0 30.4
#> [29] 15.8 19.7 15.0 21.4
mtcars$mpg
#> [1] 21.0 21.0 22.8 21.4 18.7 18.1 14.3 24.4 22.8 19.2 17.8 16.4 17.3 15.2
#> [15] 10.4 10.4 14.7 32.4 30.4 33.9 21.5 15.5 15.2 13.3 19.2 27.3 26.0 30.4
#> [29] 15.8 19.7 15.0 21.4
mtcars[["mpg"]]
#> [1] 21.0 21.0 22.8 21.4 18.7 18.1 14.3 24.4 22.8 19.2 17.8 16.4 17.3 15.2
#> [15] 10.4 10.4 14.7 32.4 30.4 33.9 21.5 15.5 15.2 13.3 19.2 27.3 26.0 30.4
#> [29] 15.8 19.7 15.0 21.4
mtcars %>% pull(mpg)
#> [1] 21.0 21.0 22.8 21.4 18.7 18.1 14.3 24.4 22.8 19.2 17.8 16.4 17.3 15.2
#> [15] 10.4 10.4 14.7 32.4 30.4 33.9 21.5 15.5 15.2 13.3 19.2 27.3 26.0 30.4
#> [29] 15.8 19.7 15.0 21.4
2 pre odpoveď č. 2
`$`(x, y)
je iný spôsob, ako napísať
x[[y, exact = FALSE]]
To znamená, ak y = "foo"
, potom
`$`(x, y)
je totožná s
x$foo