Есть список email emails = ["a@x.com", "b@y.com", "c@x.com"]. Нужно получить множество доменов (часть после @). Какой вариант корректен?
A
{e.split("@")[0] for e in emails}B
{e.split("@")[1] for e in emails}C
[e.split("@")[1] for e in emails]D
set(emails)Правильный ответ. Set comprehension позволяет извлечь домен из каждой строки и автоматически убрать дубликаты.
Разбор
Выражение {e.split("@")[1] for e in emails} берёт часть после @ для каждого email. Результат — set, поэтому повторяющиеся домены (например, "x.com") автоматически схлопываются в один элемент.
Проверь себя · 1/3разбор после ответа
Есть список сумм
amounts = [0, 0, 10]. Что вернёт выражение any(a > 0 for a in amounts)?Ещё вопросы по теме «Генераторы списков и встроенные функции»
- Дан список `xs = [1, -2, 3, 0]`. Что вернёт выражение `[x * 2 for x in xs if x > 0]`?
- Есть список словарей `users`, где у некоторых пользователей отсутствует email (например, `u.get("email")` возвращает `None`). Нужно получить список email в нижнем регистре, пропуская отсутствующие. Какой вариант обычно наиболее читаемый?
- Дан список батчей `batches = [[101, 102], [], [103]]`. Что вернёт выражение `[x for batch in batches for x in batch]`?
- Дан список `vals = [0, 1, 2]`. Что вернёт выражение `[x if x % 2 == 0 else -1 for x in vals]`?
- У вас есть список словарей `users` с ключами `id` и `is_active`. Нужно получить список `id` только активных пользователей. Какое решение обычно проще читать, чем комбинация `map()` + `filter()` с `lambda`?
- Все вопросы по «Генераторы списков и встроенные функции» →