Pythoner
7.21K subscribers
861 photos
27 videos
4 files
655 links
Полезные материалы по Python, которые будут интересны опытному и начинающему разработчику.

Сотрудничество - @flattys
Цены - @serpent_media

Канал на бирже: https://telega.in/c/pythonercode
Download Telegram
🐍Метод zfill() используется для дополнения строкового значения слева нулями до указанной длины.

💡Если исходная строка уже имеет равную или большую длину, то метод ничего не делает и возвращает исходную строку.

➡️Таким образом, метод zfill() полезен, когда вам нужно привести число к определенному формату с ведущими нулями.
Please open Telegram to view this post
VIEW IN TELEGRAM
7👍6🔥1
🐍Команда «python -m timeit» в консоли используется для тестирования производительности фрагмента кода на Python путем многократного его выполнения и измерения времени выполнения.

➡️Она запускает модуль timeit, который является частью стандартной библиотеки Python.

➡️Это позволяет оценить производительность определенного участка кода.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍83🔥1
🐍Метод strip() по умолчанию удаляет все пробельные символы с начала и конца строки.

➡️Если в метод strip() передать набор символов в качестве аргумента, он удалит все вхождения этих символов с обоих концов строки.

➡️Он возвращает новую строку, в которой все эти символы удалены.

💡Если нужно удалить символы только с одного конца строки, то можно использовать методы lstrip() (для удаления слева) и rstrip() (для удаления справа).
Please open Telegram to view this post
VIEW IN TELEGRAM
8👍3🔥3
🐍Метод encode() в Python преобразует строки в байтовые объекты, используя определенную кодировку (по умолчанию UTF-8).

➡️Если в строке есть символы, недопустимые в выбранной кодировке, возникает исключение UnicodeEncodeError.
При пустой строке метод вернет пустую последовательность байтов.

➡️Метод encode() создает новый объект байтов, представляющий исходную строку в выбранной кодировке, не изменяя исходную строку.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍53🔥1
🐍Для динамического импорта модулей в Python можно использовать функцию import_module() из стандартной библиотеки importlib.

⬆️В данном примере код динамически импортирует модуль random и использует функцию sample() из этого модуля для выбора нескольких случайных элементов из списка.

➡️Обычно динамический импорт модулей применяется, когда имена модулей неизвестны на этапе написания кода, а определяются в процессе выполнения программы.
Например, на основе пользовательского ввода или конфигурационных данных.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍65🔥2
🐍Существуют ситуации, когда при работе с терминалом необходимо выделить определенную информацию цветом. Один из способов — использовать ANSI Escape Codes.

➡️Символ \033 обозначает начало управляющего кода ANSI, [33;104m — это параметры, где 33 — желтый цвет текста, 104 — синий цвет фона, а [0m возвращает цвет текста в стандартный черный.

➡️Важно отметить, что поддержка ANSI Escape Codes может варьироваться в зависимости от используемой операционной системы и терминала.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍83🔥1
🐍Байтовые объекты - это объекты, которые хранят и обрабатывают данные в виде байтов, а не в виде символов.

➡️Байтовые объекты в Python представлены типом данных bytes и bytearray.

➡️Основное различие между ними заключается в том, что bytes является неизменяемым типом данных, в то время как bytearray - изменяемым.

➡️Синтаксис для байтовых литералов похож на строковые литералы, но с добавлением префикса "b", который указывает интерпретатору Python на то, что строка должна быть представлена в виде байтового объекта.

💡Эти объекты часто используются для работы с бинарными файлами, сетевыми пакетами и другими данными, которые нужно представить в виде последовательности байтов.
Please open Telegram to view this post
VIEW IN TELEGRAM
6👍2🔥1
🐍Декоратор @jit в библиотеке Numba используется для компиляции функции Python в машинный код с целью ускорения её выполнения, одновременно сохраняя гибкость работы с разнообразными типами данных благодаря динамичности компиляции.

➡️Этот результат достигается за счёт использования JIT-компиляции (just-in-time compilation), что означает, что код компилируется только тогда, когда он действительно требуется в процессе выполнения программы, а не заранее.

💡Однако важно помнить, что результаты использования Numba могут варьироваться в зависимости от конкретной задачи и данных. В некоторых случаях, особенно при работе с небольшими объемами данных, накладные расходы на компиляцию могут превысить выигрыш в скорости. Поэтому рекомендуется провести тщательное тестирование перед внедрением Numba в проект.
Please open Telegram to view this post
VIEW IN TELEGRAM
5👍4🔥3
🐍Функция mean() из модуля statistics в Python используется для вычисления среднего значения (средней арифметической) из последовательности чисел и принимает в качестве аргумента итерируемый объект.

➡️Однако стоит отметить, что statistics.mean() не работает со строками или другими нечисловыми типами данных. Если в вашей последовательности есть строки, вам нужно предварительно провести преобразование к числовому типу.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍63🔥1
🐍Чтобы объект стал итерируемым, необходимо реализовать метод __iter__().
Метод __iter__() должен возвращать объект, который имеет метод __next__(), либо сам являтся итерируемым (итератором).

⬆️В этом примере при каждом вызове next() возвращается следующий элемент из data, пока не будет достигнут конец списка, после чего вызывается исключение StopIteration, что говорит о завершении итерации.

➡️Таким образом, реализуя методы iter() и next(), можем сделать свой объект итерируемым и использовать его в циклах for и других местах, где требуется работа с итерируемыми объектами.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍62🔥1
🐍Ошибка IndexError в Python возникает, когда происходит попытка обращения к элементу последовательности (списка, кортежа, строки и т. д.) с индексом, который выходит за пределы допустимого диапазона индексов.

➡️Например, если у нас есть список с пятью элементами, а мы пытаемся обратиться к элементу с индексом 5 или -1 (если индексация идет с 0), то будет сгенерирована ошибка IndexError.

💡Для предотвращения ошибки IndexError важно всегда учитывать допустимый диапазон индексов при обращении к элементам последовательности. Можно использовать условные проверки перед обращением к элементу, чтобы убедиться, что индекс находится в допустимом диапазоне.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍52🔥1
🐍Метод upper() в Python используется для преобразования всех символов строки в верхний регистр. То есть все буквы в строке будут преобразованы в прописные (заглавные) буквы.

➡️Метод upper() не изменяет исходную строку, а создает новую строку с символами верхнего регистра. Поэтому для сохранения изменений необходимо присвоить результат работы метода переменной.

➡️Этот метод полезен, если вам нужно сравнивать строки без учета регистра символов, форматировать данные для вывода или в любых других случаях, когда вам нужно преобразовать все символы строки в верхний регистр.
Please open Telegram to view this post
VIEW IN TELEGRAM
9👍6🔥3
🤣29👍4😁4🗿3
🐍cProfile - это модуль в стандартной библиотеке Python, который предоставляет возможность профилирования кода. Он позволяет измерить время выполнения каждой функции в вашем коде, а также количество вызовов каждой функции. Это делает его отличным инструментом для определения тех мест в вашем коде, которые являются узкими местами и могут быть оптимизированы.

💡 Как использовать cProfile?

➡️Использование cProfile довольно просто. Вы просто импортируете модуль и вызываете функцию cProfile.run(), передавая ей строку кода, который вы хотите проанализировать. Вы также можете использовать cProfile в качестве командной строки, передав ему имя файла Python, который вы хотите профилировать. Результаты профилирования могут быть отсортированы по различным критериям, таким как общее время выполнения, время выполнения на вызов и количество вызовов.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍63🔥3
🐍Для создания словаря из двух списков в Python можно воспользоваться функцией zip(). Функция zip() объединяет элементы двух списков попарно и создает кортежи, которые затем можно преобразовать в словарь.

⬆️В данном примере мы создаем два списка keys и values, а затем используем функцию zip() для объединения элементов этих списков. Затем мы преобразуем полученные кортежи в словарь с помощью функции dict(). Результат выполнения кода будет следующим:

{'a': 1, 'b': 2, 'c': 3}


➡️Таким образом, мы создали словарь, в котором ключами являются элементы списка keys, а значениями - элементы списка values.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍74🔥1
🐍Trac - это веб-приложение, написанное на языке программирования Python, которое предоставляет инструменты для управления проектами и отслеживания ошибок.

➡️Trac позиционируется как простой и легкий инструмент для управления проектами и разработки программного обеспечения. Он широко используется сообществами разработчиков для совместной работы над проектами, отслеживания прогресса и обмена информацией.
Please open Telegram to view this post
VIEW IN TELEGRAM
4👍4🔥1
🐍Декораторы - это особый тип функций в Python, которые позволяют изменять поведение других функций. Декораторы позволяют добавлять новую функциональность к существующим функциям без изменения их кода.

➡️Для создания декоратора в Python используется символ @, после которого указывается имя декоратора. Декоратор представляет собой функцию, которая принимает другую функцию в качестве аргумента и возвращает новую функцию.

⬆️В данном примере мы создаем декоратор mydecorator, который выводит сообщения до и после вызова функции. Затем мы применяем декоратор к функции sayhello с помощью символа @. При вызове функции sayhello декоратор mydecorator добавляет дополнительное поведение к функции, выводя соответствующие сообщения.

💡Важно помнить, что декораторы могут быть использованы для различных целей, таких как логирование, проверка аргументов, кэширование и другие. Декораторы улучшают читаемость и поддерживаемость кода, делая его более гибким и масштабируемым.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍93🔥1
🐍Аннотация свойств (property annotation) в Python позволяет устанавливать атрибуты для доступа к атрибутам класса через геттеры, сеттеры и делитеры. Это удобный способ добавить логику к чтению и записи атрибутов объекта.

⬆️В этом примере класс Person имеет атрибут _name, к которому можно получить доступ через свойство name, определенное с помощью декоратора @property. Мы также определяем методы name.setter и name.deleter, чтобы управлять установкой и удалением значения атрибута name.

💡Использование аннотированных свойств помогает улучшить читаемость и поддерживаемость кода, а также добавляет гибкость и контроль над доступом к данным в классах Python.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍43🔥2
🐍Поиск в строке (string search) - это процесс поиска подстроки в строке для определения наличия или расположения конкретной последовательности символов. В Python для этого часто используется метод find(), который возвращает индекс первого вхождения подстроки в строку, или метод index(), который возвращает индекс первого вхождения подстроки, бросая исключение, если подстрока не найдена.

⬆️В обоих примерах мы ищем подстроку "world" в строке "Hello, world!". Первый пример использует метод find(), который вернет индекс первого вхождения подстроки, если она найдена, или -1, если нет. Второй пример использует метод index(), который также возвращает индекс первого вхождения подстроки, но бросает исключение ValueError, если подстрока не найдена.

➡️Это базовые примеры поиска в строке в Python, и существуют и другие методы и библиотеки для более сложных операций поиска и обработки строк. Вам также может быть полезно изучить регулярные выражения (модуль re) для более гибкого поиска и обработки текста в Python.
Please open Telegram to view this post
VIEW IN TELEGRAM
👍7🔥3🙈2