[Перевод] 10 продвинутых сниппетов Python, которые повысят ваши навыки кодирования

a9291b44b4f0c69c86ad194dd7382ef4

Универсальность и простота Python делают его любимцем среди разработчиков для различных задач, от веб-разработки до анализа данных и машинного обучения. Однако владение Python выходит за рамки понимания его синтаксиса; речь идет о написании эффективного, элегантного и читаемого кода. В этой статье мы рассмотрим 10 сниппетов Python, которые помогут вам кодировать как профессионал, улучшая ваши навыки программирования и продуктивности.

1. Операции с множествами

Множества в Python поддерживают различные операции, такие как объединение, пересечение и разность.

set1 = {1, 2, 3}
set2 = {3, 4, 5}
union = set1 | set2
intersection = set1 & set2
difference = set1 - set2

Этот сниппет демонстрирует операции с множествами для комбинирования, поиска общих элементов и различий между множествами.

2. Частичные функции

Частичные функции позволяют зафиксировать определенное количество аргументов функции и создать новую функцию.

from functools import partial
def power(base, exponent):
    return base ** exponent

square = partial(power, exponent=2)
cube = partial(power, exponent=3)

print(square(2))  # Output: 4
print(cube(2))    # Output: 8

Этот сниппет демонстрирует, как создать специализированные функции с использованием partial.

3. Мемоизация

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

from functools import lru_cache

@lru_cache(maxsize=None)
def fib(n):
    if n < 2:
        return n
    return fib(n-1) + fib(n-2)

print(fib(10))  # Output: 55

4. Метаклассы

Метаклассы — это классы классов. Они позволяют настраивать поведение создания класса в Python.

class SingletonMeta(type):
    _instances = {}

    def __call__(cls, *args, **kwargs):
        if cls not in cls._instances:
            cls._instances[cls] = super().__call__(*args, **kwargs)
        return cls._instances[cls]

class Singleton(metaclass=SingletonMeta):
    pass

obj1 = Singleton()
obj2 = Singleton()
print(obj1 is obj2)  # Output: True

5. Конкурентность с asyncio

asyncio — это библиотека для написания конкурентного кода с использованием синтаксиса async/await.

import asyncio

async def greet(name):
    await asyncio.sleep(1)
    print(f"Hello, {name}!")

async def main():
    await asyncio.gather(greet("Alice"), greet("Bob"))

asyncio.run(main())

Этот фрагмент демонстрирует асинхронное программирование с помощью asyncio для одновременного приветствия нескольких людей.

6. Дата-классы

Дата-классы предоставляют простой способ создания классов для хранения данных.

from dataclasses import dataclass

@dataclass
class Point:
    x: float
    y: float

p = Point(1.5, 2.5)
print(p)  # Output: Point(x=1.5, y=2.5)

Этот фрагмент кода создает простой класс данных для представления точки в 2D-пространстве.

7. Декораторы с аргументами

Декораторы могут принимать аргументы, позволяя более гибкое поведение.

def repeat(num_times):
    def decorator_repeat(func):
        def wrapper(*args, **kwargs):
            for _ in range(num_times):
                result = func(*args, **kwargs)
            return result
        return wrapper
    return decorator_repeat

@repeat(num_times=3)
def greet(name):
    print(f"Hello, {name}!")

greet("Alice")

8. Перегрузка функций с functools.singledispatch

functools.singledispatch позволяет перегружать функции на основе типа первого аргумента.

from functools import singledispatch

@singledispatch
def process(arg):
    print("Default processing:", arg)

@process.register(int)
def _(arg):
    print("Processing an integer:", arg)

@process.register(list)
def _(arg):
    print("Processing a list:", arg)

process(10)       # Output: Processing an integer: 10
process([1, 2, 3])# Output: Processing a list: [1, 2, 3]

9. Асинхронные итераторы

Асинхронные итераторы позволяют асинхронно итерировать последовательность данных.

async def async_generator():
    for i in range(3):
        yield i
        await asyncio.sleep(1)

async def main():
    async for item in async_generator():
        print(item)

asyncio.run(main())

10. Динамический доступ к атрибутам с getattr

Функция getattr возвращает значение атрибута указанного объекта в Python.

class MyClass:
    def __init__(self):
        self.x = 10
        self.y = 20

obj = MyClass()
attribute_name = "x"
print(getattr(obj, attribute_name))  # Output: 10

Заключение

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

© Habrahabr.ru