다음과 같은 데이터 프레임이 있습니다.
library(dplyr)
library(tibble)
df <- tibble(
  source = c("a", "b", "c", "d", "e"),
  score = c(10, 5, NA, 3, NA ) ) 
df
다음과 같이 보입니다 :
# A tibble: 5 x 2
  source score
  <chr>  <dbl>
1 a         10 . # current max value
2 b          5
3 c         NA
4 d          3
5 e         NA
내가하고 싶은 것은 NA점수 열에서 기존 max  + n이후의 범위 값 으로 대체하는 것입니다 . 여기서 n1에서 총 행 수의 범위df
이 결과 (수동 코딩) :
  source score
  a         10
  b          5
  c         11 # obtained from 10 + 1
  d          3
  e         12 #  obtained from 10 + 2
어떻게하면 되나요?
답변
다른 옵션 :
transform(df, score = pmin(max(score, na.rm = TRUE) +
                      cumsum(is.na(score)), score, na.rm = TRUE))
#  source score
#1      a    10
#2      b     5
#3      c    11
#4      d     3
#5      e    12
이 작업을 수행하려면 dplyr
library(dplyr)
df %>% mutate(score = pmin(max(score, na.rm = TRUE) +
                      cumsum(is.na(score)), score, na.rm = TRUE))
답변
기본 R 솔루션
df$score[is.na(df$score)] <- seq(which(is.na(df$score))) + max(df$score,na.rm = TRUE)
그런
> df
# A tibble: 5 x 2
  source score
  <chr>  <dbl>
1 a         10
2 b          5
3 c         11
4 d          3
5 e         12
답변
dplyr접근 방식 은 다음과 같습니다 .
df %>%
 mutate(score = replace(score,
                       is.na(score),
                       (max(score, na.rm = TRUE) + (cumsum(is.na(score))))[is.na(score)])
                       )
그것은,
# A tibble: 5 x 2 source score <chr> <dbl> 1 a 10 2 b 5 3 c 11 4 d 3 5 e 12
답변
로 dplyr:
library(dplyr)
df %>%
  mutate_at("score", ~ ifelse(is.na(.), max(., na.rm = TRUE) + cumsum(is.na(.)), .))
결과:
# A tibble: 5 x 2
  source score
  <chr>  <dbl>
1 a         10
2 b          5
3 c         11
4 d          3
5 e         12
답변
dplyr솔루션입니다.
df %>%
  mutate(na_count = cumsum(is.na(score)),
         score = ifelse(is.na(score), max(score, na.rm = TRUE) + na_count, score)) %>%
  select(-na_count)
## A tibble: 5 x 2
#  source score
#  <chr>  <dbl>
#1 a         10
#2 b          5
#3 c         11
#4 d          3
#5 e         12
답변
또 다른 하나는 ThomasIsCoding의 솔루션과 매우 유사합니다.
> df$score[is.na(df$score)]<-max(df$score, na.rm=T)+(1:sum(is.na(df$score)))
> df
# A tibble: 5 x 2
  source score
  <chr>  <dbl>
1 a         10
2 b          5
3 c         11
4 d          3
5 e         12
답변
기본 R 솔루션에 비해 상당히 우아하지는 않지만 여전히 가능합니다.
library(data.table)
setDT(df)
max.score = df[, max(score, na.rm = TRUE)]
df[is.na(score), score :=(1:.N) + max.score]
또는 한 줄이지 만 조금 느립니다.
df[is.na(score), score := (1:.N) + df[, max(score, na.rm = TRUE)]]
df
   source score
1:      a    10
2:      b     5
3:      c    11
4:      d     3
5:      e    12
