Python: Цепочка вызовов

В этом уроке мы рассмотрим, как комбинировать различные подходы, когда пишем код, а также разберем типичные ошибки новичков.

У нас есть следующий код:

name = 'Tirion'
print(name.upper().lower())  # => `tirion`

Он напечатал на экране tirion.

Синтаксис нескольких подряд идущих точек мы видим впервые, но все операции, которые здесь встречаются, нам знакомы. В этом коде объединились известные возможности языка.

Такое в программировании происходит часто. Если вы не знаете синтаксис, то можно все равно пробовать комбинировать различные подходы, и есть вероятность, что они заработают.

Чтобы понять, как работает этот код, нужно разбить цепочку на отдельные операции:

name = 'Tirion'
upper_name = name.upper()  # 'TIRION'
print(upper_name.lower())  # 'tirion'

Первый и второй примеры эквивалентны. Мы можем выполнять операции последовательно с промежуточным созданием переменных, а можем строить непрерывную цепочку из атрибутов и методов. В цепочках вычисления всегда идут слева направо.

Еще один пример для закрепления:

name = 'Tirion'
print(name.replace('Ti', 'Ki').lower())  # => ?

Над этим кодом нужно хорошо подумать. .lower() применяется к результату вызова метода, который находится левее. А метод replace() возвращает строку. Новички часто делают ошибки в цепочках с методами и забывают ставить вызов:

name = 'Tirion'
# Этот код отработает неверно!
print(name.upper.lower())

Также возможно строить бесконечно длинные и бесполезные цепочки, которые включают в себя срезы:

name = 'Tirion'
# Чему равен результат такого вызова?
print(name[1:5].upper().find('I'))

С функциями это не сработает, так как обычно они вкладываются друг в друга — f(f(f())). Это значительно ухудшает анализ. Но это не значит, что нельзя сделать красиво. В других языках это реализуется через композицию функций или пайплайн-оператор.

Задание

С помощью среза строк получите часть предложения, записанного в переменную text, c 5 по 15 символы включительно. Полученную подстроку обработайте методом .strip() и выведите на экран длину итоговой подстроки. Выполните эти операции подряд в цепочке без создания промежуточных переменных.

Определения

Метод
это функция или процедура, принадлежащая какому-то классу или объекту.
Как с вами связаться? 🙃

Команда проекта находится в телеграм-сообществе по ссылке https://ttttt.me/HexletLearningBot. Там можно задать любой вопрос и повлиять на проект

Упражнение не проходит проверку — что делать? 😶

Если вы зашли в тупик, то самое время поговорить с нашим асситентом Тота во вкладке "Обсуждение". Как правильно задать вопрос:

В моей среде код работает, а здесь нет 🤨

Тесты устроены таким образом, что они проверяют решение разными способами и на разных данных. Часто решение работает с одними входными данными, но не работает с другими. Чтобы разобраться с этим моментом, изучите вкладку «Тесты» и внимательно посмотрите на вывод ошибок, в котором есть подсказки.

Мой код отличается от решения учителя 🤔

Это нормально 🙆, в программировании одну задачу можно выполнить множеством способов. Если ваш код прошел проверку, то он соответствует условиям задачи. В редких случаях бывает, что решение подогнано под тесты, но это видно сразу.

Прочитал урок — ничего не понятно 🙄

Создавать обучающие материалы, понятные для всех без исключения, довольно сложно. Мы очень стараемся, но всегда есть что улучшать. Если вы встретили материал, который вам непонятен, опишите проблему в обратной связи нашего сообщества

Нашли ошибку? Есть что добавить? Пулреквесты приветствуются

Привет! Я Тота и моя задача помочь в обучении. Чтобы активировать меня, нужно зарегистрироваться или залогиниться, если у вас уже есть аккаунт

Loading...

Ваше упражнение проверяется по этим тестам

1from hexlet.test import expect_output
2
3
4def test(capsys):
5    expected = "7"
6    expect_output(capsys, expected)
7

Решение учителя откроется через:

20:00
waiting_clock