Функция pow()
, возводящая число в какую-нибудь степень, принимает два параметра: какое число возводить и в какую степень возводить. Если вызывать pow()
без параметров, то Python выдаст следующее: "TypeError: pow expected at least 2 arguments, got 0". Интерпретатор сообщает, что функция ожидает 2 параметра, а вы вызвали её без параметров.
Тот, кто создавал функцию pow()
, сделал её функцией с двумя обязательными параметрами, поэтому pow()
невозможно вызвать с другим количеством параметров.
Более того, параметрами pow()
могут быть только числа. Попытка передать в неё, например, пару строк приведет к следующей ошибке: "TypeError: unsupported operand type(s) for ** or pow(): 'str' and 'str'". Результат вызова функции — тоже всегда число.
Другая функция может иметь другое число параметров и другие типы параметров. Например, может существовать функция, которая принимает три параметра: число, строку и еще одно число.
Откуда мы знаем, сколько каких параметров нужно функции pow()
и какого типа будет «возврат»? Мы заглянули в сигнатуру этой функции. Сигнатура определяет входные параметры и их типы, а также выходной параметр и его тип. Про функцию pow()
можно почитать в официальной документации Python или в неофициальной документации на русском языке. Обычно документация для функции имеет вид:
pow(x, y[, z])
Возвращает x в степени y; если z присутствует, возвращает x в степени y, по модулю z.
Первая строка здесь — это сигнатура функции. У функции два обязательных параметра — x
и y
. Параметр z
указан в квадратных скобках. Это означает, что он является не обязательным. Следом идёт пояснение, для чего функция нужна. Документация позволяет понять сколько аргументов у функции и какого они типа, возвращает ли что-то функция и если да, то какой тип будет иметь возвращаемое значение.
Рассмотрим функцию round()
, которая округляет переданное ей число:
result = round(10.25, 0) # 10.0
Мы передали в неё два параметра: число, которое нужно округлить, и точность округления. 0
означает, что округление будет до целого значения.
Чаще всего нужно округлять именно до целого числа (а не до десятых, например), поэтому создатели функции round
сделали второй параметр необязательным и задали ему внутри функции значение по умолчанию 0
. Значит, можно не указывать второй параметр, а результат будет тем же:
result = round(10.25) # 10.0
А если нужна другая точность, то можно передать параметр:
# округление до одного знака после запятой
result = round(10.25, 1) # 10.2
Если функция в Python принимает необязательные аргументы, то они всегда стоят после обязательных. Их количество может быть любым (это зависит от самой функции), но они всегда идут рядом и в конце списка аргументов.
Вам ответят команда поддержки Хекслета или другие студенты.
Курсы программирования для новичков и опытных разработчиков. Начните обучение бесплатно.
Наши выпускники работают в компаниях:
С нуля до разработчика. Возвращаем деньги, если не удалось найти работу.
Зарегистрируйтесь или войдите в свой аккаунт