R: Как фильтровать с двумя условиями одного столбца?

Например, у меня есть три столбца: столбец ID, столбец посещений, столбец наркотиков. Столбец «Препарат» содержит символьные значения A, B, C и D. Проблема в том, что каждый идентификатор содержит только A, B, C или D ИЛИ комбинацию A и B.

ID  Visit Drug 
1   1       A
1   2       B
1   3       A
2   1       B
2   2       B
3   1       C
3   2       C

Итак, если я хочу отфильтровать идентификатор, содержащий ТОЛЬКО лекарство B (у него не может быть одновременно A и B), как мне отфильтровать это? Сверху мне нужен только ID 2, но НЕ ID 1, потому что ID 1 имеет как A, так и B.

Я пробовал этот код, но он дает неверный результат

df %>% 
group_by(id) %>% 
filter(drug == "B" | drug != "A" & drug != "B" )

Любая помощь будет оценена по достоинству!

Стоит ли изучать PHP в 2023-2024 годах?
Стоит ли изучать PHP в 2023-2024 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
1
0
58
1

Ответы 1

В этом случае вы должны указать условие для всего вектора Drug, как в случае с all в следующем:

df %>% group_by(ID) %>% filter(all(Drug == "B"))
# A tibble: 2 x 3
# Groups:   ID [1]
#      ID Visit Drug 
#   <int> <int> <fct>
# 1     2     1 B    
# 2     2     2 B  

Если я хочу отфильтровать как A, так и B, то могу ли я сделать то же самое? ... filter (all (drug_code == "A" & drug_code == "B")) дает мне 0 наблюдений

irene 27.10.2018 02:45

Вы имеете в виду, как в вашем примере получить ID равным 1? В любом случае all(drug_code == "A" & drug_code == "B") никогда ничего не вернет. Возьмите df$Drug[1:3] и посмотрите, что произойдет: df$Drug[1:3] == "A" & df$Drug[1:3] == "B" будет искать (векторизованным образом) свои элементы, которые одновременно являются "A" и "B", что невозможно. В данном случае вам нужен df %>% group_by(ID) %>% filter(all(c("A", "B") %in% Drug)), означающий, что и "A", и "B" существуют где-то в Drug.

Julius Vainora 27.10.2018 02:51

Я предлагаю взять df$Drug и попробовать any, all, ==, !=, x %in% y, y %in% x, чтобы получить хорошее представление о том, что происходит.

Julius Vainora 27.10.2018 02:53

Большое спасибо! Это действительно помогло !! Я изучу те, что указаны выше :)

irene 27.10.2018 02:57

Возможно, я ошибаюсь, но я считаю, что c («A», «B») внутри all (c («A», «B»)% в% Drug даст идентификаторы с '«либо» A или B, что немного отличается от фильтрации идентификаторов как с A, так и с B

irene 27.10.2018 02:59

Он сохранит те ID, которые содержат "A" хотя бы один раз и "B" хотя бы один раз, давая только ID == 1. Если ноль вхождений тоже нормально, но элементами Drug могут быть только "A" или "B", тогда вы должны использовать df %>% group_by(ID) %>% filter(all(Drug %in% c("A", "B"))), задав ID как 1 и 2. (Это означает, что %in% не симметричен).

Julius Vainora 27.10.2018 03:04

Рад помочь. Думаю, теперь ответ можно принять.

Julius Vainora 27.10.2018 03:17

Другие вопросы по теме