Python tricks | Хитрости Питона
6.73K subscribers
1.89K photos
26 videos
1 file
2.19K links
Здесь вы найдете лучшие практики и приёмы, которые используют опытные программисты.

Сотрудничество: @SIeep_Token

Мы на платформе: https://telegram.me/python_tricks

Ссылка на канал: https://t.me/+QayZf6ccsQllZTYy
Download Telegram
math prod

В Python 3.8 и более поздних версиях в модуле math есть функция prod, которая вычисляет произведение всех элементов в последовательности. Эта функция особенно удобна, когда тебе нужно вычислить произведение всех элементов в списке или другой последовательности. В предыдущих версиях Python ее можно было заменить на более универсальную функцию reduce из модуля functools. Однако math prod предоставляет более простой и читаемый способ для вычисления произведения всех элементов в последовательности.

🔗 Python tricks
Расширение возможности операции побитового "и" для пользовательских объектов

Метод rand в Python используется для реализации операции побитового "и" (оператора &), когда операнд слева не поддерживает соответствующий метод and. Этот метод полезен для работы с пользовательскими объектами, когда требуется поддерживать операцию побитового "и" с различными типами данных.

Рассмотрим пример, в котором у нас есть класс, представляющий пользовательские битовые данные, и мы хотим поддерживать операцию побитового "и" как с обычными числами Python (int), так и с другими экземплярами нашего класса.

Этот лайфхак позволяет сделать ваш класс более универсальным и поддерживать операции побитового "и" с различными типами данных, что повышает его гибкость и удобство использования.

🔗 Python tricks
Расширение возможности битового сдвига вправо для пользовательских объектов

Метод rrshift в Python используется для реализации обратного битового сдвига вправо (оператора >>), когда операнд слева не поддерживает соответствующий метод rshift. Этот метод полезен для работы с пользовательскими объектами, когда требуется поддерживать битовый сдвиг вправо с различными типами данных.

Рассмотрим пример, в котором у нас есть класс, представляющий пользовательские числа, и мы хотим поддерживать операцию битового сдвига вправо как с обычными числами Python (int), так и с другими экземплярами нашего класса.

Этот лайфхак позволяет сделать ваш класс более универсальным и поддерживающим операции битового сдвига вправо с различными типами данных, что повышает его гибкость и удобство использования.

🔗 Python tricks
Расширение возможности битового сдвига влево для пользовательских объектов

Метод rlshift в Python используется для реализации обратного битового сдвига влево (оператора <<), когда операнд слева не поддерживает соответствующий метод lshift. Этот метод полезен для работы с пользовательскими объектами, когда требуется поддерживать битовый сдвиг влево с различными типами данных.

Рассмотрим пример, в котором у нас есть класс, представляющий пользовательские числа, и мы хотим поддерживать операцию битового сдвига влево как с обычными числами Python (int), так и с другими экземплярами нашего класса.

Этот лайфхак позволяет сделать ваш класс более универсальным и поддерживающим операции битового сдвига влево с различными типами данных, что повышает его гибкость и удобство использования.

🔗 Python tricks
Расширение возможности возведения в степень для пользовательских объектов

Метод rpow в Python используется для реализации обратного возведения в степень (оператора **), когда операнд слева не поддерживает соответствующий метод pow. Этот метод полезен для работы с пользовательскими объектами, когда требуется поддерживать операцию возведения в степень с различными типами данных.

Рассмотрим пример, в котором у нас есть класс, представляющий пользовательские числа, и мы хотим поддерживать операцию возведения в степень как с обычными числами Python (int, float), так и с другими экземплярами нашего класса.

Этот лайфхак позволяет сделать ваш класс более универсальным и поддерживающим операции возведения в степень с различными типами данных, что повышает его гибкость и удобство использования.

🔗 Python tricks
string.rfind

string,rfind используется для поиска последнего вхождения подстроки в строке. Он возвращает индекс первого символа найденной подстроки, начиная справа (с конца) строки. Если подстрока не найдена, метод возвращает -1.

🔗 Python tricks
math.hypot

math.hypot — это функция в модуле math в Python, которая вычисляет гипотенузу прямоугольного треугольника, заданного катетами ( x ) и ( y ). Эта функция полезна, когда нужно вычислить расстояние между двумя точками в двумерном пространстве (координаты ( x ) и ( y )) или для других задач, связанных с расчетом длин векторов.

🔗 Python tricks
Расширение возможности матричного умножения для пользовательских объектов

Метод rmatmul в Python используется для реализации обратного матричного умножения, когда операнд слева не поддерживает соответствующий метод matmul (оператор @). Этот метод особенно полезен для работы с матрицами или объектами, которые поддерживают матричное умножение.

Рассмотрим пример, в котором у нас есть класс, представляющий пользовательские матрицы, и мы хотим поддерживать матричное умножение этих матриц как с обычными матрицами (списками списков), так и с другими экземплярами нашего класса.

Этот лайфхак позволяет сделать ваш класс более универсальным и поддерживающим операции матричного умножения с различными типами данных, что повышает его гибкость и удобство использования.

🔗 Python tricks
Расширение возможности матричного умножения для пользовательских объектов

Метод rmatmul в Python используется для реализации обратного матричного умножения, когда операнд слева не поддерживает соответствующий метод matmul (оператор @). Этот метод особенно полезен для работы с матрицами или объектами, которые поддерживают матричное умножение.

Рассмотрим пример, в котором у нас есть класс, представляющий пользовательские матрицы, и мы хотим поддерживать матричное умножение этих матриц как с обычными матрицами (списками списков), так и с другими экземплярами нашего класса.

Этот лайфхак позволяет сделать ваш класс более универсальным и поддерживающим операции матричного умножения с различными типами данных, что повышает его гибкость и удобство использования.

🔗 Python tricks
Расширение возможности вычитания для пользовательских объектов

Метод rsub в Python используется для реализации обратного вычитания, когда операнд слева не поддерживает соответствующий метод sub. Это позволяет определить, как ваш объект должен вычитаться из другого объекта.

Рассмотрим пример, в котором у нас есть класс, представляющий пользовательские числа, и мы хотим поддерживать вычитание этих чисел как с обычными числами Python (int, float), так и с другими экземплярами нашего класса.

Этот лайфхак позволяет сделать ваш класс более универсальным и поддерживающим операции вычитания с различными типами данных, что повышает его гибкость и удобство использования.

🔗 Python tricks
Использование метода __round__(self[, ndigits])

Метод round(self[, ndigits]) в Python позволяет определить пользовательское поведение округления объекта до заданного количества знаков после запятой. Этот метод полезен для пользовательских классов, когда требуется точное управление процессом округления данных.

Метод round является специальным методом, который вызывается при использовании встроенной функции round() для объекта. Он может принимать необязательный аргумент ndigits, который указывает количество знаков после запятой до которого нужно округлить объект.

Использование метода round позволяет вашим пользовательским классам быть совместимыми с встроенными операциями Python для округления чисел. Это значительно улучшает удобство использования классов в различных сценариях, требующих точного контроля над форматированием чисел.

🔗 Python tricks
string.rsplit

string.rsplit разделяет строку на подстроки, используя заданный разделитель, начиная с конца строки (справа) и возвращая список подстрок. В первом примере метод rsplit() разделяет строку по запятой с пробелом и возвращает список подстрок. Во втором примере метод разделяет строку на максимально два разбиения, начиная с конца.

🔗 Python tricks
Использование метода __index__(self)

Метод index(self) в Python позволяет определить пользовательское преобразование объекта в целочисленный индекс. Этот метод полезен для пользовательских классов, когда требуется использовать объект в качестве индекса для последовательностей (например, списков или кортежей) или для выполнения операций, ожидающих целочисленный индекс.

Метод index является специальным методом, который вызывается при использовании объекта в контексте, где ожидается целочисленный индекс, например, при индексации списка или кортежа. Он должен возвращать целое число, которое представляет объект в качестве индекса.

Использование метода index значительно улучшает удобство работы с пользовательскими классами в Python, когда необходимо работать с индексами. Это делает код более чистым, улучшает его читаемость и делает объекты вашего класса более универсальными для использования в различных контекстах, требующих целочисленные индексы.

🔗 Python tricks
Использование метода __float__(self)

Метод float(self) в Python позволяет определить пользовательское преобразование объекта в число с плавающей точкой (float). Этот метод полезен для пользовательских классов, которые хотят представить свои данные в формате числа с плавающей точкой.

Метод float является специальным методом, который вызывается при использовании встроенной функции float() для объекта. Он должен возвращать число с плавающей точкой, представляющее объект.

Использование метода float позволяет вашим пользовательским классам быть совместимыми с встроенными операциями и функциями Python, работающими с числами с плавающей точкой. Это упрощает интеграцию с другими частями экосистемы Python и делает ваш код более гибким и удобным для использования.

🔗 Python tricks
Использование метода __int__(self)

Метод int(self) в Python позволяет определить пользовательское преобразование объекта в целое число. Этот метод полезен для пользовательских классов, которые хотят определить способ преобразования своих данных в целочисленный формат.

Метод int является специальным методом, который вызывается при использовании встроенной функции int() для объекта. Он должен возвращать целое число, представляющее объект.

Использование метода int позволяет вашим пользовательским классам быть совместимыми с встроенными операциями и функциями Python, работающими с целыми числами. Это упрощает интеграцию с другими частями экосистемы Python и делает ваш код более гибким и удобным для использования.

🔗 Python tricks
Использование метода __complex__(self)

Метод complex(self) в Python позволяет определить пользовательское поведение при преобразовании объекта в комплексное число. Этот метод полезен для пользовательских классов, которые хотят представлять свои данные в комплексной форме.

Метод complex является специальным методом, который вызывается при использовании встроенной функции complex() для объекта. Он должен возвращать комплексное число, которое представляет объект в контексте комплексных чисел.

Использование метода complex позволяет объектам вашего класса быть совместимыми с встроенными инструментами Python для работы с комплексными числами. Это не только делает ваш код более гибким и удобным для использования, но и улучшает его интеграцию с другими частями экосистемы Python, особенно в области научных и инженерных вычислений.

🔗 Python tricks
Эффективное использование метода ior(self, other)

Метод ior(self, other) в Python позволяет определить поведение оператора побитового ИЛИ с присваиванием (|=) для пользовательских классов. Этот метод полезен для выполнения битовых операций над данными, которые хранятся в пользовательских объектах.

Метод ior является специальным методом, который позволяет реализовать операцию побитового ИЛИ с присваиванием. Когда оператор |= применяется к объекту, Python вызывает этот метод, позволяя изменить объект на месте в соответствии с результатом операции.

Использование метода ior позволяет легко реализовать операцию побитового ИЛИ с присваиванием для пользовательских классов. Это делает код более чистым и удобным для чтения, а также улучшает производительность за счет изменения объектов на месте.

🔗 Python tricks
Эффективное использование метода __irshift__(self, other)

Метод irshift(self, other) в Python позволяет определить поведение оператора побитового сдвига вправо с присваиванием (>>=) для пользовательских классов. Этот метод полезен для работы с битовыми операциями и манипуляциями с данными, которые требуют эффективного изменения битовых представлений.

Метод irshift является специальным методом, который позволяет реализовать операцию побитового сдвига вправо с присваиванием. Когда оператор >>= применяется к объекту, Python вызывает этот метод, позволяя изменить объект на месте в соответствии с результатом сдвига.

Использование метода irshift позволяет легко реализовать операцию побитового сдвига вправо с присваиванием для пользовательских классов. Это делает код более чистым и удобным для чтения, а также улучшает производительность за счет изменения объектов на месте.

🔗 Python tricks
Эффективное использование метода __ixor__(self, other)

Метод ixor(self, other) в Python позволяет определить поведение оператора побитового исключающего ИЛИ с присваиванием (^=) для пользовательских классов. Этот метод полезен для выполнения битовых операций над данными, которые хранятся в пользовательских объектах.

Метод ixor является специальным методом, который позволяет реализовать операцию побитового исключающего ИЛИ с присваиванием. Когда оператор ^= применяется к объекту, Python вызывает этот метод, позволяя изменить объект на месте в соответствии с результатом операции.

Использование метода ixor позволяет легко реализовать операцию побитового исключающего ИЛИ с присваиванием для пользовательских классов. Это делает код более чистым и удобным для чтения, а также улучшает производительность за счет изменения объектов на месте.

🔗 Python tricks
math.fsum

math.fsum — это функция в модуле math, которая возвращает точную сумму значений, содержащихся в итерируемом объекте (например, списке или кортеже). math.fsum обеспечивает высокую точность, особенно при суммировании большого количества чисел с плавающей точкой, поскольку она использует алгоритм компенсации ошибок для уменьшения погрешностей при сложении.

🔗 Python tricks