20070
Полный Дзен Пайтона в одном канале Разместить рекламу: @tproger_sales_bot Правила общения: https://tprg.ru/rules Другие каналы: @tproger_channels Сайт: https://tprg.ru/site Регистрация в перечне РКН: https://tprg.ru/xZOL
Как в одно слово назвать Django-разработчика?
🏆— Джангист
🦄 — Джангер
👀 — Джангэстро
🌚 — Свое (поделитесь в комментариях)
tkforge: из Figma в Tkinter
Интересная коллекция компонентов, позволяющая сверстать на канвасе небезызвестной Figma интерфейс, а потом командной строкой перегнать это сразу в Python-код для Tkinter.
#библиотека
@zen_of_python
Фейковые техинтервью и трояны
Если верить статье с xakep.ru, группа корейских IT-компаний приглашает на собеседование на должность фулстэк-разработчика, и под эгидой демонстрации навыков просят клонировать и использовать репозиторий Dev Popper — якобы NPM-расширение.
На деле же при запуске активируется обфусцированный js-скрипт, который в итоге запускает py-скрипт (!) — троян, собирающий:
— данные для входа на ваши сервера;
— историю CLI-команд (ищет креды, опять же);
— возможности для дистанционного развёртывания вредоносного ПО.
Коллеги, с корейскими компаниями пока на собеседования не ходим.
#факты
@zen_of_python
OpenTelemetry: здоровье вашего py-приложения
Доступный англоязычный гайд по настройке телеметрии вашего проекта. Инструмент позволяет:
— собирать логи;
— отслеживать исполнение запросов;
— прослеживать путь конкретного тестового запроса (чтобы найти «бутылочные горлышки»);
— отправлять уведомления о событиях в мессенджер;
— распределенно отслеживать в условиях нескольких микросервисов и проч.
#лучшиепрактики
@zen_of_python
Как сжимают zlib + 3 конкурента
Реддитор провёл бенчмарк четырёх архивирующих библиотек — zlib, lz4, brotli, zstandard на коэффициент сжатия, скорость компрессии / декомпрессии.
Вот результат по первому показателю:| Библиотека | Сжатие, разы ||------------|--------------|| zlib | 27.84 || lz4 | 18.23 || brotli | 64.78 || zstandard | 43.42 |
Остальные «пьедесталы» плюс данные о дизайне экспериментов в треде. Сжимали .json.
#факты
@zen_of_python
Бесплатная книга о Py-регулярках
Разработчики Christian Mayer, Zohaib Riaz и Lukas Rieger написали книгу, упрощающую изучение регулярных выражений в рамках Python.
Если кому удобнее учиться по видео, вот видеокурс, аналогичный книге.
#книга
@zen_of_python
Вопросы от новичков
Zen of Python поддерживает новоприбывших в особой рубрике. Как это работает:
— Спрашивайте что угодно (в комментариях под этим постом), связанное с Python. Здесь нет плохих вопросов!
— Сообщество вас поддержит. Самые интересные вопросы мы разберём в отдельном посте;
#вопросыновичков
@zen_of_python
Создание HR-платформы без legacy и смс
Ведется активный поиск системных аналитиков с опытом от 3-х лет для работы над технологической платформой нового поколения.
Что нужно делать:
— Собирать требования вместе с владельцем продукта
— Анализировать функциональность ПО
— Проектировать интеграции с источниками данных
— Поддерживать документации.
Что предложат взамен:
— Лучшие практики компонентно-реактивного подхода
— Нет legacy и полная свобода в выборе инструментов
— Ежегодный пересмотр зарплат.
Посмотреть подробности и откликнуться
Результаты опроса Django-разработчиков
JetBrains ещё в конце 2023 года провёл опрос (на английском) с целью узнать предпочтения джангистов. Результат довольно предсказуемый, однако все равно бесценный для тех, кто выбирает дополнительные компоненты.
Хороший способ для новичка познакомиться с общепринятыми дополняющими инструментами, сопровождающими Django-проект, будь то гео-бэкенд, кэш-хранилище или БД.
#факты
@zen_of_python
Поздравляем победителей
Задачу об идеальном квадрате верно решили:
— @QuantumaStelata;
— @nxiqns;
— @WhonixMan;
— @GeorKu;
— @patriarch_chesslovo;
— @maslyaev.
Кратчайшие верные решения предложили @QuantumaStelata:x = lambda s: (s**(1/2)).is_integer()
@nxiqns:def check_square_perfection(num): return (num**0.5).is_integer()
и @WhonixMan:def check_square_perfection(num): return int(num**0.5) == num**0.5
Отдельно выделим решение @maslyaev, учитывающее случай очень больших чисел:def check_square_perfection(area: int | float) -> bool: if area == 0 or area == 1: # На 0 и 1 ломается вавилонский метод return True if area < 4: # Отрицательная area даст False return False if area % 1 != 0: # Нецелая area даст False return False int_area = int(area) sqrt = int_area // 2 while True: next_sqrt = (sqrt + int_area//sqrt)//2 if next_sqrt == sqrt: break sqrt = next_sqrt return sqrt * sqrt == int_area
#задача
@zen_of_python
Как пользоваться raise
Исчерпывающая серия видеоуроков с небезызвесного realpython.com. Поднимут следующие темы:
— встроенные и кастомные исключения;
— группировка и проч.
#факты
@zen_of_python
Как спасти время тем, кто использует ваш код
Если вы выкладываете свой код в опенсорс, или заботитесь о коллегах по проекту, облегчить его сборку можно с помощью фиксации версий зависимостей. В современном питоничеcком пространстве библиотеки обновляются довольно быстро, что делает их сочетание нерабочим уже через 6-12 месяцев.
Простой совет для новичков: чтобы сохранить версии в установочном файле, набираем в командной строке:pip freeze >> requirements.txt
Вопросы от новичков
Zen of Python поддерживает новоприбывших в особой рубрике. Как это работает:
— Спрашивайте что угодно (в комментариях под этим постом), связанное с Python. Здесь нет плохих вопросов!
— Сообщество вас поддержит. Самые интересные вопросы мы разберём в отдельном посте;
#вопросыновичков
@zen_of_python
Поиск контактных данных с помощью Yandex GPT 3 API
Совершенствуем модерацию — поиск контактов в файлах .pdf . / .docx с помощью новой версии нейронки Яндекса, причём полностью на демо-деньги.
#нейросети
@zen_of_python
Сложность структур данных и алгоритмов
Если вы подступились к объёмным данным в проекте, самое время задуматься: а те ли методы и функции вы используете? Какова будет скорость интерпретации и не «повесится» ли программа вообще?
На pythonmorsels.com опубликовали англоязычную статью на 9 минут про виды сложностей (они на графике ниже), и про сравнение встроенных методов списков, очередей (queue), словарей, сетов, класса-счётчика (Counter), кучи и других структур. Самое оно, чтобы аккуратно вьехать в стадию оптимизации своего кода.
Если вам нужно сначала разобраться с понятием Time Complexity, вот доступная статья от основателя Типичного программиста.
#лучшиепрактики
@zen_of_python
Инженер-программист, помни!
Если ты всей душой в майских праздниках, то эксперименты с «пивным» пиком Балмера никто не отменял.
«Каким-то образом Балмер посчитал, что 1,29–1,38‰ алкоголя в крови открывают у него сверхчеловеческие способности к программированию: он выпивал пару литров пива, входил в состояние лёгкого опьянения и мог продуктивно кодить».
Ну если сверхкода в таком состоянии все же не написать, то за «жабистые» таски точно легче браться.
#кек
@zen_of_python
Поздравляем победителей
Задачу об инверсии строки верно решили:
— Cool and Fun Python (@Python3k);
— Лев Выскубов;
— @sidor0912;
— @lomserman;
— @HackingSection;
— @VasilTerekin (засчитываю, хотя запрошена функция);
— @patriarch_chesslovo;
— @IvanImmortal;
— @Sentiago.
Кратчайшие верные решения предложили @patriarch_chesslovo:VOWELS_LOWERCASE = set('aeoiuаоыуэяёиюе')def invert_vowels(strng): reversed_vowels = (i for i in strng[::-1] if i.lower() in VOWELS_LOWERCASE) return ''.join([i if i.lower() not in VOWELS_LOWERCASE else next(reversed_vowels) for i in strng])
и @HackingSection:def invert_vowels(s, vowels = "аяоёиыуюеэ"): vowelsInText = [j for j in s if j in vowels] return [vowelsInText.pop(-1) if i in vowels else i for i in s]
Отдельный респект Cool and Fun Python за разбор своего решения:Предполагается, что все буквы в тексте строчные и русские. Иначе требуется доработать строку гласных.У решения линейная асимптотика. Но если очень хочется, можно повысить быстродействие, превратив vowels в множество строк односимвольников: vowels = {'а', 'я', ...}И преобразование строки в список и обратно - вынужденная мера. Строка в Python неизменяемая. Впрочем, на сохранение асимптотики O(N) это не влияет.Кстати, если бы постановщик задачи гарантировал наличие гласных (всё же предлоги "в", "с" тоже считаются словами), можно было бы убрать проверки left < right в двух внутренних циклах.
Отдельная благодарность @lomserman за создание тестирующей функции:def test(original: str, expected: str): result = invert_vowels(original) print(result) assert result == expected
p.s. Админ подписывается на всех ребятушек, что решают задачи. Если «провалиться» в профили решивших, там полно питонической годноты.
#задача
@zen_of_python
Задача о подстроке
Получаем две строки s и t . Напишите функцию проверки: является ли s подстрокой t.
Подстрока формируется из исходной строки путём удаления некоторых символов (может быть, ни одного) без нарушения положения остальных. "ace" является подстрокой "abcde", а "aec" — нет.
Ограничения:
0 <= len(s) <= 100
0 <= len(t) <= 10^4
s и t состоят только из строчных английских букв.
s = "abc"
t = "ahbgdc"
>>> is_substring(s, t)
... true
🌚 — все равно перепишу, ад зависимостей — потомкам
🕊️— готов к такому
🗿— bash'ем не занимаюсь
JSON Crack, устраняющий разрыв между данными и визуализацией
Это расширение VSCode позволяет разработчикам, аналитикам данных и энтузиастам легко преобразовывать сложные наборы данных JSON в информативные и визуально привлекательные графики.
Цена: бесплатно
@prog_tools
Безсерверный Python: Cloudflare Workers
Workers на Cloudflare — это платформа, позволяющая исполнять бессерверные функции, то есть отчасти замена привычной архитектуре проекта на сервере.
Теперь вы можете импортировать подмножество популярных пакетов Python, включая FastAPI, Langchain, Numpy и другие. Никаких дополнительных шагов сборки или внешних цепочек инструментов не требуется.
Об обновлении Cloudflare
#факты
@zen_of_python
Знакомство с aiogram
Если вы хотите вкатиться в Python-разработку, боты — неплохой способ сделать это. Разработчик @mastergroosha сверстал целую серию русскоязычных статей об одном из самых ходовых в 2024 году «ботических» фреймворках. Там можно познакомиться с хэндлерами, диспетчерами, асинхронностью и проч. — всем тем, что новичка обычно смущает при заскакивании на этот поезд.
#лучшиепрактики
@zen_of_python
UTF-8 станет дефолтным стандартом, начиная с Python 3.15
В PEP 686 описывается переход на UTF-8 — распространённый стандарт кодирования символов. Это затронет:
— все py-файлы;
— файлы конфигураций;
— большинство IDE, включая Visual Studio Code и Блокнот Windows (при создании файла.py);
— большинство веб-сайтов на Python.
#факты
@zen_of_python
Llama 3 теперь доступна в РФ
Meta AI наконец вспомнили, что такое настоящий опенсорс, свободный от политики, и открыли доступ к своей LLM для граждан РФ без VPN.
Попробовать Llama 3
@neuro_channel
#llm
Задача об инверсии гласных
Вам даётся строка s. Напишите функцию, которая инвертирует порядок гласных:>>> s = 'погода'>>> invert_vowels(s)... пагодо
#задача
@zen_of_python
streamlit для дата-приложений
Репозиторий сейчас находится в топе трендов GitHub и позволяет создавать интерактивные дашборды, отчёты или даже мессенджеры. Позволяет лихо подключиться к популярным хранилищам, от Google Firebase и PostgreSQL до Google Sheets и Tableau.
Для для развития фантазии создатели даже сделали галерею приложений.
@zen_of_python
Работодатель вынужден увеличить питонисту зарплату, хотя не дает полный доступ к данным, чтобы оценить экономический эффект от его присутствия.
🤩 — Мне подняли з/п за прошлый год, причем даже не просил
🌚 — Мне подняли, когда пригрозил(-а) уйти
🍌 — Какой подъем? Даже индексации нет.
🌭 — Работаю за еду
Краски, холст, Германия, XVI век
@zen_of_python
Освой бэкенд-разработку на летней стажировке «Технолето» от Яндекса
Студенты смогут не только погрузиться в профессию, но и поближе познакомиться с вдохновляющей культурой Яндекса. Стажеров ждут образовательные мастер-классы, спортивные выезды, карьерные ивенты, зажигательные тусовки с диджеями и опен-эйр.
Во время стажировки студенты, желающие освоить бэкенд, узнают о тонкостях написания кода для высоконагруженных веб-сервисов, освоят навыки эксплуатации сложных систем, а также систематизируют знания и приобретут востребованные в индустрии скиллы. Помимо бэкенда, здесь можно освоить фронтенд, машинное обучение, аналитику, мобильную разработку и многое другое.
Стажировка оплачивается, а график обучения можно выстраивать под себя. Расходы на дорогу и проживание иногородним студентам компания оплачивает сама.
Больше половины стажеров Яндекса затем переходят в штат компании, поэтому это отличная возможность начать карьеру в BigTech.
Оставляй заявку на участие в программе «Технолето» и проходи тестовое задание.
Это #партнёрский пост
25 баз данных, которые актуальны в 2024 году
Современный мир производит огромное количество данных каждую секунду, создавая огромный объем информации, который требуется хранить, управлять и анализировать. В этой статье мы кратко рассмотрим 25 из самых популярных баз данных, которые играют важную роль в обработке и хранении данных в различных сферах, от корпоративного управления до интернет-технологий. Каждая из этих баз данных обладает своими особенностями и применением, внося вклад в разнообразные сферы бизнеса и науки.
От классических фаворитов до малоизвестных новичков, приготовьтесь к дикой поездке по стране баз данных!
Читать: https://habr.com/ru/articles/785366/