Как преобразовать из таблицы в формат данных?

Сначала я усреднил данные игрока и уменьшил их.

player <- player %>%
   group_by(NM) %>%
   summarise_all(funs(mean(., na.rm = TRUE)))

И это результат.

head(player) 
# A tibble: 6 x 26
  NM       NO   MIN `2PTM` `2PTA` `2PT(%)` `3PTM` `3PTA` `3PT(%)`   FGM   FGA `FG(%)`    FTM   FTA `FT(%)`    OR    DR   REB
  <chr> <dbl> <dbl>  <dbl>  <dbl>    <dbl>  <dbl>  <dbl>    <dbl> <dbl> <dbl>   <dbl>  <dbl> <dbl>   <dbl> <dbl> <dbl> <dbl>
1 a.~     6  918.  0.32   0.72     14.8   0.44   1.9       13.7 0.76  2.62     17.9 0.18   0.32     6.5  0.38  0.64  1.02 
2 b.~    13 1681.  3.41   6.43     54.5   0.574  2.13      19.7 3.98  8.56     47.4 0.907  1.33    35.5  2.04  3.22  5.26 
3 c.~    31  704.  0.921  2.16     36.0   0.421  1.18      21.1 1.34  3.34     38.6 0.447  0.658   19.7  0.526 1.16  1.68 
4 d.~    21  968.  0.885  1.88     32.6   0.846  2.08      22.1 1.73  3.96     35.3 1.15   1.35    39.1  0.462 1.04  1.5  
5 e.~     9  105.  0.118  0.294     8.82  0.176  0.412     11.8 0.294 0.706    18.6 0.0588 0.118    2.94 0.294 0.176 0.471
6 f.~     2  509.  0.571  1.57     21.4   0.286  1.29      10   0.857 2.86     17   0.286  0.714   21.4  0.143 0.714 0.857
# ... with 8 more variables: AST <dbl>, TO <dbl>, STL <dbl>, BS <dbl>, PF <dbl>, FO <dbl>, PP <dbl>, PTS <dbl>

Затем я использовал функцию mutate. Но это не добавило столбец. Я слышал, что Tibble был ограничен. Из-за этого я превратил его в фрейм данных.

> head(as.data.frame(player))
  NM NO       MIN      2PTM      2PTA    2PT(%)      3PTM      3PTA   3PT(%)       FGM       FGA    FG(%)        FTM
1 a  6  918.0600 0.3200000 0.7200000 14.800000 0.4400000 1.9000000 13.74000 0.7600000 2.6200000 17.94000 0.18000000
2 b 13 1680.8889 3.4074074 6.4259259 54.462963 0.5740741 2.1296296 19.72222 3.9814815 8.5555556 47.42593 0.90740741
3 c 31  704.0526 0.9210526 2.1578947 35.973684 0.4210526 1.1842105 21.05263 1.3421053 3.3421053 38.63158 0.44736842
4 d 21  967.5000 0.8846154 1.8846154 32.576923 0.8461538 2.0769231 22.11538 1.7307692 3.9615385 35.26923 1.15384615
5 e  9  105.1765 0.1176471 0.2941176  8.823529 0.1764706 0.4117647 11.76471 0.2941176 0.7058824 18.64706 0.05882353
6 f  2  508.5714 0.5714286 1.5714286 21.428571 0.2857143 1.2857143 10.00000 0.8571429 2.8571429 17.00000 0.28571429
     FTA     FT(%)        OR        DR       REB       AST        TO        STL         BS        PF         FO        PP
1 0.3200000  6.500000 0.3800000 0.6400000 1.0200000 0.8000000 0.2200000 0.44000000 0.00000000 1.9400000 0.64000000 0.6400000
2 1.3333333 35.481481 2.0370370 3.2222222 5.2592593 1.2592593 0.8333333 0.74074074 0.42592593 3.3888889 1.70370370 4.5925926
3 0.6578947 19.736842 0.5263158 1.1578947 1.6842105 0.4736842 0.1842105 0.28947368 0.02631579 1.3684211 0.65789474 1.6842105
4 1.3461538 39.115385 0.4615385 1.0384615 1.5000000 0.9230769 0.8846154 0.50000000 0.03846154 2.1923077 2.46153846 1.6153846
5 0.1176471  2.941176 0.2941176 0.1764706 0.4705882 0.0000000 0.1176471 0.05882353 0.00000000 0.1176471 0.05882353 0.1176471
6 0.7142857 21.428571 0.1428571 0.7142857 0.8571429 0.7142857 0.5714286 0.28571429 0.00000000 1.4285714 0.57142857 0.8571429
    PTS
1 2.1400000
2 9.4444444
3 3.5526316
4 5.4615385
5 0.8235294
6 2.2857143

Q. 1. Почему я не могу использовать функцию mutate? На самом деле, из-за отсутствия кода ошибки, это работает. Но столбец не добавляется.

  1. Как преобразовать tibble в data.frme без изменений? Я предполагаю, что это связано с иррациональным числом.

0 ответов

Если вам нужен фрейм данных сразу после этого преобразования, вы можете попробовать:

already_a_DF <- player %>%
       group_by(NM) %>%
       summarise_all(funs(mean(., na.rm = TRUE))) %>% as.data.frame
Другие вопросы по тегам