👍2
При обнаружении пропущенного значения во время импорта файла библиотека pandas заменяет его NumPy-объектом
Обратите внимание, что
nan
. Акроним nan означает «нечисловое значение» (not a number) и представляет собой собирательный термин для неопределенных значений. Другими словами, nan
— условный объект, обозначающий пустое или отсутствующее значение.Обратите внимание, что
dtype
у Series — float64
. При обнаружении значения nan
pandas
автоматически преобразует числовые значения из целых в числа с плавающей точкой; такое внутреннее техническое требование позволяет библиотеке хранить числовые значения и отсутствующие значения в одном и том же однородном Series
.👍2👎1
Что выведет код?
Anonymous Quiz
61%
Привет
6%
Ничего
31%
NameError: имя func2() не определено
2%
TypeError: функцию нельзя вкладывать в другую функцию
👍6
Код внутри тела какой-то функции не запускается до тех пор, пока функция не будет вызвана; поскольку имена в функции не распознаются вплоть до ее действительного выполнения, внутри функции обычно можно ссылаться на имена, находящиеся где угодно в файле.
Однако правило LEGB вносит свои корректировки. Python все равно проверяет существование имен во время выполнения, а не во время определения функции, так что следующий код вызовет ошибку:
x должен существовать в момент вызова функции, а не просто где-то в файле.
Однако правило LEGB вносит свои корректировки. Python все равно проверяет существование имен во время выполнения, а не во время определения функции, так что следующий код вызовет ошибку:
def main(x):
print(x)
main(x)
x = 5
x должен существовать в момент вызова функции, а не просто где-то в файле.
👍2👨💻1
🌱 Что выведет recur2.py?
Anonymous Quiz
3%
1
16%
2
39%
ModuleNotFoundError: не найден модуль recur1
42%
ImportError: невозможно импортировать Y
🤯5
В модуле recur1 присваивается имя X и затем перед присваиванием имени Y импортируется модуль recur2. В этой точке recur2 может извлечь recur1 как единое целое с помощью оператора import — он уже существует во внутренней таблице модулей Python, которая делает его импортируемым и также препятствует зацикливанию операций импортирования. Но если в модуле гecuг2 применяется from, то он будет в состоянии видеть только имя X; имя Y, которое присваивается позже оператора import в recur1, еще не существует, а потому вы получите ошибку:
Python избегает повторного выполнения операторов модуля recur1, когда он рекурсивно импортируется из recur2 (иначе операции импортирования отправляли бы сценарий в бесконечный цикл, который мог бы требовать нажатия <Ctrl+C> или чего-то более радикального), но пространство имен модуля recurl является незавершенным, когда он импортируется в модуле recur2.
Если бы в recur2.py использовался просто
from recur1 import X # Нормально: имя X уже присвоено
from recur1 import Y # Ошибка: имя Y пока не существует
Python избегает повторного выполнения операторов модуля recur1, когда он рекурсивно импортируется из recur2 (иначе операции импортирования отправляли бы сценарий в бесконечный цикл, который мог бы требовать нажатия <Ctrl+C> или чего-то более радикального), но пространство имен модуля recurl является незавершенным, когда он импортируется в модуле recur2.
Если бы в recur2.py использовался просто
import recur1
, а не from recur1 import Y
, всё бы сработало, потому что import не требует, чтобы имя уже было определено — оно просто добавляет модуль как объект:
import recur1
print(recur1.Y) # Это бы сработало, если бы вызвалось после выполнения recur1.py
🤪2
Что верно о переменных на верхнем уровне модуля, чьи имена начинаются с одиночного подчеркивания?
Anonymous Quiz
6%
Они игнорируются интерпретатором
37%
Они не копируются в область видимости, когда используется from *
12%
Они всегда являются магическими методами
45%
Ничего из вышеперечисленного не верно
👍2🤮1💯1
Переменные на верхнем уровне модуля, чьи имена начинаются с одиночного подчеркивания, не копируются в область видимости импортера, когда используется форма оператора
Можно управлять тем, что импортируется через
from *
. Тем не менее, они по-прежнему доступны посредством оператора import
или нормальной формы оператора from
. Можно управлять тем, что импортируется через
from *
, явно определяя список __all__:
__all__ = ['visible_name']
👍5
🔍 Чем изменение sys.path отличается от установки PYTHONPATH для модификации пути поиска модулей?
Anonymous Quiz
14%
sys.path работает только в виртуальном окружении
16%
sys.path является подмножеством PYTHONPATH
37%
Изменение sys.path воздействует только на одну выполняющуюся программу
32%
Начиная с Python 3.X, эти способы идентичны
🤬2😱1🤝1🤗1
Изменение
sys.path
воздействует только на одну выполняющуюся программу (процесс), и оно временно — когда программа заканчивает работу, изменение утрачивается. Настройка PYTHONPATH
существует в среде операционной системы — она подхватывается глобально всеми вашими программами на компьютере и потому эта настройка остается после завершения программ.👍1🤬1🤡1
В Python суперкласс — это класс, от которого наследуется другой класс. Другими словами, это родительский класс по отношению к дочернему (подклассу).
Также в Python есть функция
class Animal: # суперкласс
def speak(self):
print("Some sound")
class Dog(Animal): # подкласс
def speak(self):
print("Bark")
Также в Python есть функция
super()
, которая позволяет обращаться к методам суперкласса из подкласса:
class Dog(Animal):
def speak(self):
super().speak() # вызов метода speak из Animal
print("Bark")
👍1🤨1😭1
👍1🤯1
Когда создаёшь pd.Series из списка кортежей, каждый кортеж становится отдельным элементом серии. В результате вывод будет выглядеть так:
0 (120, 41, 26)
1 (196, 165, 45)
dtype: object
🥱1
Предоставлять ли объяснения к задаче сразу? (пост может выходить одновременно с задачей)
Anonymous Poll
41%
Да
46%
Нет
21%
Хочу увидеть результат
👍2🥴1
👍1😱1😢1