我有這種型別的資料,其中列中的數值Sequ定義了一個行序列,而Q名稱中的字符值定義了序列的型別:
df <- data.frame(
Line = 1:12,
Speaker = c(NA, "ID01.A", NA, "ID01.B", "ID07.A", NA, "ID33.B",
"ID33.A", "ID33.C", NA, "ID77.A", "ID77.C"),
Utterance = c(NA, "Who did it?", "(1.99)", "Peter did.", "Hello!", NA, "So you're coming?",
"erm", "Yes, sure.", "(0.22)", "Good night?", "Yeah, sleep well"),
Sequ = c(NA,1,1,1, NA,NA, 2,2,2, NA, 3,3),
Q = c(NA, "q_wh", "", "", NA, NA, "q_decl", "", "", NA, "q_wh", "")
)
我想在那些Sequ數值(而不是NA) AND where 的值上對資料框進行子集化Q == q_wh。我可以通過使用na_if然后完成此任務fill:
library(tidyr)
df %>%
mutate(Q = na_if(Q, "")) %>%
fill(Q, .direction = "down") %>%
filter(!is.na(Sequ) & Q == "q_wh")
Line Speaker Utterance Sequ Q
1 2 ID01.A Who did it? 1 q_wh
2 3 <NA> (1.99) 1 q_wh
3 4 ID01.B Peter did. 1 q_wh
4 11 ID77.A Good night? 3 q_wh
5 12 ID77.C Yeah, sleep well 3 q_wh
但是有沒有另一種更直接的方法,不用繞道na_ifand fill, 來過濾df?
編輯:
我找到了一個沒有fill和的解決方案na_if:
df %>%
group_by(Sequ) %>%
mutate(Q = Q[!Q==""]) %>%
filter(!is.na(Sequ) & Q == "q_wh")
uj5u.com熱心網友回復:
使用分別ave替換 by"Sequ"與 first Q, finally subset。
df[!is.na(df$Sequ), ] |>
transform(Q=ave(Q, Sequ, FUN=\(x) x[1])) |>
subset(!is.na(Sequ) & Q == 'q_wh')
# Line Speaker Utterance Sequ Q
# 2 2 ID01.A Who did it? 1 q_wh
# 3 3 <NA> (1.99) 1 q_wh
# 4 4 ID01.B Peter did. 1 q_wh
# 11 11 ID77.A Good night? 3 q_wh
# 12 12 ID77.C Yeah, sleep well 3 q_wh
注: R version 4.1.2 (2021-11-01)。
或者使用 tidyverse 方言。
library(magrittr)
df[!is.na(df$Sequ), ] %>%
dplyr::mutate(Q=ave(Q, Sequ, FUN=\(x) x[1])) %>%
dplyr::filter(!is.na(Sequ) & Q == 'q_wh')
# Line Speaker Utterance Sequ Q
# 1 2 ID01.A Who did it? 1 q_wh
# 2 3 <NA> (1.99) 1 q_wh
# 3 4 ID01.B Peter did. 1 q_wh
# 4 11 ID77.A Good night? 3 q_wh
# 5 12 ID77.C Yeah, sleep well 3 q_wh
資料:
df <- structure(list(Line = 1:12, Speaker = c(NA, "ID01.A", NA, "ID01.B",
"ID07.A", NA, "ID33.B", "ID33.A", "ID33.C", NA, "ID77.A", "ID77.C"
), Utterance = c(NA, "Who did it?", "(1.99)", "Peter did.", "Hello!",
NA, "So you're coming?", "erm", "Yes, sure.", "(0.22)", "Good night?",
"Yeah, sleep well"), Sequ = c(NA, 1, 1, 1, NA, NA, 2, 2, 2, NA,
3, 3), Q = c(NA, "q_wh", "", "", NA, NA, "q_decl", "", "", NA,
"q_wh", "")), class = "data.frame", row.names = c(NA, -12L))
轉載請註明出處,本文鏈接:https://www.uj5u.com/ruanti/393443.html
上一篇:基于一列和一行合并兩個資料集
下一篇:按組選擇倒數第二個日期并改變新列
