Вы уже узнали об операторах, позволяющих различными способами комбинировать множества. Эти операторы максимально похожи на те, что применяются в теории множеств в математике и эта похожесть — очень важное свойство. С теорией множеств любой уважающий себя программист должен познакомиться хотя бы поверхностно — это тот самый пресловутый "фундамент". Поэтому лично я придерживаюсь мнения, что множества нужно использовать в сочетании с операторами.
Однако умолчать о том, что у каждого оператора есть и "словесный" метод-аналог, было бы неправильно. Так что знакомьтесь, методы:
a.union(b) # аналог "a | b"
a.intersection(b) # аналог "a & b"
a.difference(b) # аналог "a - b"
a.symmetric_difference(b) # аналог "a ^ b"
Есть ещё одна причина, по которой я рассказал про те четыре метода выше. Помните, мы рассматривали метод update
у словаря, обновляющий словарь "по месту" с помощью данных из другого словаря? Так вот, для множеств таких update-методов несколько.
difference_update
difference_update
работает похоже на -
/difference
, а именно — удаляет из связанного множества все элементы, которые входят в множество-аргумент:
a, b = {1, 2}, {2, 3}
a.difference_update(b)
a # {1}
intersection_update
intersection_update
(изменяющий аналог &
/intersection
) оставляет в связанном множестве только те элементы, которые входят и в множество-аргумент:
a, b = {1, 2}, {2, 3}
a.intersection_update(b)
a # {2}
symmetric_difference_update
symmetric_difference_update
(изменяющий аналог ^
/symmetric_difference
) добавляет в связанное множество элементы, которые есть только в множестве-аргумента, и удаляет элементы, которые есть в обоих множествах:
a, b = {1, 2}, {2, 3}
a.symmetric_difference_update(b)
a # {1, 3}
update
update
(изменяющий аналог |
/union
) дополняет связанное множество отсутствующими элементами из множества-аргумента:
a, b = {1, 2}, {2, 3}
a.update(b)
a # {1, 2, 3}
Метод
update
с точки зрения единообразия надо было бы назватьunion_update
, но выбрали более распространённое имяupdate
, т.к. это имя часто используется для сходных по смыслу методов других коллекций.
Вам ответят команда поддержки Хекслета или другие студенты.
Выделите текст, нажмите ctrl + enter и отправьте его нам. В течение нескольких дней мы исправим ошибку или улучшим формулировку.
Загляните в раздел «Обсуждение»:
Базовый план откроет полный доступ ко всем курсам, упражнениям и урокам Хекслета, проектам и пожизненный доступ к теории пройденных уроков. Подписку можно отменить в любой момент.
Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно.
Наши выпускники работают в компаниях:
С нуля до разработчика. Возвращаем деньги, если не удалось найти работу.
Зарегистрируйтесь или войдите в свой аккаунт