👀 Проверь, насколько ты хорош в Python
Угадай термин, о котором идёт речь. Он связан с Python и часто всплывает при работе с кодом.
🔒 Ответы прячем под спойлер, чтобы не спойлерить остальным.
Самые догадливые — в комменты 👇
Библиотека питониста #междусобойчик
Угадай термин, о котором идёт речь. Он связан с Python и часто всплывает при работе с кодом.
🔒 Ответы прячем под спойлер, чтобы не спойлерить остальным.
Самые догадливые — в комменты 👇
Библиотека питониста #междусобойчик
❤4🥱2👍1
🔍 Код-ревью: как не поругаться и улучшить код
Недавно спросили:
Код-ревью — это не просто поиск ошибок. Это часть инженерной культуры: возможность учиться, делиться опытом и вместе делать код лучше.
Но чтобы ревью не стало тормозом или ареной споров, важно выстроить процесс правильно.
1️⃣ Чёткие цели и ожидания
Ревью — это не только «работает или нет». Мы смотрим на читаемость, архитектуру, соответствие гайдлайнам, тесты, безопасность и возможные побочные эффекты.
✅ Важно заранее договориться, что считается «блокером», а что — рекомендацией.
2️⃣ Гайдлайны и чек-листы
Хороший чек-лист помогает не забыть важное:
✅ Есть ли тесты и документация?
✅ Соответствует ли код стилю (
✅ Не сломано ли API?
✅ Понятна ли логика?
Такой список снижает субъективность и упрощает обсуждение.
3️⃣ Формат общения
Тон — критически важен. Мы не говорим:
🙅♂️ «Почему ты сделал это так странно?»
А говорим:
✅ «Как думаешь, если сделать вот так — будет понятнее? Вот пример...»
Ревью — это диалог, а не суд. И да, автор тоже имеет право отстоять решение, если оно обоснованное.
4️⃣ Обратная связь и обучение
Каждое ревью — шанс узнать что-то новое.
✅ Хорошие команды не просто указывают на ошибку, а объясняют «почему» и «как лучше».
5️⃣ Инструменты и скорость
Обычно используется Pull Request + CI.
Линтеры и типизация (
✅ Ревью лучше делать в течение дня, чтобы не тормозить разработку.
💬 А как устроено ревью у вас в команде? Что работает, а что вызывает споры? Делитесь в комментариях 👇
Библиотека питониста #междусобойчик
Недавно спросили:
Как вы организуете код-ревью в Python-команде и как избежать конфликтов?
Код-ревью — это не просто поиск ошибок. Это часть инженерной культуры: возможность учиться, делиться опытом и вместе делать код лучше.
Но чтобы ревью не стало тормозом или ареной споров, важно выстроить процесс правильно.
Ревью — это не только «работает или нет». Мы смотрим на читаемость, архитектуру, соответствие гайдлайнам, тесты, безопасность и возможные побочные эффекты.
Хороший чек-лист помогает не забыть важное:
black
, ruff
, mypy
)?Такой список снижает субъективность и упрощает обсуждение.
Тон — критически важен. Мы не говорим:
А говорим:
Ревью — это диалог, а не суд. И да, автор тоже имеет право отстоять решение, если оно обоснованное.
Каждое ревью — шанс узнать что-то новое.
Обычно используется Pull Request + CI.
Линтеры и типизация (
black
, ruff
, mypy
) — на автомате, чтобы не обсуждать стиль вручную.💬 А как устроено ревью у вас в команде? Что работает, а что вызывает споры? Делитесь в комментариях 👇
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8❤4🔥3😢1
📌 Холивар: одна строка — одно действие
В сообществе Python-программистов давно спорят: как лучше оформлять код — разбивать каждое действие на отдельную строку или использовать методные цепочки?
➡️ Подход «одна строка — одно действие»:
— Улучшает читаемость
— Упрощает отладку
— Позволяет легко комментировать каждое действие
— Делает
Пример:
➡️ Подход с цепочками методов:
— Более выразителен, особенно при работе с данными
— Помогает избежать временных переменных
— Позволяет видеть весь «путь трансформации» объекта в одном месте
— Хорошо работает с API вроде pandas, SQLAlchemy, Fluent-style интерфейсами
Пример:
⚠️ Но где проходит граница между выразительностью и нечитаемым монолитом?
💬 А вы что предпочитаете в повседневной практике — лаконичные цепочки или строго пошаговый стиль?
Приводите примеры, делитесь опытом — обсудим!
Библиотека питониста #междусобойчик
В сообществе Python-программистов давно спорят: как лучше оформлять код — разбивать каждое действие на отдельную строку или использовать методные цепочки?
— Улучшает читаемость
— Упрощает отладку
— Позволяет легко комментировать каждое действие
— Делает
git diff
и blame
более нагляднымиПример:
df = df.dropna()
df = df[df["age"] > 18]
df = df.sort_values("score", ascending=False)
df = df.reset_index(drop=True)
— Более выразителен, особенно при работе с данными
— Помогает избежать временных переменных
— Позволяет видеть весь «путь трансформации» объекта в одном месте
— Хорошо работает с API вроде pandas, SQLAlchemy, Fluent-style интерфейсами
Пример:
df = (
df.dropna()
[df["age"] > 18]
.sort_values("score", ascending=False)
.reset_index(drop=True)
)
⚠️ Но где проходит граница между выразительностью и нечитаемым монолитом?
Приводите примеры, делитесь опытом — обсудим!
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7❤5🔥3❤🔥1
🔄 Breaking Changes в Python: как сделать их менее болезненными
На саммите Python Language Summit 2025 инженеры из Meta* поделились опытом массового деплоя Python-кода в прод и тем, как breaking changes усложняют жизнь разработчикам.
▶️ Суть проблемы
Breaking changes — это изменения в языке или стандартной библиотеке, которые ломают совместимость. Они неизбежны, но можно и нужно сделать их предсказуемыми и управляемыми.
▶️ Классификация breaking changes по «болезненности»
1️⃣ Легко находимые
— Можно найти через AST, grep, линтеры
— Примеры: удалённые функции, изменённые аргументы
2️⃣ Находятся при сборке/импорте
— Ошибки видны сразу при запуске или импорте
— Например: изменения в
3️⃣ Проявляются только во время исполнения
— Ошибки зависят от типа/значения
— Самые опасные: ловятся только тестами или в проде
▶️ Что можно улучшить
— Создать таксономию изменений по степени влияния
— Публиковать понятные гайды миграции, включая альтернативы и отличия API
— Сохранять документацию удалённых модулей
— Поддерживать тестирование на pre-release-версиях Python
— Разработать автоматические фиксаторы (например, с использованием Ruff)
▶️ Что обсуждали в комьюнити
—
— Успешный опыт pre-release CI у научного Python
— Идея: «экосистемные тесты» по dependency graph — проверять библиотеки заранее
💬 Вопрос на последок:
Напишите в комментарии или выберите реакцию:
🔥 — Лучше ломать, но двигаться вперёд
❤️ — Нет, стабильность важнее новых фич
👍 — Зависит от масштаба проекта
💥 Понравился пост? С ваc буст, а с нас больше топового контента!
Библиотека питониста #междусобойчик
* признанной экстремистской на территории Российской Федерации
На саммите Python Language Summit 2025 инженеры из Meta* поделились опытом массового деплоя Python-кода в прод и тем, как breaking changes усложняют жизнь разработчикам.
Breaking changes — это изменения в языке или стандартной библиотеке, которые ломают совместимость. Они неизбежны, но можно и нужно сделать их предсказуемыми и управляемыми.
— Можно найти через AST, grep, линтеры
— Примеры: удалённые функции, изменённые аргументы
— Ошибки видны сразу при запуске или импорте
— Например: изменения в
dataclasses
в 3.12— Ошибки зависят от типа/значения
— Самые опасные: ловятся только тестами или в проде
— Создать таксономию изменений по степени влияния
— Публиковать понятные гайды миграции, включая альтернативы и отличия API
— Сохранять документацию удалённых модулей
— Поддерживать тестирование на pre-release-версиях Python
— Разработать автоматические фиксаторы (например, с использованием Ruff)
—
typing-extensions
ломал pydantic
: предлагали автоматические тесты зависимых проектов— Успешный опыт pre-release CI у научного Python
— Идея: «экосистемные тесты» по dependency graph — проверять библиотеки заранее
💬 Вопрос на последок:
Что важнее: эволюция языка или стабильность экосистемы?
Напишите в комментарии или выберите реакцию:
🔥 — Лучше ломать, но двигаться вперёд
❤️ — Нет, стабильность важнее новых фич
👍 — Зависит от масштаба проекта
Библиотека питониста #междусобойчик
* признанной экстремистской на территории Российской Федерации
Please open Telegram to view this post
VIEW IN TELEGRAM
👍13🔥7❤4👾1
🧩 Задача: неожиданный результат с изменением словаря
Что выведет следующий код?
❓ Вопросы:
1. Какой будет вывод каждой из трёх строк?
2. Почему
3. Как изменить функцию, чтобы оригинальный словарь не менялся, а возвращалась новая копия с обновлённым значением?
Подвох:
Словари — изменяемые объекты, передаются по ссылке, поэтому любые изменения внутри функции влияют на оригинал.
Решение:
Что проверяет задача:
✅ Понимание изменяемых объектов и передачи по ссылке в Python
✅ Умение создавать копии объектов для избежания побочных эффектов
✅ Навыки работы с функциями и аргументами
Библиотека питониста #междусобойчик
Что выведет следующий код?
def update_dict(d, key, value):
d[key] = value
return d
my_dict = {'a': 1, 'b': 2}
print(update_dict(my_dict, 'c', 3))
print(update_dict(my_dict, 'd', 4))
print(my_dict)
❓ Вопросы:
1. Какой будет вывод каждой из трёх строк?
2. Почему
my_dict
меняется после вызова функции?3. Как изменить функцию, чтобы оригинальный словарь не менялся, а возвращалась новая копия с обновлённым значением?
Подвох:
Решение:
def update_dict(d, key, value):
new_dict = d.copy()
new_dict[key] = value
return new_dict
Что проверяет задача:
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
❤11👍6🔥3
🤔 Вопрос подписчика: где сейчас хостят Python веб-приложения
🔍 Куда хостить FastAPI / Python веб-приложения в 2025
1️⃣ Render / Railway / Fly.io
— Быстрый деплой, минимальный DevOps
— Поддержка Python из коробки
— Платформа берёт на себя сетку, сертификаты, CI/CD
— Хорошо для MVP, pet-проектов и стартапов
2️⃣ Docker + VPS (Hetzner, DigitalOcean, Contabo)
— Полный контроль над окружением
— Подходит для продакшна, если вы не боитесь DevOps
— Можно легко масштабировать вручную
— Дешевле в долгосрочной перспективе, но требует рук
3️⃣ Serverless (AWS Lambda + API Gateway, Vercel Edge Functions)
— Хорошо, если нужны функции «по вызову»
— Сложно, если у вас нестандартные зависимости или heavy backend
— Не для всех библиотек (например, сложно с pydantic, numpy, и heavy ML)
4️⃣ Cloud Platform-as-a-Service (Google Cloud Run, AWS App Runner, Azure App Service)
— Почти как Heroku, но от облачного провайдера
— Баланс между простотой и гибкостью
— Можно автошкалировать, легко подключить storage / мониторинг
5️⃣ Bonus: Hugging Face Spaces / Gradio / Streamlit Cloud
— Идеально для демо ML-моделей
— Не для продакшна, но отлично для презентаций и ссылок на GitHub
💬 А вы где хостите свои Python проекты?
Есть ли любимый стек или платформа, которая «просто работает»?
Библиотека питониста #междусобойчик
«У меня небольшой проект на FastAPI. Раньше разворачивал Ruby-приложения на EC2, Heroku, VPS. А что сейчас модно/удобно для Python?»
🔍 Куда хостить FastAPI / Python веб-приложения в 2025
— Быстрый деплой, минимальный DevOps
— Поддержка Python из коробки
— Платформа берёт на себя сетку, сертификаты, CI/CD
— Хорошо для MVP, pet-проектов и стартапов
— Полный контроль над окружением
— Подходит для продакшна, если вы не боитесь DevOps
— Можно легко масштабировать вручную
— Дешевле в долгосрочной перспективе, но требует рук
— Хорошо, если нужны функции «по вызову»
— Сложно, если у вас нестандартные зависимости или heavy backend
— Не для всех библиотек (например, сложно с pydantic, numpy, и heavy ML)
— Почти как Heroku, но от облачного провайдера
— Баланс между простотой и гибкостью
— Можно автошкалировать, легко подключить storage / мониторинг
— Идеально для демо ML-моделей
— Не для продакшна, но отлично для презентаций и ссылок на GitHub
💬 А вы где хостите свои Python проекты?
Есть ли любимый стек или платформа, которая «просто работает»?
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7❤2🔥1
🐒 Monkey patching в Python: спасение или анти-паттерн
Monkey patching — это когда вы внедряетесь в чужой код прямо во время выполнения программы.
Например:
— переопределяете метод библиотеки без форка,
— меняете поведение фреймворка на лету,
— или «чините» баг, не дожидаясь pull request'а.
Когда это бывает полезно:
✅ Патчишь баг в библиотеке, который авторы будут чинить 3 месяца
✅ Легаси-проект: трогать архитектуру нельзя, а фичу сдать надо
✅ Хочешь изменить поведение без вмешательства в исходники
А в чём подвох:
❌ Читаемость кода: новый разработчик ничего не поймёт
❌ Ломает совместимость при апдейтах
❌ Трудно отлаживать и тестировать
❌ Можно выстрелить себе в ногу (и команде тоже)
🔥 Вот теперь холиварный момент
Monkey patching — это:
🔥 — Инструмент сильных, просто надо уметь
❤️ — Костыль, который нельзя нормализовать
😃 — Иногда — единственный способ сделать хорошо
👍 — Признак плохой архитектуры, точка
А вы использовали monkey patching в проде?
👇 Расскажите в комментах — чем закончилось и стоило ли оно того?
Библиотека питониста #междусобойчик
Monkey patching — это когда вы внедряетесь в чужой код прямо во время выполнения программы.
Например:
— переопределяете метод библиотеки без форка,
— меняете поведение фреймворка на лету,
— или «чините» баг, не дожидаясь pull request'а.
Когда это бывает полезно:
А в чём подвох:
🔥 Вот теперь холиварный момент
Monkey patching — это:
🔥 — Инструмент сильных, просто надо уметь
❤️ — Костыль, который нельзя нормализовать
😃 — Иногда — единственный способ сделать хорошо
👍 — Признак плохой архитектуры, точка
А вы использовали monkey patching в проде?
👇 Расскажите в комментах — чем закончилось и стоило ли оно того?
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
😁20❤10🔥10👍2
📦 Устанавливаем Python 3.14 beta: быстрый гайд
Многие хотят попробовать Python 3.14 с новым free-threaded режимом, но не знают, как установить beta-версию.
Один из частых вопросов от подписчиков:
Хороший вопрос! Несмотря на то, что Python 3.14 пока в стадии бета, вы уже можете установить его для тестирования.
👇 Вот как это сделать:
➡️ Если вы на Ubuntu
➡️ Если вы на Windows
Скачайте установщик с официального сайта и просто установите
➡️ Если у вас другая система
Скачайте исходный код с python.org и соберите вручную. Некоторые пакетные менеджеры также уже предлагают сборки бета-версий.
⚠️ Важно: это бета, не используйте её в продакшене. Только для экспериментов, например, чтобы протестировать free-threading или другие новинки.
Библиотека питониста #междусобойчик
Многие хотят попробовать Python 3.14 с новым free-threaded режимом, но не знают, как установить beta-версию.
Один из частых вопросов от подписчиков:
Хочу попробовать Python 3.14 с новым free-threaded режимом. Как его установить, если он ещё в бете?
Хороший вопрос! Несмотря на то, что Python 3.14 пока в стадии бета, вы уже можете установить его для тестирования.
# Добавляем PPA
sudo add-apt-repository ppa:deadsnakes/ppa
sudo apt update
# Устанавливаем Python 3.14
sudo apt install python3.14
Скачайте установщик с официального сайта и просто установите
.exe
— он будет существовать параллельно с текущей версией.Скачайте исходный код с python.org и соберите вручную. Некоторые пакетные менеджеры также уже предлагают сборки бета-версий.
⚠️ Важно: это бета, не используйте её в продакшене. Только для экспериментов, например, чтобы протестировать free-threading или другие новинки.
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍8❤2🔥1
Самые догадливые, пишите ответ в комментах 👇
Небольшая подсказка — это термин относится к Python.
Прячем ответы под спойлер, чтобы не спалить остальным.
Библиотека питониста #междусобойчик
Небольшая подсказка — это термин относится к Python.
Прячем ответы под спойлер, чтобы не спалить остальным.
Библиотека питониста #междусобойчик
❤6👍1
🧨 Если бы вы могли навсегда удалить ОДНУ вещь из Python…
Один подписчик признался:
И тут мы задумались... А какие фичи Python вы бы с радостью вычеркнули навсегда?
Вот топ кандидатур на удаление:
❌
❌
❌
❌
❌
❌
❌ и, конечно, магические
🗯 А вы что выберете?
Пишите в комментариях, какую фичу вы бы убрали без сожалений.
Давайте соберём рейтинг самых раздражающих особенностей Python.
Библиотека питониста #междусобойчик
Один подписчик признался:
«Удалил бы self. Ну серьёзно — Python придумал классы, но заставляет каждый раз напоминать об этом вручную.»
И тут мы задумались... А какие фичи Python вы бы с радостью вычеркнули навсегда?
Вот топ кандидатур на удаление:
self
в методахlambda
, которая ничего не объясняетis
vs ==
(и бесконечные грабли с ними)GIL
, тормозящий многопоточностьtyping
, который пугает начинающихasync
/ await
, который «ещё чуть-чуть и заработает»__dunder__
-методы🗯 А вы что выберете?
Пишите в комментариях, какую фичу вы бы убрали без сожалений.
Давайте соберём рейтинг самых раздражающих особенностей Python.
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
😁15❤2👏1
🔥 Cython и PyPy — реальное спасение производительности Python или маркетинговый хайп
Python часто критикуют за скорость — интерпретатор и глобальная блокировка (GIL) создают узкие места, особенно в вычислительно тяжёлых задачах.
Чтобы решить эти проблемы, появились инструменты:
✅ Cython — позволяет писать части кода на языке, близком к C, компилируется в расширения для Python.
➡️ Может дать значительный прирост скорости, особенно для циклов и численных вычислений. Но требует переписывания части кода и понимания низкоуровневых деталей.
✅ PyPy — альтернативная реализация Python с JIT-компиляцией, которая на лету ускоряет выполнение кода без изменений в исходниках.
➡️ Работает отлично для чистого Python-кода, но может иметь проблемы с совместимостью сторонних C-расширений.
Вопрос в воздухе: действительно ли Cython и PyPy — универсальное решение для ускорения Python, или это просто хайп для узких и редких кейсов?
💬 Многие скажут: зачем заморачиваться с этими костылями, если проще переписать узкие места на нативных библиотеках или просто масштабировать. А переход на Cython или PyPy — это лишь добавление головной боли и сложности поддержки.
Библиотека питониста #междусобойчик
Python часто критикуют за скорость — интерпретатор и глобальная блокировка (GIL) создают узкие места, особенно в вычислительно тяжёлых задачах.
Чтобы решить эти проблемы, появились инструменты:
Вопрос в воздухе: действительно ли Cython и PyPy — универсальное решение для ускорения Python, или это просто хайп для узких и редких кейсов?
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
❤8👍4
🔥 Холивар: обратная связь после собеса — обязательна или «идите лесом»
В последнее время всё чаще появляются кандидаты, которые требуют расширенную обратную связь после интервью. Кто-то даже предъявляет претензии в ответ на отказ — «я же дошёл до финала, где мой оффер?!» Один умудрился пригрозить судом, аргументируя это тем, что раз прошёл два тура, значит имел право на трудоустройство. Эйчары в шоке.
🈁 Одни говорят: «Мы потратили своё время — вы обязаны объяснить, почему отказали!»
🈁 Другие: «Это не университет, чтобы каждому ставить рецензию. Не подошёл — до свидания.»
🈁 А третьи: «Если нет фидбэка — вы токсичная компания, и точка.»
Голос народа: вам вообще нужна обратная связь после собеса:
❤️ — Да, и желательно максимально подробная
👍 — Краткая: причины отказа, без воды
🔥 — Нет, это лишнее и бесполезно
😆 — Не нужна, но хоть будьте вежливы
👇 Пишите в комментарии — интересно, кто на чьей стороне.
Библиотека питониста #междусобойчик
В последнее время всё чаще появляются кандидаты, которые требуют расширенную обратную связь после интервью. Кто-то даже предъявляет претензии в ответ на отказ — «я же дошёл до финала, где мой оффер?!» Один умудрился пригрозить судом, аргументируя это тем, что раз прошёл два тура, значит имел право на трудоустройство. Эйчары в шоке.
Голос народа: вам вообще нужна обратная связь после собеса:
❤️ — Да, и желательно максимально подробная
👍 — Краткая: причины отказа, без воды
🔥 — Нет, это лишнее и бесполезно
😆 — Не нужна, но хоть будьте вежливы
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍81❤27😁5🔥4
На первый взгляд — крутой проект на GitHub, обещающий ускорение Python в десятки раз. По факту — странный бинарник без исходников, нереалистичные бенчмарки и токсичный автор, удаляющий комментарии.
🚩 Что должно вызывать тревогу
PyPI и GitHub больше не гарантируют безопасность
Теперь важен не только open source, но и open build chain:
— есть ли CI/CD?
— как собираются бинарники?
— воспроизводим ли релиз?
Как обезопасить себя:
— Не ставьте
pip install
с непроверенных проектов— Всегда читайте исходники перед установкой, особенно если есть нативный код
— Используйте виртуальные окружения или Docker для тестов
— Сканируйте зависимости через safety или pip-audit
А вы проверяете код, прежде чем ставить библиотеку с GitHub? Кто должен проверять (PyPI / GitHub или же пользователь)?
— ❤️ Всегда
— 😁 Только если мало звёзд
— 👍 Кто вообще так делает, просто pip install
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍19😁7❤4
Один из наших подписчиков поделился мыслями после пары месяцев использования uv:
Вроде всё классно… но я всё ещё сомневался, зачем он мне лично.
В целом, инструмент делает именно то, что заявляет: ускоряет Python-проекты, улучшает стандартный tooling (установка пакетов, создание виртуалок и т.д.). Работает быстро и стабильно — не придраться.
Но! Как обычный пользователь Python-библиотек, он взаимодействует с uv всего 2–3 раза в месяц. Всё остальное время — старые добрые pip, venv и уже настроенные окружения.
И вот какие вопросы возникли:
А теперь к вам, сообщество:
Вы уже пробовали uv? Реально ли он экономит вам время? Или всё ещё кажется решением без боли, но и без особой необходимости?
Библиотека питониста #междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
😁3❤2👍1🥱1
Холивар: запускать все тесты — или только нужные
Вопрос для питонистов: что лучше — полный прогон тестов при каждом пуше или выборочный запуск только нужных?
⚡️ Сторонники выборочного запуска говорят:
— «Мы изменили одну функцию в
— CI отрабатывает за 5 минут, а не за 40
— Меньше простаивания разработчиков в ожидании билдов
— Логи чище, меньше случайных падений
🐢 Сторонники полного прогона отвечают:
— «Вчера просто поправили формат даты в
— Легче отлавливать неожиданные регрессии
— Нет сюрпризов после релиза
— CI — это страховка, а не ускоритель
Вот, например, кто-то предложил использовать Snob — инструмент, который экономит время и деньги, анализируя граф зависимостей Python-проекта и выбирая для запуска только те тесты, которые реально затронуты изменениями в коде.
📌 Что делает Snob:
— Отбрасывает ~99% тестов, не связанных с изменениями
— Ускоряет разработку и снижает стоимость CI
— Работает на основе статических импортов, а не предсказаний
— Не заменяет полный регрессионный прогон, но сильно помогает при разработке больших кодовых баз
⚠️ Чего Snob не делает:
— Не ловит динамические импорты, сайд-эффекты во время выполнения и другие неявные зависимости
💬 А теперь вопрос — вы бы доверили такому инструменту свой пайплайн, или всё-таки только полный прогон даёт спокойствие?
Библиотека питониста #междусобойчик
Вопрос для питонистов: что лучше — полный прогон тестов при каждом пуше или выборочный запуск только нужных?
⚡️ Сторонники выборочного запуска говорят:
— «Мы изменили одну функцию в
utils.py
— зачем нам прогонять тесты на API, авторизацию и экспорт в Excel?»— CI отрабатывает за 5 минут, а не за 40
— Меньше простаивания разработчиков в ожидании билдов
— Логи чище, меньше случайных падений
🐢 Сторонники полного прогона отвечают:
— «Вчера просто поправили формат даты в
utils.py
, и тихо умер отчёт в аналитике — в тестах API это бы поймали»— Легче отлавливать неожиданные регрессии
— Нет сюрпризов после релиза
— CI — это страховка, а не ускоритель
Вот, например, кто-то предложил использовать Snob — инструмент, который экономит время и деньги, анализируя граф зависимостей Python-проекта и выбирая для запуска только те тесты, которые реально затронуты изменениями в коде.
📌 Что делает Snob:
— Отбрасывает ~99% тестов, не связанных с изменениями
— Ускоряет разработку и снижает стоимость CI
— Работает на основе статических импортов, а не предсказаний
— Не заменяет полный регрессионный прогон, но сильно помогает при разработке больших кодовых баз
⚠️ Чего Snob не делает:
— Не ловит динамические импорты, сайд-эффекты во время выполнения и другие неявные зависимости
💬 А теперь вопрос — вы бы доверили такому инструменту свой пайплайн, или всё-таки только полный прогон даёт спокойствие?
Библиотека питониста #междусобойчик
❤8👍1
Наши подписчики вспомнили, как у них началось знакомство с Python.
Иногда — это лёгкий старт, но чаще — забавные (и немного болезненные) истории.
Вот три из них
Я учил Python… прямо во время написания C++ модуля.
Задача — сделать часть C++ кода вызываемой из Python. До того, как я вообще знал Python.
SWIG помог, но ощущения были как при операции на открытом сердце человеку, с которым ты только что пошёл на первое свидание.
Мой первый Python-скрипт назывался python.py. Он не работал, и я несколько часов ломал голову, пока не написал свой первый вопрос на Stack Overflow.
Там спросили: «А вы точно не назвали его python?» — и помогли.
Теперь понимаю, насколько это было глупо… но для новичка это казалось отличным названием.
Я пришёл из R и был в бешенстве, что скобки и фигурные, и квадратные в Python значат совсем разные вещи.
А ещё меня бесило, что нет функции grep.
💬 А как у вас началось знакомство с Python?
#междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
😁5❤1
🌀 Заблуждения программистов: где логика даёт сбой
В разработке есть особый класс ошибок — falsehoods: заблуждения, в которые программисты верят, но которые на практике оказываются ложными.
Обычно это звучит логично. Например:
И многие пишут валидацию именно так. Но на деле email может содержать несколько @. Ваш код внезапно «ломается» в реальных условиях.
Таких примеров десятки. Все эти предположения — falsehoods, которые делают софт хрупким.
📚 Существуют целые подборки таких «ложных убеждений». Они помогают расширить взгляд и писать более надёжный код, учитывающий реальные данные и сценарии.
👉 Если хотите стать сильнее как инженер — изучите список falsehoods и держите их в голове.
🐸 Библиотека питониста
#междусобойчик
В разработке есть особый класс ошибок — falsehoods: заблуждения, в которые программисты верят, но которые на практике оказываются ложными.
Обычно это звучит логично. Например:
Email всегда содержит ровно один символ @.
И многие пишут валидацию именно так. Но на деле email может содержать несколько @. Ваш код внезапно «ломается» в реальных условиях.
Таких примеров десятки. Все эти предположения — falsehoods, которые делают софт хрупким.
📚 Существуют целые подборки таких «ложных убеждений». Они помогают расширить взгляд и писать более надёжный код, учитывающий реальные данные и сценарии.
👉 Если хотите стать сильнее как инженер — изучите список falsehoods и держите их в голове.
#междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
🤔6❤4👍2🌚1
Делимся классным туториалом: как сделать мозаику из гифов 90-х с анимацией, полностью рендерящуюся в браузере.
В статье показано:
✨ Немного ностальгии и техно-магии.
#междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7❤1😁1
⚡️ AsyncFlow — симулятор асинхронных распределённых бэкендов
Обычно масштабирование и отказоустойчивость проверяют уже на проде или в нагрузочном стенде. AsyncFlow позволяет сделать это до написания продакшн-кода.
Что умеет:
— моделировать сценарии с учётом RTT, джиттера, лимитов ресурсов, фейлов
— показывать реальное влияние: рост очередей, давление на сокеты/память, распределение задержек
— тестировать стратегии масштабирования и сетевые предположения на уровне архитектуры
Как работает:
— система задаётся как граф компонентов (клиенты, балансировщики, серверы), соединённых сетевыми рёбрами с настраиваемой латентностью
— каждый сервер осознаёт event loop:
• CPU блокирует цикл,
• RAM остаётся занята до освобождения,
• I/O освобождает цикл — как в реальных async-фреймворках
— топологии описываются через YAML или Python DSL
С новым движком событий можно воспроизводить: пики трафика, падения серверов, деградацию линков — и смотреть, что реально произойдёт.
📱 Репозиторий
🐸 Библиотека питониста
#междусобойчик
Обычно масштабирование и отказоустойчивость проверяют уже на проде или в нагрузочном стенде. AsyncFlow позволяет сделать это до написания продакшн-кода.
Что умеет:
— моделировать сценарии с учётом RTT, джиттера, лимитов ресурсов, фейлов
— показывать реальное влияние: рост очередей, давление на сокеты/память, распределение задержек
— тестировать стратегии масштабирования и сетевые предположения на уровне архитектуры
Как работает:
— система задаётся как граф компонентов (клиенты, балансировщики, серверы), соединённых сетевыми рёбрами с настраиваемой латентностью
— каждый сервер осознаёт event loop:
• CPU блокирует цикл,
• RAM остаётся занята до освобождения,
• I/O освобождает цикл — как в реальных async-фреймворках
— топологии описываются через YAML или Python DSL
С новым движком событий можно воспроизводить: пики трафика, падения серверов, деградацию линков — и смотреть, что реально произойдёт.
#междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
❤6👍6
✨ Starplot — библиотека Python для построения карт звёздного неба
Если вы когда-нибудь хотели построить собственную карту неба или визуализировать астрономические объекты, теперь это можно сделать прямо в Python.
Что умеет Starplot:
⭐️ Zenith Plots — показывает всё небо в конкретное время и месте
⭐️ Map Plots — разные картографические проекции
⭐️ Horizon Plots — визуализация горизонта в выбранный момент
⭐️ Optic Plots — эмуляция того, что вы увидите через телескоп
⭐️ Планеты и объекты глубокого космоса — встроено более 14 000
⭐️ Кастомные стили для объектов
От простой карты горизонта до сложных проекций с планетами и галактиками — всё доступно из кода.
🔗 Репозиторий и документация
🐸 Библиотека питониста
#междусобойчик
Если вы когда-нибудь хотели построить собственную карту неба или визуализировать астрономические объекты, теперь это можно сделать прямо в Python.
Что умеет Starplot:
От простой карты горизонта до сложных проекций с планетами и галактиками — всё доступно из кода.
#междусобойчик
Please open Telegram to view this post
VIEW IN TELEGRAM
❤9👍2😍1