data:image/s3,"s3://crabby-images/570c8/570c8971103ee53c553fec177648bd27b41cf2ac" alt="R logo"
前回の続き。
下記データフレーム(Dat)で、"Expenses" の値を補完しようと思うけど、
data:image/s3,"s3://crabby-images/4c78e/4c78e1bda4863261ccc57509cf8199c3cd8392c2" alt="r-na-median-2-1"
17行目の "Expenses" は、両隣の "Revenue" と "Profit" から計算できる。
この場合は、
"Expenses (経費)" = "Revenue (収益)" - "Profit (利益)"
となる。
これを R で計算するためには、
# Expenses が NA で Revenue と Profit のデータがある行を抽出
Dat[is.na(Dat$Expenses) & !is.na(Dat$Revenue) & !is.na(Dat$Profit),]
目的の行のみを抽出できた。
data:image/s3,"s3://crabby-images/84b35/84b35883ce4e20f79c200a99876c7e571a0051a2" alt="r-na-5-1"
で、ここの "Expenses" の列の "NA" に "Revenue - Profit" の値を代入したいので、
# Expenses が NA で Revenue と Profit のデータがある行を抽出 し、w に代入
w <- is.na(Dat$Expenses) & !is.na(Dat$Revenue) & !is.na(Dat$Profit)
# 該当のセルに 計算結果を代入
Dat[w,"Expenses"] <- Dat[w,"Revenue"]-Dat[w,"Profit"]
該当の行(17行目)を確認すると、
# 確認
Dat[17,]
無事代入できていた。
data:image/s3,"s3://crabby-images/67030/670302ef3009a0a024adc256b80323e9ded05bd4" alt="r-na-5-2"
リンク
リンク
リンク
リンク