👍2👎1
Функция
— username — пустая строка
— full_name — не пустая строка ("John Doe")
— first_name — также не пустая строка ("John")
В строке
— интерпретатор проверяет условия по очереди и сразу выбирает первое истинное значение;
— Поскольку
get_user_info()
возвращает кортеж из трех элементов, где:— username — пустая строка
— full_name — не пустая строка ("John Doe")
— first_name — также не пустая строка ("John")
В строке
display_name = username or full_name or first_name or "Anonymous"
:— интерпретатор проверяет условия по очереди и сразу выбирает первое истинное значение;
— Поскольку
username
пустой, проверяется full_name
(непустой), и оно присваивается переменной display_name
.👍3👎1
👍4👎2
Атрибут
shape
возвращает кортеж с размерностями структуры данных pandas. Для одномерного объекта Series единственное значение этого кортежа совпадает с размером этого Series. Запятая после 3 — стандартное наглядное представление кортежей Python из одного элемента:
print(diet.shape) # (3, )
👍3👎1
🔍 Что выведет код в Python 3.6+?
Anonymous Quiz
16%
Память: 1e91.50 GB
44%
Память: 1.50 GB
23%
Память: +1.50 GB
16%
Error
👍3👎1
В Python 3.6+ можно использовать кириллические имена переменных в f-строках. Это стало возможным благодаря PEP 498, который ввел f-строки в Python 3.6. Однако это bad practice.
f-строки — это нечто большее, чем просто вставка переменных. Существует скрытый синтаксис форматирования, называемый Format Mini-Language, который позволяет вам лучше контрировать форматирование:
f-строки — это нечто большее, чем просто вставка переменных. Существует скрытый синтаксис форматирования, называемый Format Mini-Language, который позволяет вам лучше контрировать форматирование:
memory = 1.5e9 # 1.5 Гб в байтах
# Базовый пример
print(f"Memory: {memory / 1e9:+.2f} GB") # Добавит знак плюса, оставит только два знака после запятой
# Разные форматы чисел
print(f"Memory (scientific): {memory / 1e9:.2e} GB") # научная нотация
print(f"Memory (percentage): {memory / 1e9:.1%} GB") # процентный формат
print(f"Memory (binary): {int(memory):b} bytes") # двоичный формат
Python Enhancement Proposals (PEPs)
PEP 498 – Literal String Interpolation | peps.python.org
Python supports multiple ways to format text strings. These include %-formatting 1, str.format() 2, and string.Template 3. Each of these methods have their advantages, but in addition have disadvantages that make them cumbersome to use in practice. This...
👍2👎1
🔍 Что выведет код?
Anonymous Quiz
33%
Память: 0000001.50 GB
38%
Память: 1.50 GB
25%
Память: 1.01050 GB
4%
Error
❤🔥2👍2👎1😁1
🔍Что выведет код?
Anonymous Quiz
41%
Память: 1,500,000,000 байт(-ов)
21%
Память: 2B байт(-ов)
28%
Память: 1.500.000.000 байт(-ов)
9%
Error
👍2❤🔥1
В Format Mini-Language есть еще фокусы:
memory = 1.5e9 # 1.5 GB в байтах
# Выравнивание и заполнение
print(f"Memory (right aligned): {memory / 1e9:>10.2f} GB") # выравнивание по правому краю
print(f"Memory (left aligned): {memory / 1e9:<10.2f} GB") # выравнивание по левому краю
print(f"Memory (centered): {memory / 1e9:^10.2f} GB") # центрирование
print(f"Память: {memory / 1e9:010.2f} GB") # заполнение нулями
# Группировка цифр
print(f"Память: {memory:,.0f} байт(-ов)") # разделение запятыми
👍2👎1
LRUcache (от англ. Least Recently Used cache) — это механизм кэширования, который хранит ограниченное количество результатов вычислений или обращений к данным, и при переполнении освобождает место, удаляя из кэша самый долго неиспользуемый элемент.
Декоратор @cache применяется к функциям и автоматически запоминает результаты их вызовов с конкретными аргументами. Если функция с такими же аргументами вызывается повторно, результат берется из кэша, что значительно ускоряет работу, особенно при дорогих в вычислении функциях.
Декоратор @cache применяется к функциям и автоматически запоминает результаты их вызовов с конкретными аргументами. Если функция с такими же аргументами вызывается повторно, результат берется из кэша, что значительно ускоряет работу, особенно при дорогих в вычислении функциях.
🔥2👍1👎1
❤🔥2👍1👎1
Интерпретатор «замрет», потому что попадет в состояние бесконечного ожидания (deadlock).
С такой ситуацией можно справиться, если добавить аргумент-таймаут:
future = Future() # создаем Future-объект в состоянии pending
print(future.result()) # Просим показать result(), БЛОКИРУЯ
future.set_result("Hello from the future!") # Задаем result
result()
будет ждать, пока результат не будет установлен, но set_result()
никогда не будет вызван, так как выполнение программы остановилось на предыдущей строке.С такой ситуацией можно справиться, если добавить аргумент-таймаут:
future.result(timeout=1)
👍2👎1