<?xml version="1.0" encoding="UTF-8"?>

<rss version="2.0" xmlns:dc="http://purl.org/dc/elements/1.1/" >

  <channel>
    <title><![CDATA[Все посты подряд / Python / Хабр]]></title>
    <link>https://habr.com/ru/hubs/python/posts/</link>
    <description><![CDATA[Python – высокоуровневый язык программирования]]></description>
    <language>ru</language>
    <managingEditor>editor@habr.com</managingEditor>
    <generator>habr.com</generator>
    <pubDate>Sat, 06 Jun 2026 00:24:36 GMT</pubDate>
    
    
      <image>
        <link>https://habr.com/ru/</link>
        <url>https://habrastorage.org/webt/ym/el/wk/ymelwk3zy1gawz4nkejl_-ammtc.png</url>
        <title>Хабр</title>
      </image>
    

    
      
        
    

  

  
  <item>
    <title><![CDATA[Пост @dugalb — Python — 04.06.2026 07:56]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1043412/</guid>
    <link>https://habr.com/ru/posts/1043412/?utm_campaign=1043412&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Почему подсчёт металлопроката на фото нельзя решить простым CV: инженерный эксперимент</strong></p><p>В задачах строительного контроля и складского учёта регулярно возникает практическая проблема: необходимо автоматически определить количество элементов в пачке металлопроката (трубы, профили, швеллеры) по фотографии.</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/c6e/55a/f3d/c6e55af3d76a1ea4d4b879e58e52adab.png" width="1155" height="650"></figure><p>На практике это до сих пор часто выполняется вручную — с типичными ошибками: — перекрытие элементов в пачке — сложное освещение на площадке — различие типов профилей — человеческий фактор при массовом пересчёте</p><p>Была проверена базовая идея: можно ли обойтись без нейросетей и решить задачу классическими методами компьютерного зрения.</p><p>Использован упрощённый CV-конвейер:</p><ul><li><p>локальное размытие изображения (11×1 и 1×11) </p></li><li><p>сравнение пикселей с локальным средним уровнем </p></li><li><p>выделение областей повышенной интенсивности</p></li><li><p>формирование бинарной маски потенциальных торцов</p></li></ul><p>Метод не требует обучения модели и работает на CPU.</p><p><strong>Результаты</strong></p><p>Метод действительно даёт первичный сигнал, но имеет существенные ограничения:</p><ul><li><p>быстро отсекает явно пустые или нерелевантные области</p></li><li><p>не разделяет плотные пачки профилей</p></li><li><p>чувствителен к освещению и теням</p></li><li><p>даёт ложные срабатывания на посторонние объекты</p></li></ul><p><strong>Вывод</strong></p><p>Классические методы CV могут использоваться только как предварительный фильтр.</p><p>Для практической задачи подсчёта металлопроката требуется: — детекция объектов (YOLO-подходы) — либо сегментация с учётом перекрытий — адаптация под разные типы профилей</p><p>Если у вас есть похожие задачи на производстве или складе — интересно обсудить реальные условия: — типы проката — качество фото — сценарии учёта</p><p>P.S. Код базового эксперимента — это около 20 строк на OpenCV. Если нужен код — дайте знать в комментариях, выложу полный сниппет с фильтрацией. Но спойлер: для реальной работы его недостаточно.</p> <a href="https://habr.com/ru/posts/1043412/?utm_campaign=1043412&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Thu, 04 Jun 2026 04:56:11 GMT</pubDate>
    <dc:creator><![CDATA[dugalb]]></dc:creator>
      
      <category><![CDATA[opencv]]></category><category><![CDATA[python]]></category><category><![CDATA[matplotlib]]></category><category><![CDATA[компьютерное зрение]]></category><category><![CDATA[computervision]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @dugalb — Python — 04.06.2026 07:29]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1043408/</guid>
    <link>https://habr.com/ru/posts/1043408/?utm_campaign=1043408&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Автоматизация расчётных схем: Python против ручного оформления</strong></p><p>Иногда на построение расчётной схемы уходит больше времени, чем на сам расчёт.</p><p>Нужно показать балку, нагрузки, размеры, оформить картинку для отчёта или пояснительной записки. И вот уже запускается ЛИРА, CAD или другой тяжёлый софт ради схемы, которую можно описать несколькими параметрами.</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/2f2/97d/cec/2f297dcecedd4faa992d1b9e5529696a.png" width="1280" height="720"></figure><p>Есть и другой подход — генерировать такие схемы программно на Python через Matplotlib.</p><p>Вместо ручного рисования задаются:</p><p>• координаты опор;</p><p>• сосредоточенные силы;</p><p>• распределённые нагрузки;</p><p>• размеры и подписи.</p><p>Меняется исходное значение — схема перестраивается автоматически за доли секунды.</p><p>На изображении пример консольной балки(часть балки для МНП - расчета по Маколею или методу начальных параметов) с нагрузками 75 кН и 20 кН/м. Вся графика построена кодом. Никакого ручного оформления, масштабирования и выравнивания стрелочек.</p><p>Что нравится больше всего — оформление перестаёт быть отдельной задачей. Можно сосредоточиться на механике и проверке гипотез, а не на поиске нужной кнопки в интерфейсе.</p><p>Кстати, сам скрипт занимает меньше 30 строк кода.</p><p>Если хотите продолжения — напишите, какую схему или эпюру вы бы автоматизировали в первую очередь. Потребуется код — предупредите, подготовлю.</p> <a href="https://habr.com/ru/posts/1043408/?utm_campaign=1043408&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Thu, 04 Jun 2026 04:29:15 GMT</pubDate>
    <dc:creator><![CDATA[dugalb]]></dc:creator>
      
      <category><![CDATA[сопромат]]></category><category><![CDATA[python]]></category><category><![CDATA[matplotlib]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @denis-19 — Python (+4) — 29.05.2026 07:39]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1040916/</guid>
    <link>https://habr.com/ru/posts/1040916/?utm_campaign=1040916&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Открытый проект <a href="https://github.com/solvercaptcha/solvecaptcha-python" rel="noopener noreferrer nofollow">Python library for interacting with the Solvecaptcha API (captcha‑solving service)</a>&nbsp;— это легковесная библиотека на&nbsp;Python, которая проходит самые популярные проверки через Solvecaptcha. </p><p>Обходит большинство самых мощных и популярных капч: </p><ul><li><p>reCAPTCHA v2&nbsp;и v3;</p></li><li><p>Cloudflare Turnstile;</p></li><li><p>FunCaptcha (Arkose Labs); </p></li><li><p>GeeTest и GeeTest v4; </p></li><li><p>Amazon WAF; </p></li><li><p>KeyCaptcha; </p></li><li><p>Grid, ClickCaptcha, Rotate, Canvas; </p></li><li><p>обычные текстовые и графические капчи, в&nbsp;том числе аудио.</p></li></ul><p>Библиотека небольшая, работает стабильно, разработчики её поддерживают, добавляя новые виды капч. Можно настраивать таймауты решения капч, чтобы имитировать поведение человека.</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/7d6/a4f/05d/7d6a4f05dc6ea700bf58e26fc8afdd2a.jpeg" width="1280" height="870"></figure> <a href="https://habr.com/ru/posts/1040916/?utm_campaign=1040916&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Fri, 29 May 2026 04:39:54 GMT</pubDate>
    <dc:creator><![CDATA[denis-19]]></dc:creator>
      
      <category><![CDATA[Solvecaptcha API]]></category><category><![CDATA[Solvecaptcha]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @andrey_chuyan — DevOps (+1) — 27.05.2026 12:28]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1040016/</guid>
    <link>https://habr.com/ru/posts/1040016/?utm_campaign=1040016&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/ab9/cb7/650/ab9cb76502e30681d7ee84fd05ec0c1b.jpg" width="1331" height="751"></figure><p>Привет, коллеги! 👋 Уже в это воскресенье, 31 мая в 10:00, устроим мощный заряд знаний! ⚡️ За 4 часа своими руками поднимем стек мониторинга, настроим дашборды и оповещения! 📊🔔</p><p>Для кого это будет полезно:<br>- разработчики 💻<br>- аналитики 📈<br>- системные инженеры 🔧</p><p>Все подробности здесь: <a href="https://debugskills.ru/articles/labs/prometheus-grafana/" rel="noopener noreferrer nofollow">https://debugskills.ru/articles/labs/prometheus-grafana/</a></p> <a href="https://habr.com/ru/posts/1040016/?utm_campaign=1040016&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Wed, 27 May 2026 09:28:27 GMT</pubDate>
    <dc:creator><![CDATA[andrey_chuyan]]></dc:creator>
      
      <category><![CDATA[grafana]]></category><category><![CDATA[prometheus]]></category><category><![CDATA[observability]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @vibecodingai — Python (+1) — 26.05.2026 14:29]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1039580/</guid>
    <link>https://habr.com/ru/posts/1039580/?utm_campaign=1039580&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>🐍 Python Roadmap 2026: наконец-то  актуальная карта изучения Python.</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/646/2fe/1cf/6462fe1cfb92c08c6140efd797bde21c.jpg" width="1024" height="1280"></figure><p>На <a href="https://github.com/justxor/pythonroamap2026" rel="noopener noreferrer nofollow">GitHub выложили большой русскоязычный роадмап</a> по Python на 2026 год - от первых скриптов до уровня Middle+/Senior.</p><p>&nbsp;Маршрут собран под современный Python:</p><p>- Python 3.13+</p><p>- free-threaded mode без GIL</p><p>- JIT</p><p>- uv вместо боли с pip/venv/poetry</p><p>- ruff, pyright, pytest, hypothesis</p><p>- async-first подход</p><p>- типизация</p><p>- CPython внутри</p><p>- web, базы, ML/AI, DevOps и архитектура</p><p>В роадмапе есть нормальная последовательность: сначала окружение и база, потом идиомы, ООП, типы, стандартная библиотека, асинхронность, тестирование, внутренности CPython, web, базы данных, AI-направление, продакшн и архитектура.</p><p>На каждом этапе есть задачи, чеклисты, примеры кода и бесплатные ресурсы. То есть это не мотивационная простыня, а маршрут, по которому реально можно идти несколько месяцев и видеть прогресс.</p><p>Для джунов  хороший роадмап закрыть дыры.</p><ul><li><p><a href="https://github.com/justxor/pythonroamap2026" rel="noopener noreferrer nofollow">Github</a></p></li></ul><p>#junior #python </p> <a href="https://habr.com/ru/posts/1039580/?utm_campaign=1039580&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Tue, 26 May 2026 11:29:39 GMT</pubDate>
    <dc:creator><![CDATA[vibecodingai]]></dc:creator>
      
      <category><![CDATA[python]]></category><category><![CDATA[python3]]></category><category><![CDATA[roadmap]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @senya_t — Natural Language Processing (+3) — N/P]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1039284/</guid>
    <link>https://habr.com/ru/posts/1039284/?utm_campaign=1039284&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Всем привет, нужны рекомендации и советы по следующим вопросам:</p><ol><li><p>Порекомендуйте бесплатные ресурсы для подготовки к собеседованиям по аналитике. </p></li><li><p>Если найдётся кто-то, кто работал над галлюцинациями и достоверностm. информации, сгенерированной LLM, поделитесь опытом.</p></li></ol> <a href="https://habr.com/ru/posts/1039284/?utm_campaign=1039284&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Mon, 25 May 2026 17:58:01 GMT</pubDate>
    <dc:creator><![CDATA[senya_t]]></dc:creator>
      
      <category><![CDATA[ai]]></category><category><![CDATA[llm]]></category><category><![CDATA[собеседования]]></category><category><![CDATA[аналитика]]></category><category><![CDATA[анализ данных]]></category><category><![CDATA[аналитика данных]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @SvetaDT — Блог компании Doubletapp — N/P]]></title>
    <guid isPermaLink="true">https://habr.com/ru/companies/doubletapp/posts/1038764/</guid>
    <link>https://habr.com/ru/companies/doubletapp/posts/1038764/?utm_campaign=1038764&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Как запускать маркетинговые спецпроекты с помощью мини-приложений в VK, Telegram и Макс&nbsp;</strong></p><p>Mini Apps уже давно не просто «обертка для бота», а полноценная платформа для запуска спецпроектов, игровых механик и промо-активностей, которые&nbsp; часто используются в маркетинге.&nbsp;</p><p>Сегодня Mini Apps и боты — это полноценные платформы для:</p><ul><li><p>игровых механик</p></li><li><p>программ лояльности</p></li><li><p>event-маркетинга</p></li><li><p>UGC-кампаний</p></li><li><p>проектов с прямыми эфирами</p></li><li><p>AI-сценариев</p></li><li><p>интерактивного контента.</p></li></ul><p>В этой подборке – статьи команды Doubletapp о запуске и, проектировании мини-приложений на разных платформах, а также реализации проектов наших клиентов.&nbsp;</p><p><strong><a href="https://habr.com/ru/companies/doubletapp/articles/917286/" rel="noopener noreferrer nofollow">От кнопки до продакшена: как мы делаем Telegram Mini Apps</a></strong></p><p>В туториале разработчики разобрали все стадии создания мини аппа:</p><ul><li><p>как настроить проект</p></li><li><p>как создать фронтенд на React с поддержкой Telegram SDK</p></li><li><p>как реализовать бэкенд на Python (Django)</p></li><li><p>как связать все компоненты и развернуть приложение.  </p></li></ul><p>Пройдите все этапы вместе с авторами — и получите базу для запуска собственного Mini App в Telegram. </p><p><strong><a href="https://habr.com/ru/companies/doubletapp/articles/1013494/" rel="noopener noreferrer nofollow">Fame to Flame: как мы за два месяца собрали VK Mini App на 80 000 пользователей и собственный видеостриминг</a></strong></p><p>Интересный кейс про создание VK Mini App для танцевального чемпионата — с загрузкой пользовательского видеоконтента, голосованием, розыгрышами призов, anti-fraud системой и высокой нагрузкой.</p><p>Хороший пример того, как мини-приложения превращаются из маркетинговой механики в полноценную event-платформу.</p><p><strong><a href="https://habr.com/ru/companies/doubletapp/articles/928874/" rel="noopener noreferrer nofollow">Меньше нагрузки — больше запросов: искусство кеширования API</a></strong></p><p>Маркетинговые спецпроекты часто живут короткое время, но получают резкие всплески нагрузки: запуск рекламы, стрим в реальном времени, конкурсы, голосования и UGC-механики.</p><p>В статье backend-разработчик Doubletapp показывает, как правильно строить API caching и снижать нагрузку на инфраструктуру без потери производительности.</p><blockquote><p>Если вы планируете запуск собственного Mini App в Telegram, VK или Макс — команда <a href="https://doubletapp.ai/miniapp/?utm_source=habr&amp;utm_medium=post&amp;utm_campaign=podborka_mini_apps" rel="noopener noreferrer nofollow">Doubletapp</a> поможет пройти путь от идеи и UX-сценариев до production-инфраструктуры и масштабирования под высокие нагрузки.&nbsp;</p></blockquote> <a href="https://habr.com/ru/posts/1038764/?utm_campaign=1038764&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Mon, 25 May 2026 12:00:01 GMT</pubDate>
    <dc:creator><![CDATA[SvetaDT (Doubletapp)]]></dc:creator>
      
      <category><![CDATA[боты]]></category><category><![CDATA[mini apps]]></category><category><![CDATA[mini app]]></category><category><![CDATA[mini apps telegram]]></category><category><![CDATA[mini apps python react]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @vibecodingai — Машинное обучение (+2) — 24.05.2026 10:35]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1038620/</guid>
    <link>https://habr.com/ru/posts/1038620/?utm_campaign=1038620&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Microsoft выложила в open source AI Engineer Coach - плагин, который оценивает, насколько адекватно вы работаете с агентами и не сливаете токены в пустоту.</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/fe3/11c/3d1/fe311c3d15cf84a07b302180374a36c1.jpg" width="1280" height="1182"></figure><p>По сути, это локальный тренер по агентному кодингу. Он смотрит на ваши сессии, показывает, какие агенты использовались, сколько ушло токенов, где промпты были нормальными, а где вы просто заставляли дорогую модель делать работу, которую можно было решить проще.</p><p>Отдельно плагин проверяет 45 анти-паттернов. Например, если вы не используете plan mode, гоняете мощные модели на мелкие задачи, повторяете одни и те же действия руками или плохо готовите проект под работу агентов - он это подсветит.</p><p>Есть и практичная часть: AI Engineer Coach анализирует, готов ли проект к агентному кодингу, есть ли нужные файлы и инструкции, находит повторяющиеся промпты и помогает превращать их в скиллы. Плюс внутри есть роадмап по вайбкодингу и ачивки, чтобы было понятно, куда расти дальше.</p><p>Всё работает локально и бесплатно. Microsoft отдельно подчёркивает, что данные никуда не отправляются.</p><p>Выглядит как полезная штука для тех, кто уже живёт в Claude Code, Codex, Cursor и похожих инструментах, но хочет понять, где реально ускоряется, а где просто красиво сжигает контекст.</p><p><a href="https://github.com/microsoft/AI-Engineering-Coach" rel="noopener noreferrer nofollow">https://github.com/microsoft/AI-Engineering-Coach</a></p> <a href="https://habr.com/ru/posts/1038620/?utm_campaign=1038620&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Sun, 24 May 2026 07:35:55 GMT</pubDate>
    <dc:creator><![CDATA[vibecodingai]]></dc:creator>
      
      <category><![CDATA[машинное+обучение]]></category><category><![CDATA[искусственный интеллект]]></category><category><![CDATA[ai]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @vibecodingai — Машинное обучение (+3) — 19.05.2026 13:54]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1036862/</guid>
    <link>https://habr.com/ru/posts/1036862/?utm_campaign=1036862&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><a href="https://github.com/justxor/MachineLearningRoadmap" rel="noopener noreferrer nofollow">Большой русскоязычный roadmap по машинному обучению</a>: от первого <code>import numpy</code> до LLM, RAG, fine-tuning, AI-агентов и MLOps и лучших примеров вабкодинга.</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/195/ea9/e63/195ea9e63ecba8748bbf87335b09b3f8.jpg" width="853" height="1280"></figure><p>Внутри нормальная структура: что учить, в каком порядке, зачем это нужно и что должно получиться на практике после каждого этапа.</p><p>Roadmap разбит на 7 треков:</p><ol><li><p>Фундамент: Python, математика, статистика, инструменты</p></li><li><p>Классический ML: scikit-learn, табличные данные, метрики, валидация</p></li><li><p>Deep Learning: PyTorch, CNN, RNN, training loop</p></li><li><p>LLM и трансформеры: attention, KV-cache, RAG, LoRA, агенты</p></li><li><p>Generative AI: изображения, видео, аудио, мультимодальность</p></li><li><p>MLOps и прод: Docker, Kubernetes, CI/CD, monitoring, serving</p></li><li><p>Специализация: CV, NLP, RecSys, RL, Safety</p></li></ol><p>Roadmap не продаёт иллюзию “обучил модель - стал ML-инженером”.</p><p>В реальной работе много времени уходит на данные, метрики, деплой, мониторинг, воспроизводимость и разбор ошибок. Модель - только часть системы.</p><p>Хорошая мысль из roadmap: LLM не делает джуна сеньором. Она ускоряет того, кто уже понимает базу. Без базы человек просто становится оператором Copilot, который не может объяснить, почему всё сломалось.</p><p>По времени тоже без сказок:</p><ol><li><p>0-3 месяца: Python, математика, классический ML</p></li><li><p>3-6 месяцев: Deep Learning и PyTorch</p></li><li><p>6-12 месяцев: LLM, RAG, fine-tuning, AI-агенты</p></li><li><p>12+ месяцев: MLOps, прод, масштабирование, специализация</p></li></ol><p>Тут же собрано 7 болших бесплатных курсов по машинному обучению, математике и вайбкодингу!</p><p>Если давно хотели зайти в ML системно, а не прыгать между роликами про ChatGPT, Stable Diffusion и “топ-10 библиотек”, это хороший ориентир.</p><p><a href="https://github.com/justxor/MachineLearningRoadmap" rel="noopener noreferrer nofollow">https://github.com/justxor/MachineLearningRoadmap</a></p> <a href="https://habr.com/ru/posts/1036862/?utm_campaign=1036862&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Tue, 19 May 2026 10:54:14 GMT</pubDate>
    <dc:creator><![CDATA[vibecodingai]]></dc:creator>
      
      <category><![CDATA[машинное+обучение]]></category><category><![CDATA[искусственный интеллект]]></category><category><![CDATA[python]]></category><category><![CDATA[data]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @Rembish — Открытые данные (+3) — 18.05.2026 17:19]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1036516/</guid>
    <link>https://habr.com/ru/posts/1036516/?utm_campaign=1036516&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Вы когда-нибудь задумывались о том, насколько связен наш мир? Насколько сложно пересечь границу между странами? И вообще сколько их, этих граничных переходов? А насколько хорош аэропорт Вашего города - в сколько стран или направлений из него можно улететь? А есть ли паромы и периодические водные маршруты между двумя государствами? А ходят ли поезда из одной страны в другую, или ветка уже давно заброшена?</p><p>Это кажется простой задачей, пока мы находимся в Европе или, к примеру, в Северной Америке. Но начинает быть очень интересным исследованием, когда мы переместимся в Африку, Центральную Азию или, положим, в Южную Америку. А в Карибском бассейне вдруг окажется, что этим маленькие острова и не связаны настолько хорошо между собой.</p><p>А если включить в это уравнение закрытость границ, визовые и паспортные ограничение, то внезапно окажется, что задачка-то и не из лёгких.</p><p>Именно поэтому и возник проект Портулан: <strong><a href="https://portolanmap.com" rel="noopener noreferrer nofollow">portolanmap.com</a></strong>. Чтобы показать доступность территорий для внешнего мира. Ведь хотелось бы, чтобы границы были только у нас в головах, но на деле нам приходится считаться с границами государств и территорий.</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/f2e/ad9/8df/f2ead98df2bfadd0b264d4d991b0400c.png" alt="Заглавный экран карты" title="Заглавный экран карты" width="1323" height="939"><div><figcaption>Заглавный экран карты</figcaption></div></figure><p>Аэропорты, терминалы паромов, сеть железных дорог, включая международные. Визы, посольства, базовая информация по странам. Всё вместе и в очень залипательном формате.</p><p>Под капотом - Python-pipeline для сбора и нормализации данных, Svelte/MapLibre GL на фронтенде, статическая раздача через Cloudflare без бэкенда и баз данных.</p> <a href="https://habr.com/ru/posts/1036516/?utm_campaign=1036516&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Mon, 18 May 2026 14:19:20 GMT</pubDate>
    <dc:creator><![CDATA[Rembish]]></dc:creator>
      
      <category><![CDATA[gis]]></category><category><![CDATA[python]]></category><category><![CDATA[maplibre]]></category><category><![CDATA[maplibre gl]]></category><category><![CDATA[open data]]></category><category><![CDATA[геоданные]]></category><category><![CDATA[аэропорты]]></category><category><![CDATA[карта мира]]></category><category><![CDATA[страны]]></category><category><![CDATA[маршруты]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @kobubu — Искусственный интеллект (+2) — N/P]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1032794/</guid>
    <link>https://habr.com/ru/posts/1032794/?utm_campaign=1032794&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>В фильме Пассажиры 2016 г. впервые показано, как ии-ассистент сливает чувствительную информацию другим пользователям и рушит их жизни</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/f17/752/268/f17752268b8a5670243fbf725457896a.png" alt="ИИ-агент готовится слить твой секрет другому пользователю" title="ИИ-агент готовится слить твой секрет другому пользователю" width="530" height="298"><div><figcaption>ИИ-агент готовится слить твой секрет другому пользователю</figcaption></div></figure><p>Прикольный эпизод из фильма Пассажиры 2016 г., который точно описывает один из механизмов работы агентов. По сюжету, герой по ошибке пробуждается один из 5000 человек на корабле, который летит на далекую планету, и понимает, что он проснулся слишком рано, а до пункта назначения лететь еще  90 лет. Единственный его собеседник - андроид-бармен Артур.</p><p>Героя мучает совесть, но он все же будит спящую пассажирку, чтобы ему было не так скучно лететь. Однако прежде чем ее разбудить, он просит Артура хранить в секрете то, что это он ее разбудил. Говоря в терминологии ии-агентов, пользователь и агент на этом месте заключили контракт о чувствительной информации.</p><p>Затем во время празднования ДР героини в баре она сообщает Артуру, что между ними нет секретов. Артур, как хороший ии-агент, переспрашивает у героя, так ли это, и тот подтверждает, не особо задумываясь. В этот момент ии-агент получает указание, что эта информация больше не является чувствительной, что сразу же рушит счастье героя. Пардон за спойлер, если что.</p><p><a href="https://t.me/ML_Goose" rel="noopener noreferrer nofollow">Телеграм канал автора</a>, где он что‑то пишет про&nbsp;ML, NLP и разработку  </p> <a href="https://habr.com/ru/posts/1032794/?utm_campaign=1032794&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Fri, 08 May 2026 05:56:48 GMT</pubDate>
    <dc:creator><![CDATA[kobubu]]></dc:creator>
      
      <category><![CDATA[ии-агент]]></category><category><![CDATA[ии-агенты в бизнесе]]></category><category><![CDATA[ии]]></category><category><![CDATA[ии и машинное обучение]]></category><category><![CDATA[ии чат-бот]]></category><category><![CDATA[ии-ассистент]]></category><category><![CDATA[ии помощник]]></category><category><![CDATA[ии-модель]]></category><category><![CDATA[ии бот]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @asrelo — Python — N/P]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1030730/</guid>
    <link>https://habr.com/ru/posts/1030730/?utm_campaign=1030730&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>В TOML нет <code>null</code>. У меня — есть (только для Python)</strong></p><p><strong>TLDR: </strong>TOML — удобный формат конфигураций, но ему не хватает поддержки <code>null</code>. Создатели языка осознанно отказались и отказываются добавлять <code>null</code>. Я столкнулся с этой проблемой при слиянии TOML-конфигураций в своём Python-проекте и решил её, форкнув популярные библиотеки и добавив в них поддержку значения <code>null</code>  : <a href="https://pypi.org/project/tomli-null/" rel="noopener noreferrer nofollow">tomli-null</a> (парсер) и <a href="https://pypi.org/project/tomli-w-null/" rel="noopener noreferrer nofollow">tomli-w-null</a> (генератор).</p><p><a href="https://toml.io/" rel="noopener noreferrer nofollow">TOML</a> — популярный с недавних пор язык конфигурационных файлов, <s>сочетающий</s> избегающий проблемы других языков:</p><ul><li><p>TOML стандартизован, имеет типы данных, позволяет кодировать вложенные структуры (привет, INI);</p></li><li><p>TOML относительно прост и парсится без хитростей (привет, YAML),</p></li><li><p>синтаксис TOML легко читаем, поддерживает комментарии и не имеет нюансов вроде ошибок от далёких скобок и лишних запятых (привет, JSON).</p></li></ul><p>TOML, согласно <a href="https://toml.io/en/v1.1.0" rel="noopener noreferrer nofollow">спецификации</a>, "стремится быть минимальным форматом для файлов конфигурации, который легко читается благодаря очевидной семантике". С "минимальностью" языка в принципе можно поспорить — там и отдельные типы для даты/времени (4 штуки, 3 из них имеют варианты синтаксиса), и сахар в числовых литералах вроде <code>0xFF00_0000</code>, и непростой синтаксис для ключей (чтобы допускать и сочетать простые ключи, составные ключи, произвольные ключи в кавычках).</p><p>Но вот что я совершенно не ожидал и проглядел, когда выбирал TOML основным форматом для человеко-редактируемых структур данных в своём проекте, — что <strong>в TOML нет <code>null</code></strong>. Вообще. Это осознанное решение создателей языка. Разные аргументы против <code>null</code>, прозвучавшие за это время:</p><ul><li><p>"<em>Если значение не определено, пару ключ-значение просто нужно не указывать.</em>" <em>Нужно</em>, не <em>можно</em>.</p><p>Случаи, когда в приложении значение по умолчанию отличается от <code>null</code>, игнорируются.</p></li><li><p>"<em><code>null</code> создаёт неоднозначность между значением <code>null</code> и отсутствием пары ключ-значение.</em>"</p></li><li><p>"<em>Если мы разрешим <code>null</code>, это повлияет на всю систему типов; например, целое число теперь будет не "целое число", а "</em><a href="https://github.com/toml-lang/toml/issues/146#issuecomment-14217902" rel="noopener noreferrer nofollow"><em>целое число или null</em></a><em>".</em>"</p><p>???</p></li><li><p>"<em>Если очень нужно, вы можете использовать специальные значения по своему усмотрению: <code>0</code>, <code>-1</code>, <code>""</code>, <code>"null"</code>, <code>[]</code>, <code>{}</code>. Ещё можно использовать дополнительные поля для обозначения наличия значения (типа <code>{ present=true, value=100500 }</code>, или <code>null_values = ["key_a", "key_c"]</code>).</em>"</p><p>Гора разнообразных костылей с барского плеча, на пустом месте добавляющие кучу боли для интероперабельности, спасибо.</p></li></ul><p>Ответственных за спецификацию <a href="https://github.com/toml-lang/toml/issues/30" rel="noopener noreferrer nofollow">годами</a> <a href="https://github.com/toml-lang/toml/issues/802" rel="noopener noreferrer nofollow">просят</a> <a href="https://github.com/toml-lang/toml/discussions/1037" rel="noopener noreferrer nofollow">добавить</a> <code>null</code> в будущей версии, ответственные ушли в глухой отказ.</p><p>Для меня наличие <code>null</code> в подобном языке было само собой разумеющимся, я даже не думал об этом, когда разрабатывал сложный проект на Python, где файлы TOML пишутся и читаются человеком, пишутся и читаются программами, сливаются друг с другом. Когда я наконец-то напоролся на практике на отсутствие <code>null</code> (при слиянии конфигураций), менять всё на YAML было уже слишком поздно, а костыли добавили бы слишком много сложности.</p><p>Поэтому я форкнул пару библиотек и добавил в них поддержку <code>null</code> самым очевидным образом, не нуждающимся даже в примерах — просто литерал <code>null</code> на стороне TOML соответствует <code>None</code> на стороне Python.</p><ul><li><p><a href="https://pypi.org/project/tomli-null/" rel="noopener noreferrer nofollow">tomli-null</a> — парсер, форк <a href="https://pypi.org/project/tomli/" rel="noopener noreferrer nofollow">tomli</a> (<code>tomli</code> включена в Python 3.11 как <a href="https://docs.python.org/3/library/tomllib.html" rel="noopener noreferrer nofollow">tomllib</a>);</p></li><li><p><a href="https://pypi.org/project/tomli-w-null/" rel="noopener noreferrer nofollow">tomli-w-null</a> — генератор, форк <a href="https://pypi.org/project/tomli-w/" rel="noopener noreferrer nofollow">tomli-w</a>.</p></li></ul><p>(100% покрытие тестами прилагается само собой.)</p><p>P.S. PyPI очень... <em>интересным </em>образом показывает информацию об авторах из пакета, несколько раз напоролся, пока пытался убрать автора оригинальных библиотек из поля "для связи" на сайте.</p> <a href="https://habr.com/ru/posts/1030730/?utm_campaign=1030730&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Sat, 02 May 2026 20:32:20 GMT</pubDate>
    <dc:creator><![CDATA[asrelo]]></dc:creator>
      
      <category><![CDATA[TOML]]></category><category><![CDATA[Python]]></category><category><![CDATA[конфигурация]]></category><category><![CDATA[open source]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @denis-19 — Open source (+4) — 01.05.2026 20:06]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1030514/</guid>
    <link>https://habr.com/ru/posts/1030514/?utm_campaign=1030514&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Представлен открытый проект <a href="https://github.com/olalie/tapmap" rel="noopener noreferrer nofollow">TapMap</a>, который следит за всеми подключениями на интерактивной карте и показывает, к серверам в каких странах отправляет запросы ПК пользователя. </p><p>Проект сканирует приложения, сервисы, страны и порты за последние 30 дней. При этом данные никуда не улетают — всё локально на компьютере.</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/790/d90/ef7/790d90ef73a6457396065f94f66922cb.gif" width="1916" height="1076"></figure> <a href="https://habr.com/ru/posts/1030514/?utm_campaign=1030514&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Fri, 01 May 2026 17:06:55 GMT</pubDate>
    <dc:creator><![CDATA[denis-19]]></dc:creator>
      
      <category><![CDATA[TapMap]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @zdanevich-vitaly — Rust (+4) — 30.04.2026 08:28]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1029870/</guid>
    <link>https://habr.com/ru/posts/1029870/?utm_campaign=1029870&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p>Я давний пользователь <a href="https://github.com/vitaly-zdanevich/geeknote" rel="noopener noreferrer nofollow">Geeknote</a> - это cli для <a href="https://evernote.com/" rel="noopener noreferrer nofollow">Evernote</a>. Несколько лет назад проект застрял на втором Питоне - и никто не хотел его портировать на третий. Я ждал что кто-то займётся этим - но пришлось самому - так что я форкнул, починил, и даже связался с Виталием Роденко - одним из создателей Geeknote и администратора на PyPI, чтобы получить право туда пушить. За десяток лет я видел как Geeknote переходил из одни руки в другие - и как он забрасывался, и через несколько лет находился новый мантейнер. Было забавно осознать, что теперь и я стал мантейнером программного продукта, который всегда установлен на все мои машины.</p><p>Как и большинство из нас, я стал пробовать LLM - как замену поиску, для анализа кодов, советов, и вот наконец - несколько проектов - даже не читая кода - только давая команды и тестируя результат. Известная шутка - переписать на Rust. Почему бы у нет - Geeknote не велик - около пяти тысяч строк на Питоне, что я и попробовал - через <strong>Codex gpt-5.5</strong>. Несколько десятков итераций, "добавь это", "добавь то", "пропали теги", "пропала анимация" - и за несколько часов я получил рабочий Geeknote на Rust, назвал его <a href="https://gitlab.com/vitaly-zdanevich/reeknote" rel="noopener noreferrer nofollow">reeknote</a>. </p><p>Результат: быстрее работает, раза в два. Теперь буду им пользоваться.</p><p>P.S.: CLI хороши для перфоманса, SSH, быстрее разработка без GUI, а ещё похоже и для LLM - можно попросить сохранить ответ в Evernote. Как и прочие интеграции, в том числе в скриптах.</p> <a href="https://habr.com/ru/posts/1029870/?utm_campaign=1029870&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Thu, 30 Apr 2026 05:28:25 GMT</pubDate>
    <dc:creator><![CDATA[zdanevich-vitaly]]></dc:creator>
      
      <category><![CDATA[evernote]]></category><category><![CDATA[geeknote]]></category><category><![CDATA[cli]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @dugalb — Интерфейсы (+2) — 28.04.2026 23:25]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1029316/</guid>
    <link>https://habr.com/ru/posts/1029316/?utm_campaign=1029316&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Что&nbsp;такое magicgui и зачем он нам?</strong></p><p><strong><a href="https://github.com/pyapp-kit/magicgui" rel="noopener noreferrer nofollow">magicgui</a> </strong>— это Python‑библиотека для&nbsp;быстрой разработки простых интерфейсов. Если нужен сложный интерфейс с&nbsp;кастомной вёрсткой и нестандартным поведением&nbsp;— лучше взять PyQt‑Pyside. Когда задача обернуть функцию в&nbsp;окошко за 5&nbsp;минут&nbsp;— magicgui справится.</p><p>В&nbsp;настоящее время&nbsp;<strong>magicgui</strong>&nbsp;поддерживает следующие бэкэнды:</p><ul><li><p><a href="https://www.qt.io/" rel="noopener noreferrer nofollow">Qt</a>&nbsp;(через&nbsp;<a href="https://pypi.org/project/PySide2/" rel="noopener noreferrer nofollow">PySide2</a>&nbsp;/&nbsp;<a href="https://pypi.org/project/PySide6/" rel="noopener noreferrer nofollow">PySide6</a>&nbsp;или&nbsp;<a href="https://pypi.org/project/PyQt5/" rel="noopener noreferrer nofollow">PyQt5</a>&nbsp;/&nbsp;<a href="https://pypi.org/project/PyQt6/" rel="noopener noreferrer nofollow">PyQt6</a>&nbsp;)</p></li><li><p><a href="https://ipywidgets.readthedocs.io/en/latest/" rel="noopener noreferrer nofollow">Виджеты Jupyter</a></p></li></ul><p>API организовано на&nbsp;двух уровнях:</p><figure class="bordered full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/81a/715/c93/81a715c93a49425ee6f7e71fef4a6675.png" alt="слои API magicgui" title="слои API magicgui" width="834" height="1158"><div><figcaption>слои API magicgui</figcaption></div></figure><p>Верхний уровень&nbsp;— магия типов. Декораторы <a class="mention" href="/users/magicgui">@magicgui</a>, <a class="mention" href="/users/guiclass">@guiclass</a>, автоопределение виджетов по&nbsp;аннотациям.</p><p>Нижний уровень&nbsp;— ручная сборка из&nbsp;готовых <a href="https://pyapp-kit.github.io/magicgui/widgets/" rel="noopener noreferrer nofollow">виджетов </a>(SpinBox, Slider, PushButton).</p><p><strong>Примеры работы: </strong><a href="https://pyapp-kit.github.io/magicgui/generated_examples/" rel="noopener noreferrer nofollow">https://pyapp‑kit.github.io/magicgui/generated_examples/</a></p><p><strong>Github: </strong><a href="https://github.com/pyapp-kit/magicgui" rel="noopener noreferrer nofollow">https://github.com/pyapp‑kit/magicgui</a></p> <a href="https://habr.com/ru/posts/1029316/?utm_campaign=1029316&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Tue, 28 Apr 2026 20:25:42 GMT</pubDate>
    <dc:creator><![CDATA[dugalb]]></dc:creator>
      
      <category><![CDATA[gui]]></category><category><![CDATA[ui]]></category><category><![CDATA[qt]]></category><category><![CDATA[интерфейсы]]></category><category><![CDATA[python]]></category><category><![CDATA[pyqt]]></category><category><![CDATA[pyside]]></category><category><![CDATA[jupyter]]></category><category><![CDATA[jupyter notebook]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @tripolskypetr — Искусственный интеллект (+4) — 28.04.2026 19:27]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1029260/</guid>
    <link>https://habr.com/ru/posts/1029260/?utm_campaign=1029260&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Почему цена почти доходит до TP, но разворачивается</strong></p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/82e/760/046/82e76004632d75e862d32dea7c6d7422.png" width="1168" height="784"></figure><p><strong>Будущее это вероятностная функция от прошлого</strong>. ATR это чистая функция от прошлого. Разница в том, что в вероятностной функции есть коэфициент случайности и точно прогнозировать можно только лучший и худший случай</p><p>Именно по этому цена не доходит до TP, если высчитать его на индикаторах. Либо TP слишком низкий и не окупает fees. <strong>Верным решением для вероятностной функции будет прогнозировать лучший и худший случай на лету</strong></p><pre><code class="typescript">//@version=5
strategy("Стратегия с TP по ATR")

...

tpPrice    = entryPrice + atrMultTP * atr // Это не работает</code></pre><p>Выходить из позиции при просадке PNL на заранее известный процент статистически предсказуемо.</p><pre><code class="typescript">listenActivePing(async ({ symbol, data }) =&gt; {
  const peakProfitDistance = await getPositionHighestProfitDistancePnlPercentage(symbol);
  const currentProfit = await getPositionPnlPercent(symbol);

  if (currentProfit &lt; 0) {
    return;
  }

  if (peakProfitDistance &lt; TRAILING_TAKE) {
    return;
  }

  await commitClosePending(symbol, {
    id: "unknown",
    note: str.newline(
      "# Позиция закрыта по trailing take",
    ),
  });
});</code></pre><p>Тут есть разница: в отличие от классического trailing take где выход из позиции ставится на цену, которая каждый раз разная, отклонение PnL - постоянная величина</p> <a href="https://habr.com/ru/posts/1029260/?utm_campaign=1029260&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Tue, 28 Apr 2026 16:27:07 GMT</pubDate>
    <dc:creator><![CDATA[tripolskypetr]]></dc:creator>
      
      <category><![CDATA[трейдинг]]></category><category><![CDATA[криптовалюты]]></category><category><![CDATA[мосбиржа]]></category><category><![CDATA[tradingview]]></category><category><![CDATA[pinescript]]></category><category><![CDATA[typescript]]></category><category><![CDATA[python]]></category><category><![CDATA[торговля]]></category><category><![CDATA[биржа]]></category><category><![CDATA[binance]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @VAGNAT — Проектирование и рефакторинг (+4) — 28.04.2026 10:43]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1028926/</guid>
    <link>https://habr.com/ru/posts/1028926/?utm_campaign=1028926&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Паттерны проектирования еще актуальны?</strong></p><p>Вокруг все чаще говорят, что ИИ скоро будет писать код за нас. Логичный вопрос — нужны ли тогда паттерны? Зачем разбираться в паттернах GoF, если нейросеть и так сгенерирует рабочий код по описанию?</p><p>У меня ощущение обратное.</p><p>Я плотно вошел в разработку в 2019 году. Переходил из 1С в .NET. Книги по паттернам GoF у меня были, но долго лежали как «книга на полке». Казалось, они оторваны от повседневных задач. Теорию вроде понимал, но не видел, где это реально применяется.</p><p>Все поменялось, когда я стал использовать ИИ как инструмент для обучения. Просил давать задачи, искать проблемы в решениях, объяснять, почему в одном месте уместен Strategy, а в другом лучше Mediator. Через практику и обсуждение паттерны перестали быть абстракцией.</p><p>Чем проще генерировать код, тем важнее понимать его форму и границы. Иначе не ускоришь разработку, а ускоришь накопление технического долга.</p><p>Из этого и вырос мой pet-project <a href="http://gofinsights.com" rel="noopener noreferrer nofollow">gofinsights.com</a>. Я делаю его тренажером по паттернам проектирования. Не просто «прочитал и забыл», а через практику, сравнение решений и постепенное распознавание типовых архитектурных ходов.</p><p>Сейчас там есть интерактивный квиз, где можно проверить базу и не перепутать Factory Method с Abstract Factory. Дальше хочу развивать проект в сторону более глубокого ИИ-разбора. Чтобы можно было не только узнавать паттерн, но и разбирать кодовые запахи, причины проблем и возможную эволюцию решений.</p><p>Как вы это видите? Паттерны проектирования все еще рабочая база для разработчика? Или с появлением ИИ они станут менее важны?</p> <a href="https://habr.com/ru/posts/1028926/?utm_campaign=1028926&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Tue, 28 Apr 2026 07:43:49 GMT</pubDate>
    <dc:creator><![CDATA[VAGNAT]]></dc:creator>
      
      <category><![CDATA[паттерны проектирования]]></category><category><![CDATA[паттерны программирования]]></category><category><![CDATA[шаблоны]]></category><category><![CDATA[тренажёр]]></category><category><![CDATA[java]]></category><category><![CDATA[python]]></category><category><![CDATA[csharp]]></category><category><![CDATA[php]]></category><category><![CDATA[go]]></category><category><![CDATA[шаблоны проектирования]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @dugalb — Python (+2) — 28.04.2026 05:54]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1028848/</guid>
    <link>https://habr.com/ru/posts/1028848/?utm_campaign=1028848&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/c26/a3c/8ef/c26a3c8ef1efc23c9278c851cd3e5574.png" width="860" height="578"></figure><p><strong>Разрываем шаблоны: строим график с&nbsp;разрывом всего на 65&nbsp;строк</strong> </p><p>Иногда нужно скрыть часть графика используя&nbsp;линию обрыва, чтобы показать данные с&nbsp;сильно различающимися значениями. Например, когда один язык программирования популярнее остальных в&nbsp;разы.</p><p>Самые ходовые решения этой проблемы&nbsp;— разорванная ось (broken axis) или&nbsp;отдельные бины для&nbsp;аномалий. Проблема в&nbsp;том, что&nbsp;в&nbsp;Matplotlib нет готовой «кнопки» для&nbsp;создания гистограммы с&nbsp;разрывом. Но&nbsp;это легко* собирается руками на&nbsp;уровне нескольких осей.</p><p>Вот три рабочих подхода&nbsp;— выбирайте под&nbsp;свою задачу.</p><ol><li><p>Официальный пример из&nbsp;документации Matplotlib. 🔗 <a href="https://matplotlib.org/stable/gallery/subplots_axes_and_figures/broken_axis.html" rel="noopener noreferrer nofollow">Ссылка на&nbsp;гайд</a>. Отлично работает, когда выбросы зашкаливают по&nbsp;одной оси (X или&nbsp;Y). В&nbsp;посте разбирается как&nbsp;раз такой случай: гистограмма с&nbsp;волнистой&nbsp;линией обрыва.</p></li><li><p>Библиотека <strong>brokenaxes </strong>делает почти всё сама. Устанавливается стандартно через pip. Вариант для&nbsp;тех, кто не&nbsp;хочет углубляться в&nbsp;ручную настройку.</p></li><li><p>Логарифмическая шкала (часто&nbsp;— самый простой выход) Если выбросы строго положительные и отличаются на&nbsp;порядки, иногда достаточно двух строк: plt.xscale(«log») или&nbsp;plt.yscale(«log»). Никаких разрывов, никакой ручной работы&nbsp;— при&nbsp;этом график остаётся чистым и читаемым.</p></li></ol><pre><code class="python">import matplotlib.patches as mpatches
import matplotlib.pyplot as plt
import numpy as np
from matplotlib.path import Path


def plot_broken_axis(
    labels: list[str],
    values: tuple[float, ...],
    ylim_low=(0, 12),
    ylim_high=(20, 25),
    **kwargs,
):
    """
    Строит график с разрывом оси.
    Валидирует входные данные и инкапсулирует логику отрисовки.
    """
    if len(labels) != len(values):
        raise ValueError("Длины labels и values не совпадают")

    fig, (ax_high, ax_low) = plt.subplots(
        nrows=2, figsize=(7, 4), gridspec_kw={"height_ratios": [1, 2]}
    )

    # Настройки столбцов
    kwargs.setdefault("color", "skyblue")
    kwargs.setdefault("edgecolor", "black")
    kwargs.setdefault("alpha", 0.85)

    ax_low.bar(labels, values, **kwargs)
    ax_high.bar(labels, values, **kwargs)
    fig.subplots_adjust(hspace=0.0)

    # Настройка осей
    ax_low.set_ylim(*ylim_low)
    ax_high.set_ylim(*ylim_high)
    ax_high.set_title("График с разрывом")
    ax_low.set_ylabel("Рейтинг в %")
    ax_low.set_xlabel("Языки")
    ax_high.spines["bottom"].set_visible(False)
    ax_low.spines["top"].set_visible(False)
    ax_high.tick_params(axis="x", bottom=False, labelbottom=False)
    # Рисуем разрыв оси (волна)
    offset, n_points = 0.03, 33
    pts = np.linspace(-offset, 1 + offset, n_points)
    wave = np.array([1 + (0, offset, 0, -offset)[i % 4] for i in range(n_points)])
    path = Path(list(zip(pts, wave)), [Path.MOVETO] + [Path.CURVE3] * (n_points - 1))

    opts = dict(transform=ax_low.transAxes, clip_on=False, zorder=10)
    ax_low.add_patch(mpatches.PathPatch(path, lw=6, **opts))
    ax_low.add_patch(mpatches.PathPatch(path, lw=3, edgecolor="white", **opts))
    return fig


if __name__ == "__main__":
    langs = ["Python", "C", "C++", "Asm"]
    pops = (21.8, 11.1, 8.6, 1.1)

    # Стиль xkcd
    with plt.xkcd(scale=1, length=300, randomness=30):
        plt.rcParams["font.family"] = "Comic Sans MS"

        # Вызов функции
        fig = plot_broken_axis(langs, pops)
        plt.show()</code></pre><p>Литература:</p><ul><li><p>Документация Matplotlib. 🔗 <a href="https://matplotlib.org/stable/gallery/subplots_axes_and_figures/broken_axis.html" rel="noopener noreferrer nofollow">Ссылка на&nbsp;гайд</a></p></li><li><p>Bernd Klein. Numerisches Python Arbeiten mit NumPy, Matplotlib und Pandas</p></li><li><p>Sandro Tosi. Matplotlib for Python Developers</p></li></ul> <a href="https://habr.com/ru/posts/1028848/?utm_campaign=1028848&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Tue, 28 Apr 2026 02:54:03 GMT</pubDate>
    <dc:creator><![CDATA[dugalb]]></dc:creator>
      
      <category><![CDATA[python]]></category><category><![CDATA[matplotlib]]></category><category><![CDATA[refactoring]]></category><category><![CDATA[data-visualisation]]></category><category><![CDATA[bestpractices]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @dugalb — Искусственный интеллект (+1) — 26.04.2026 18:41]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1028172/</guid>
    <link>https://habr.com/ru/posts/1028172/?utm_campaign=1028172&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Как&nbsp;читать статьи с&nbsp;arXiv на&nbsp;русском без&nbsp;лишних усилий </strong></p><p>Если вы работаете с&nbsp;машинным обучением или&nbsp;исследовательскими задачами, arXiv, скорее всего,&nbsp;— ваш основной источник свежих идей. </p><p>Но&nbsp;далеко не&nbsp;всегда удобно читать оригинал на&nbsp;английском: устали, хотите&nbsp;быстро пробежаться по&nbsp;статье или&nbsp;просто не&nbsp;готовы сейчас разбираться в&nbsp;длинном PDF. </p><p>В&nbsp;этом посте&nbsp;— два практичных способа читать статьи с&nbsp;arXiv в&nbsp;HTML‑формате прямо в&nbsp;браузере и сразу переводить их на&nbsp;русский с&nbsp;помощью встроенного перевода. Никаких LLM, сторонних ботов и скачивания PDF.</p><p><strong>Зачем вообще HTML, если есть PDF</strong></p><p>Классический сценарий работы с&nbsp;arXiv выглядит так: вы открываете страницу статьи, скачиваете PDF и читаете его в&nbsp;отдельной программе или&nbsp;через встроенный viewer браузера.</p><p>У&nbsp;такого подхода есть несколько минусов:</p><ul><li><p>Неудобно переводить: нужно копировать текст или&nbsp;использовать отдельные инструменты.</p></li><li><p>Плохо искать по&nbsp;странице: текст может&nbsp;быть нераспознанным или&nbsp;разбитым.</p></li><li><p>Тяжелее читать на&nbsp;маленьких экранах, особенно на&nbsp;ноутбуках и планшетах.</p></li></ul><p>HTML‑версия решает эти проблемы: текст становится «живым», браузер может его переводить, а&nbsp;навигация и поиск по&nbsp;странице работают привычным образом.</p><p><strong>Способ 1. Официальный HTML (experimental)</strong></p><p>У&nbsp;части статей на&nbsp;arXiv есть встроенная HTML‑версия.Если она включена, справа на&nbsp;странице вы увидите кнопку «<strong>HTML (experimental)</strong>».</p><figure class="full-width "><img src="https://habrastorage.org/getpro/habr/upload_files/027/30e/782/02730e782058741609d9ee14befc3070.png" width="1253" height="516"></figure><p>Что&nbsp;это даёт:</p><ul><li><p>статья открывается как&nbsp;полноценная HTML‑страница;</p></li><li><p>формулы остаются корректными;</p></li><li><p>можно использовать встроенный перевод в&nbsp;браузере.</p></li></ul><p>Ограничения:</p><ul><li><p>HTML‑версии есть не&nbsp;у&nbsp;всех препринтов.</p></li><li><p>Иногда верстка «плывёт», особенно в&nbsp;сложных таблицах.</p></li></ul><p><strong>Способ 2. ar5iv (если HTML нет)</strong></p><p>Если кнопки&nbsp;<strong>HTML (experimental)</strong>&nbsp;нет, можно воспользоваться сторонним сервисом&nbsp;<strong>ar5iv</strong>&nbsp;из&nbsp;экосистемы arXiv Labs. Он автоматически конвертирует TeX‑исходники статей в&nbsp;HTML.</p><p>Идея простая: вы берете обычный URL arXiv и меняете в&nbsp;домене букву&nbsp;<code>x</code>&nbsp;на&nbsp;<code>5</code>.</p><p>Пример:</p><ul><li><p>Было: <a href="https://arxiv.org/abs/1706.03762" rel="noopener noreferrer nofollow">https://arxiv.org/abs/1706.03762</a></p></li><li><p>Стало: <a href="https://ar5iv.labs.arxiv.org/html/1706.03762" rel="noopener noreferrer nofollow">https://ar5iv.labs.arxiv.org/html/1706.03762</a></p></li></ul><p>Такой простой приём заметно снижает «порог входа» в чтение статей и экономит время, особенно если вы регулярно мониторите arXiv.</p> <a href="https://habr.com/ru/posts/1028172/?utm_campaign=1028172&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Sun, 26 Apr 2026 15:41:51 GMT</pubDate>
    <dc:creator><![CDATA[dugalb]]></dc:creator>
      
      <category><![CDATA[arxiv.org]]></category><category><![CDATA[arxiv]]></category><category><![CDATA[научные исследования]]></category><category><![CDATA[научные статьи]]></category><category><![CDATA[научные публикации]]></category><category><![CDATA[машинное+обучение]]></category><category><![CDATA[deep research]]></category><category><![CDATA[статьи]]></category><category><![CDATA[python]]></category>
  </item>
  

	
  

  

  

    

  

  
  <item>
    <title><![CDATA[Пост @dugalb — Python (+1) — 26.04.2026 15:58]]></title>
    <guid isPermaLink="true">https://habr.com/ru/posts/1028110/</guid>
    <link>https://habr.com/ru/posts/1028110/?utm_campaign=1028110&amp;utm_source=habrahabr&amp;utm_medium=rss</link>
    <description><![CDATA[<p><strong>Python на флешке: как собрать портативную среду без установки</strong></p><p>Такой вариант хорошо подходит, если нужно:</p><ul><li><p>показать скрипт на чужом компьютере;</p></li><li><p>поработать на машине без прав администратора;</p></li><li><p>запускать Python в ограниченной среде;</p></li><li><p>держать рядом интерпретатор, проект и зависимости в одном месте.</p></li></ul><p>На корпоративных ПК всё зависит от политики безопасности. Если запуск с USB,&nbsp;<code>.exe</code>&nbsp;или PowerShell ограничен, портативная сборка тоже может не стартовать.</p><p><strong>Что нужно</strong></p><p>Минимальный набор простой:</p><ul><li><p>USB-накопитель;</p></li><li><p>Windows x64;</p></li><li><p>доступ в интернет, если планируете ставить дополнительные пакеты.</p></li></ul><p><strong>Скачиваем Python</strong></p><p>Идём на официальную страницу загрузок Python и берём&nbsp;<strong>Windows embeddable package (64-bit)</strong>&nbsp;для нужной версии, например, <a href="https://www.python.org/ftp/python/3.14.4/python-3.14.4-embed-amd64.zip" rel="noopener noreferrer nofollow">python-3.14.4-embed-amd64.zip</a>.<br>После распаковки вы получите что-то вроде этого:</p><pre><code class="css">F:\
└── python3.14\
    ├── python.exe
    ├── python314.dll
    ├── python314._pth
    ├── python314.zip
    └── ...</code></pre><p>На этом этапе интерпретатор уже можно запускать прямо с флешки.</p><p><strong>Что делает&nbsp;_pth</strong></p><p>Файл&nbsp;<code>python314._pth</code>&nbsp;управляет тем, какие пути Python видит при запуске. По умолчанию embeddable package изолирован от системного окружения, реестра и установленных пакетов.</p><p>Если вам нужно подключить локальные библиотеки, можно прописать пути вручную:</p><pre><code>python314.zip
.
Lib
Lib\site-packages
import site</code></pre><p>Строка&nbsp;<code>import site</code>&nbsp;нужна, чтобы Python начал использовать&nbsp;<code>site</code>-механику и подхватывать дополнительные каталоги.</p><p><strong>Как добавить pip</strong></p><p>У embeddable package&nbsp;<code>pip</code>&nbsp;обычно не идёт «из коробки» как в обычной установке.<br>Его можно добавить вручную через официальный bootstrap-скрипт&nbsp;<code>get-pip.py</code>.</p><p>Сценарий такой:</p><ol><li><p>Скачайте&nbsp;<a href="https://bootstrap.pypa.io/get-pip.py" rel="noopener noreferrer nofollow">get-pip.py</a>.</p></li><li><p>Положите его рядом с&nbsp;<code>python.exe</code>.</p></li><li><p>Запустите:</p></li></ol><pre><code class="bash">PS F:\&gt; cd ./python3.14
PS F:\python3.14&gt; ./python get-pip.py</code></pre><p>После этого проверьте:</p><pre><code class="bash">./python -m pip --version
# Выведет версию pip (например, pip 26.0.1).</code></pre><p><strong>Ставим пакеты</strong></p><p>Когда&nbsp;<code>pip</code>&nbsp;уже доступен, можно ставить нужные библиотеки:</p><pre><code class="bash">PS F:\python3.14&gt; ./python -m pip install numpy pandas matplotlib seaborn requests</code></pre><p>Или сразу из&nbsp;<code>requirements.txt</code>:</p><pre><code class="bash">PS F:\python3.14&gt; ./python -m pip install -r requirements.txt</code></pre><p><strong>Запускаем проект</strong></p><p>Чтобы не помнить длинные пути, удобно сделать&nbsp;<code>run.bat</code>&nbsp;в корне флешки:</p><pre><code class="bash">@echo off
cd /d %~dp0
set PYTHON_HOME=%~dp0python3.14
set PATH=%PYTHON_HOME%;%PATH%

%PYTHON_HOME%\python.exe my_project\main.py
pause</code></pre><p>Плюс такого подхода в том, что он не привязан к букве диска. Сегодня флешка может быть&nbsp;<code>F:</code>, а завтра&nbsp;<code>D:</code>&nbsp;— батник всё равно найдёт себя сам.  </p><p><strong>Типичная структура</strong></p><p>Обычно папка на флешке выглядит так:</p><pre><code class="css">F:\
├── python3.14\
│   ├── python.exe
│   ├── python314.dll
│   ├── python314._pth
│   ├── python314.zip
│   └── Lib\site-packages\
├── my_project\
│   ├── main.py
│   └── requirements.txt
├── run.bat</code></pre> <a href="https://habr.com/ru/posts/1028110/?utm_campaign=1028110&amp;utm_source=habrahabr&amp;utm_medium=rss">Читать дальше &rarr;</a>]]></description>
      
    <pubDate>Sun, 26 Apr 2026 12:58:38 GMT</pubDate>
    <dc:creator><![CDATA[dugalb]]></dc:creator>
      
      <category><![CDATA[python]]></category><category><![CDATA[флешка]]></category><category><![CDATA[портативность]]></category>
  </item>
  

	
  

  

  

      

      

      

    
  </channel>
</rss>
