Кривая обучения Python: от новичка в Python до профессионала

Apr 22 2023
С фрагментами кода
Введение: Python — один из самых универсальных и широко используемых языков программирования в мире, известный своей простотой, удобочитаемостью и универсальностью. В этой статье мы рассмотрим серию примеров сценариев, в которых код разрабатывается программистами с тремя различными уровнями знаний: новичок, средний уровень и эксперт.
Фото Натана Лонга на Unsplash

Введение:

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

Промежуточные звенья и эксперты обычно используют следующее:

  • Понимание списков: краткий способ создания списков с помощью одной строки кода.
  • squares = [x**2 for x in range(1, 6)]
    print(squares)  
    # Output: [1, 4, 9, 16, 25]
    

    squares_dict = {x: x**2 for x in range(1, 6)}
    print(squares_dict)  
    # Output: {1: 1, 2: 4, 3: 9, 4: 16, 5: 25}
    

    nums = [1, 2, 3, 4, 5]
    doubles = list(map(lambda x: x * 2, nums))
    print(doubles)  # Output: [2, 4, 6, 8, 10]
    

    def greet_decorator(func):
        def wrapper():
            print("Hello!")
            func()
            print("Welcome!")
        return wrapper
    
    @greet_decorator
    def greet_name():
        print("John")
    
    greet_name()
    # Output:
    # Hello!
    # John
    # Welcome!
    

    with open("file.txt", "r") as file:
        content = file.read()
        print(content)
    

    from typing import List
    
    def sum_elements(elements: List[int]) -> int:
        return sum(elements)
    
    result = sum_elements([1, 2, 3, 4, 5])
    print(result)  # Output: 15
    

    def fibonacci_gen(n: int):
        a, b = 0, 1
        for _ in range(n):
            yield a
            a, b = b, a + b
    
    for num in fibonacci_gen(5):
        print(num, end=" ")
    # Output: 0 1 1 2 3
    

    import re
    
    text = "The email addresses are [email protected] and [email protected]"
    pattern = r"\b[A-Za-z0-9._%+-]+@[A-Za-z0-9.-]+\.[A-Z|a-z]{2,}\b"
    emails = re.findall(pattern, text)
    print(emails)  # Output: ['[email protected]', '[email protected]']
    

    try:
        result = 10 / 0
    except ZeroDivisionError as e:
        print(f"An error occurred: {e}")
    # Output: An error occurred: division by zero
    

    # Importing the 'math' module and using its 'sqrt' function
    import math
    
    sqrt_result = math.sqrt(25)
    print(sqrt_result)  # Output: 5.0
    

    import threading
    
    def print_square(num):
        print(f"Square: {num * num}")
    
    def print_cube(num):
        print(f"Cube: {num * num * num}")
    
    thread1 = threading.Thread(target=print_square, args=(4,))
    thread2 = threading.Thread(target=print_cube, args=(4,))
    
    thread1.start()
    thread2.start()
    
    thread1.join()
    thread2.join()
    
    # Output:
    # Square: 16
    # Cube: 64
    

    # Built-in functions
    numbers = [2, 4, 1, 6, 3, 8, 5, 7]
    max_num = max(numbers)  # Find the maximum number in the list
    min_num = min(numbers)  # Find the minimum number in the list
    sorted_nums = sorted(numbers)  # Sort the list in ascending order
    reversed_nums = list(reversed(numbers))  # Reverse the list
    
    print("Maximum number:", max_num)
    print("Minimum number:", min_num)
    print("Sorted numbers:", sorted_nums)
    print("Reversed numbers:", reversed_nums)
    
    # Standard library modules
    from collections import Counter
    from itertools import combinations
    
    # Counter (from collections module)
    word = "mississippi"
    counter = Counter(word)  # Count the occurrences of each character
    print("Character count:", counter)
    
    # Combinations (from itertools module)
    combos = list(combinations(numbers, 2))  # Find all combinations of size 2
    print("Combinations of size 2:", combos)
    

  • PEP 8 и стиль кодирования. Соблюдение официального руководства по стилю Python (PEP 8) и других передовых методов обеспечения удобочитаемости и согласованности кода.
  • # PEP 8 compliant code snippet
    
    def calculate_area(radius):
        """Calculate the area of a circle given its radius.
    
        Args:
            radius (float): The radius of the circle.
    
        Returns:
            float: The area of the circle.
        """
        pi = 3.14159
        return pi * radius**2
    
    
    def main():
        # Collect user input for the radius
        radius = float(input("Enter the radius of the circle: "))
    
        # Calculate the area using the defined function
        area = calculate_area(radius)
    
        # Display the result with appropriate formatting
        print(f"The area of the circle with radius {radius} is {area:.2f}")
    
    
    if __name__ == "__main__":
        main()
    

    import unittest
    
    def add_numbers(a, b):
        return a + b
    
    class TestAddition(unittest.TestCase):
        def test_addition(self):
            self.assertEqual(add_numbers(2, 3), 5)
    
    if __name__ == '__main__':
        unittest.main(argv=['first-arg-is-ignored'], exit=False)
    # Output: .
    # ----------------------------------------------------------------------
    # Ran 1 test in 0.002s
    #
    # OK
    

    Изображение автора

Новичок:

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]
even_sum = 0

for num in numbers:
    if num % 2 == 0:
        even_sum += num

print("The sum of even numbers is:", even_sum)

  • Проверяет, использует ли число даже оператор модуля
  • Добавляет четное число к переменной суммы

def is_even(num):
    return num % 2 == 0

def even_sum(numbers):
    result = 0
    for num in numbers:
        if is_even(num):
            result += num
    return result

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]
result = even_sum(numbers)
print("The sum of even numbers is:", result)

  • Создает функцию even_sumдля вычисления суммы четных чисел
  • Код более модульный и его легче поддерживать

def even_sum(numbers):
    return sum(filter(lambda num: num % 2 == 0, numbers))

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]
result = even_sum(numbers)
print("The sum of even numbers is:", result)

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

Новичок:

text = "hello world"
char_count = {}

for char in text:
    if char in char_count:
        char_count[char] += 1
    else:
        char_count[char] = 1

print("Character counts:", char_count)

#Character counts: {'h': 1, 'e': 1, 'l': 3, 'o': 2, ' ': 1, 'w': 1, 'r': 1, 'd': 1}

  • Проверяет, есть ли уже символ в словаре, и соответствующим образом обновляет счетчик.

def count_characters(text):
    char_count = {}
    for char in text:
        char_count[char] = char_count.get(char, 0) + 1
    return char_count

text = "hello world"
result = count_characters(text)
print("Character counts:", result)

  • Использует dict.get()метод для упрощения кода.

from collections import Counter

def count_characters(text):
    return Counter(text)

text = "hello world"
result = count_characters(text)
print("Character counts:", result)

  • Использует встроенную функцию Counterдля эффективного подсчета вхождений символов.
  • Изображение автора

Новичок:

numbers = [1, 2, 3, 4, 5]
total = 0

for num in numbers:
    total += num

average = total / len(numbers)
print("The average is:", average)

  • Делит сумму на длину списка, чтобы вычислить среднее

def calculate_average(numbers):
    return sum(numbers) / len(numbers)

numbers = [1, 2, 3, 4, 5]
average = calculate_average(numbers)
print("The average is:", average)

  • Использует встроенную sumфункцию для упрощения кода

from statistics import mean

def calculate_average(numbers):
    return mean(numbers)

numbers = [1, 2, 3, 4, 5]
average = calculate_average(numbers)
print("The average is:", average)

  • Использует встроенную meanфункцию для вычисления среднего
  • Изображение автора

Новичок:

text = "hello"
reversed_text = ""

for char in text:
    reversed_text = char + reversed_text

print("Reversed text:", reversed_text)
#text = "Hello"
#Reversed text: olleH

  • Объединяет символы в обратном порядке для построения обратной строки

def reverse_string(text):
    return "".join(reversed(text))

text = "hello"
reversed_text = reverse_string(text)
print("Reversed text:", reversed_text)

  • Использует reversedфункцию и joinметод для обращения строки

def reverse_string(text):
    return text[::-1]

text = "hello"
reversed_text = reverse_string(text)
print("Reversed text:", reversed_text)

Изображение автора

5. Нахождение самого большого числа в списке:

Новичок:

numbers = [1, 3, 7, 2, 5]
max_number = numbers[0]

for num in numbers:
    if num > max_number:
        max_number = num

print("The largest number is:", max_number)

#The largest number is: 7

  • Сравнивает каждое число с текущим максимумом и соответствующим образом обновляет максимум

def find_max(numbers):
    return max(numbers)

numbers = [1, 3, 7, 2, 5]
max_number = find_max(numbers)
print("The largest number is:", max_number)

  • Использует встроенную maxфункцию для нахождения максимального числа

from functools import reduce

def find_max(numbers):
    return reduce(lambda x, y: x if x > y else y, numbers)

numbers = [1, 3, 7, 2, 5]
max_number = find_max(numbers)
print("The largest number is:", max_number)

  • Использует reduceфункцию с лямбда-функцией, чтобы найти максимальное число
  • Изображение автора

Новичок:

original_list = [1, 2, 3, 1, 2, 3, 4, 5]
unique_list = []

for item in original_list:
    if item not in unique_list:
        unique_list.append(item)

print("Unique list:", unique_list)

  • Проверяет, отсутствует ли элемент в уникальном списке, и добавляет его, если он отсутствует

def remove_duplicates(items):
    return list(set(items))

original_list = [1, 2, 3, 1, 2, 3, 4, 5]
unique_list = remove_duplicates(original_list)
print("Unique list:", unique_list)

  • Использует встроенную setструктуру данных для удаления дубликатов и преобразования их обратно в список.

def remove_duplicates(items):
    return list(dict.fromkeys(items))

original_list = [1, 2, 3, 1, 2, 3, 4, 5]
unique_list = remove_duplicates(original_list)
print("Unique list:", unique_list)

Изображение автора

7. Возведение в квадрат всех чисел в списке:

Новичок:

numbers = [1, 2, 3, 4, 5]
squared_numbers = []

for num in numbers:
    squared_numbers.append(num ** 2)

print("Squared numbers:", squared_numbers)
#Squared numbers: [1, 4, 9, 16, 25]

  • Добавляет квадрат каждого числа в список квадратов чисел

def square_numbers(numbers):
    return [num ** 2 for num in numbers]

numbers = [1, 2, 3, 4, 5]
squared_numbers = square_numbers(numbers)
print("Squared numbers:", squared_numbers)

  • Использует понимание списка для создания списка квадратов чисел

def square_numbers(numbers):
    return list(map(lambda x: pow(x, 2), numbers))

numbers = [1, 2, 3, 4, 5]
squared_numbers = square_numbers(numbers)
print("Squared numbers:", squared_numbers)

      
                
Image by the Author

Новичок:

numbers = [1, 2, 3, 4, 5]
positions = 2

rotated_list = numbers[-positions:] + numbers[:-positions]
print("Rotated list:", rotated_list)
#Rotated list: [4, 5, 1, 2, 3]

Средний:

def rotate_list(numbers, positions):
    return numbers[-positions:] + numbers[:-positions]

numbers = [1, 2, 3, 4, 5]
positions = 2
rotated_list = rotate_list(numbers, positions)
print("Rotated list:", rotated_list)

  • Использует синтаксис нарезки Python для поворота списка на указанное количество позиций.

from collections import deque

def rotate_list(numbers, positions):
    rotated_numbers = deque(numbers)
    rotated_numbers.rotate(positions)
    return list(rotated_numbers)

numbers = [1, 2, 3, 4, 5]
positions = 2
rotated_list = rotate_list(numbers, positions)
print("Rotated list:", rotated_list)

  • Использует dequeкласс и его rotateметод для эффективного поворота списка на указанное количество позиций.
  • Изображение автора

Новичок:

list1 = [1, 2, 3, 4, 5]
list2 = [4, 5, 6, 7, 8]
common_elements = []

for num in list1:
    if num in list2:
        common_elements.append(num)

print("Common elements:", common_elements)
#Common elements: [4, 5]

  • Проверяет, присутствует ли элемент во втором списке, и добавляет его в список общих элементов, если он найден

def find_common_elements(list1, list2):
    return [num for num in list1 if num in list2]

list1 = [1, 2, 3, 4, 5]
list2 = [4, 5, 6, 7, 8]
common_elements = find_common_elements(list1, list2)
print("Common elements:", common_elements)

  • Использует понимание списка для создания списка общих элементов

def find_common_elements(list1, list2):
    return list(set(list1) & set(list2))

list1 = [1, 2, 3, 4, 5]
list2 = [4, 5, 6, 7, 8]
common_elements = find_common_elements(list1, list2)
print("Common elements:", common_elements)

  • Преобразует результат обратно в список
  • Изображение автора

Новичок:

matrix = [[1, 2, 3],
          [4, 5, 6],
          [7, 8, 9]]

transposed_matrix = []

for i in range(len(matrix[0])):
    transposed_row = []
    for row in matrix:
        transposed_row.append(row[i])
    transposed_matrix.append(transposed_row)

print("Transposed matrix:", transposed_matrix)

  • Добавляет элементы из каждой строки исходной матрицы для создания транспонированной матрицы.

def transpose_matrix(matrix):
    return [[row[i] for row in matrix] for i in range(len(matrix[0]))]

matrix = [[1, 2, 3],
          [4, 5, 6],
          [7, 8, 9]]
transposed_matrix = transpose_matrix(matrix)
print("Transposed matrix:", transposed_matrix)

  • Использует понимание вложенного списка для создания транспонированной матрицы

def transpose_matrix(matrix):
    return list(zip(*matrix))

matrix = [[1, 2, 3],
          [4, 5, 6],
          [7, 8, 9]]
transposed_matrix = transpose_matrix(matrix)
print("Transposed matrix:", transposed_matrix)

Изображение автора

11. Проверка, является ли строка палиндромом:

Новичок:

string = "madam"
is_palindrome = True

for i in range(len(string) // 2):
    if string[i] != string[-(i + 1)]:
        is_palindrome = False
        break

print(f"Is '{string}' a palindrome?:", is_palindrome)
#Is 'madam' a palindrome?: True

  • Сравнивает каждый символ с соответствующим ему символом с конца строки и устанавливает is_palindromeзначение False, если они не совпадают

def is_palindrome(string):
    return string == string[::-1]

string = "madam"
result = is_palindrome(string)
print(f"Is '{string}' a palindrome?:", result)

  • Использует синтаксис среза Python, чтобы перевернуть строку и сравнить ее с исходной строкой.
  • Изображение автора

Новичок:

num = 60
prime_factors = []

for i in range(2, num + 1):
    while num % i == 0:
        prime_factors.append(i)
        num = num // i

print("Prime factors:", prime_factors)
#Prime factors: [2, 2, 3, 5]

  • Использует цикл while для многократного деления числа на множитель, пока оно делится
  • Добавляет простые множители в список

def prime_factors(num):
    factors = []
    for i in range(2, num + 1):
        while num % i == 0:
            factors.append(i)
            num = num // i
    return factors

num = 60
result = prime_factors(num)
print("Prime factors:", result)

  • Использует вложенные циклы для определения основных факторов и добавления их в список.

def prime_factors(num):
    factors = []
    i = 2
    while i * i <= num:
        if num % i:
            i += 1
        else:
            num //= i
            factors.append(i)
    if num > 1:
        factors.append(num)
    return factors

num = 60
result = prime_factors(num)
print("Prime factors:", result)

  • Использует один цикл while для многократного деления числа на наименьший делитель.
  • Добавляет простые множители в список и проверяет, больше ли оставшееся число 1, чтобы учесть последний простой множитель.
  • Изображение автора

Новичок:

nested_list = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
flat_list = []

for sublist in nested_list:
    for item in sublist:
        flat_list.append(item)

print("Flat list:", flat_list)
#Flat list: [1, 2, 3, 4, 5, 6, 7, 8, 9]

  • Добавляет каждый элемент в новый плоский список

def flatten_list(nested_list):
    return [item for sublist in nested_list for item in sublist]

nested_list = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
flat_list = flatten_list(nested_list)
print("Flat list:", flat_list)

  • Использует понимание вложенного списка для создания плоского списка

from itertools import chain

def flatten_list(nested_list):
    return list(chain.from_iterable(nested_list))

nested_list = [[1, 2, 3], [4, 5, 6], [7, 8, 9]]
flat_list = flatten_list(nested_list)
print("Flat list:", flat_list)

  • Определяет функцию flatten_list, которая использует chain.from_iterableфункцию для выравнивания вложенного списка.
  • Изображение автора

Новичок:

sentence = "apple banana apple kiwi banana apple"
word_count = {}

for word in sentence.split():
    if word in word_count:
        word_count[word] += 1
    else:
        word_count[word] = 1

print("Word count:", word_count)

  • Использует базовый цикл for для перебора слов и подсчета их появления в словаре.

from collections import Counter

def count_words(sentence):
    return Counter(sentence.split())

sentence = "apple banana apple kiwi banana apple"
word_count = count_words(sentence)
print("Word count:", word_count)

  • Определяет функцию count_words, которая использует Counterкласс для подсчета частоты слов в предложении.

from collections import defaultdict

def count_words(sentence):
    word_count = defaultdict(int)
    for word in sentence.split():
        word_count[word] += 1
    return word_count

sentence = "apple banana apple kiwi banana apple"
word_count = count_words(sentence)
print("Word count:", word_count)

  • Определяет функцию count_words, которая использует defaultdict с целочисленными значениями для подсчета частоты слов.
  • Использует splitметод для токенизации предложения и цикл for для увеличения количества слов.
  • Изображение автора

Новичок:

def merge_dicts(d1, d2):
    merged_dict = d1.copy()
    merged_dict.update(d2)
    return merged_dict

dict1 = {'a': 1, 'b': 2, 'c': 3}
dict2 = {'d': 4, 'e': 5}
result = merge_dicts(dict1, dict2)
print("Merged dictionary:", result)

#Merged dictionary: {'a': 1, 'b': 2, 'c': 3, 'd': 4, 'e': 5}

  • Использует copyметод для создания копии первого словаря и updateметод для обновления словаря парами ключ-значение из второго словаря.

def merge_dicts(d1, d2):
    return {**d1, **d2}

dict1 = {'a': 1, 'b': 2, 'c': 3}
dict2 = {'d': 4, 'e': 5}
result = merge_dicts(dict1, dict2)
print("Merged dictionary:", result)

  • Использует распаковку словаря ( **d1, **d2) для объединения словарей

from collections import ChainMap

def merge_dicts(d1, d2):
    return dict(ChainMap(d1, d2))

dict1 = {'a': 1, 'b': 2, 'c': 3}
dict2 = {'d': 4, 'e': 5}
result = merge_dicts(dict1, dict2)
print("Merged dictionary:", result)

  • Определяет функцию merge_dictsдля объединения двух словарей
  • Использует ChainMapкласс для создания комбинированного представления двух словарей и преобразует результат в словарь.
  • Изображение автора

Новичок:

def list_difference(lst1, lst2):
    difference = []
    for item in lst1:
        if item not in lst2:
            difference.append(item)
    return difference

lst1 = [1, 2, 3, 4, 5]
lst2 = [4, 5, 6, 7, 8]
result = list_difference(lst1, lst2)
print("List difference:", result)

#List difference: [1, 2, 3]

  • Использует базовый цикл for для перебора элементов в первом списке и проверяет, отсутствует ли каждый элемент во втором списке.
  • Добавляет уникальные элементы в список различий

def list_difference(lst1, lst2):
    return list(set(lst1) - set(lst2))

lst1 = [1, 2, 3, 4, 5]
lst2 = [4, 5, 6, 7, 8]
result = list_difference(lst1, lst2)
print("List difference:", result)

  • Преобразует списки в наборы и использует оператор разности наборов ( -) для поиска уникальных элементов.
  • Преобразует результат обратно в список

def list_difference(lst1, lst2):
    return [item for item in lst1 if item not in set(lst2)]

lst1 = [1, 2, 3, 4, 5]
lst2 = [4, 5, 6, 7, 8]
result = list_difference(lst1, lst2)
print("List difference:", result)

  • Использует понимание списка с условием для создания списка уникальных элементов.
  • Преобразует второй список в набор для оптимизации проверки членства.
  • Изображение автора

Новичок:

def create_dict(keys, values):
    result = {}
    for key, value in zip(keys, values):
        result[key] = value
    return result

keys = ['name', 'age', 'gender']
values = ['Alice', 25, 'Female']
result = create_dict(keys, values)
print("Dictionary:", result)

#Dictionary: {'name': 'Alice', 'age': 25, 'gender': 'Female'}

  • Использует цикл for с zipфункцией для одновременного перебора ключей и значений.
  • Создает словарь, присваивая каждому значению соответствующий ключ.

def create_dict(keys, values):
    return dict(zip(keys, values))

keys = ['name', 'age', 'gender']
values = ['Alice', 25, 'Female']
result = create_dict(keys, values)
print("Dictionary:", result)

  • Использует zipфункцию для сопряжения ключей и значений, а затем использует dictконструктор для создания словаря.

def create_dict(keys, values):
    return {key: value for key, value in zip(keys, values)}

keys = ['name', 'age', 'gender']
values = ['Alice', 25, 'Female']
result = create_dict(keys, values)
print("Dictionary:", result)

  • Использует понимание словаря с zipфункцией для создания словаря
  • Изображение автора

Новичок:

def replace_word(sentence, old_word, new_word):
    return sentence.replace(old_word, new_word)

sentence = "I like apples. Apples are tasty."
old_word = "apples"
new_word = "oranges"
print(replace_word(sentence, old_word, new_word))

#I like oranges. Apples are tasty.

import re

def replace_word(sentence, old_word, new_word):
    return re.sub(r'\b' + old_word + r'\b', new_word, sentence, flags=re.IGNORECASE)

sentence = "I like apples. Apples are tasty."
old_word = "apples"
new_word = "oranges"
print(replace_word(sentence, old_word, new_word))

      
                
Image by the Author

Новичок:

def mean(numbers):
    return sum(numbers) / len(numbers)

def standard_deviation(numbers):
    avg = mean(numbers)
    return (sum((x - avg) ** 2 for x in numbers) / len(numbers)) ** 0.5

numbers = [1, 2, 3, 4, 5]
print(standard_deviation(numbers))

#1.4142135623730951

import numpy as np

numbers = [1, 2, 3, 4, 5]
print(np.std(numbers))

      
                
Image by the Author

Новичок:

from sklearn.preprocessing import OneHotEncoder

data = [['apple'], ['banana'], ['orange'], ['apple'], ['banana']]
encoder = OneHotEncoder()
one_hot_encoded = encoder.fit_transform(data).toarray()
print(one_hot_encoded)

import pandas as pd

data = pd.DataFrame({'fruit': ['apple', 'banana', 'orange', 'apple', 'banana']})
one_hot_encoded = pd.get_dummies(data, columns=['fruit'])
print(one_hot_encoded)

      
                
Image by the Author

Новичок:

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]
even_numbers = []
odd_numbers = []

for num in numbers:
    if num % 2 == 0:
        even_numbers.append(num)
    else:
        odd_numbers.append(num)

grouped_numbers = {'even': even_numbers, 'odd': odd_numbers}
print("Grouped numbers:", grouped_numbers)
#Grouped numbers: {'even': [2, 4, 6, 8], 'odd': [1, 3, 5, 7, 9]}

  • Добавляет четные числа в even_numbersсписок и нечетные числа в odd_numbersсписок
  • Сгруппируйте числа в словарь

def group_by_parity(numbers):
    return {
        'even': [num for num in numbers if num % 2 == 0],
        'odd': [num for num in numbers if num % 2 != 0],
    }

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]
grouped_numbers = group_by_parity(numbers)
print("Grouped numbers:", grouped_numbers)

  • Использует понимание словаря и понимание списка для создания сгруппированного словаря

from collections import defaultdict

def group_by_parity(numbers):
    grouped_numbers = defaultdict(list)
    for num in numbers:
        key = 'even' if num % 2 == 0 else 'odd'
        grouped_numbers[key].append(num)
    return grouped_numbers

numbers = [1, 2, 3, 4, 5, 6, 7, 8, 9]
grouped_numbers = group_by_parity(numbers)
print("Grouped numbers:", grouped_numbers)

  • Определяет функцию group_by_parity, которая использует defaultdict для группировки чисел по их четности.
  • Перебирает числа и добавляет их к соответствующему ключу («четному» или «нечетному») в сгруппированном словаре.
  • Изображение автора

Новичок:

numbers = [1, 2, 2, 3, 4, 4, 4, 5, 5]
element_count = {}

for num in numbers:
    if num in element_count:
        element_count[num] += 1
    else:
        element_count[num] = 1

most_common_element = max(element_count, key=element_count.get)
print("Most common element:", most_common_element)

#Most common element: 4

  • Использует maxфункцию с keyаргументом, чтобы найти наиболее распространенный элемент

from collections import Counter

def most_common_element(lst):
    return Counter(lst).most_common(1)[0][0]

numbers = [1, 2, 2, 3, 4, 4, 4, 5, 5]
result = most_common_element(numbers)
print("Most common element:", result)

  • Определяет функцию `most_common_element`, которая использует класс `Counter` для подсчета вхождений элементов в списке.

from statistics import mode

def most_common_element(lst):
    return mode(lst)

numbers = [1, 2, 2, 3, 4, 4, 4, 5, 5]
result = most_common_element(numbers)
print("Most common element:", result)

  • Определяет функцию most_common_element, которая использует modeфункцию для поиска наиболее часто встречающегося элемента в списке.
  • Функция modeвозвращает самый распространенный элемент в списке
  • Изображение автора

Новичок:

def dict_to_tuples(d):
    return [(key, value) for key, value in d.items()]

dictionary = {'a': 1, 'b': 2, 'c': 3}
result = dict_to_tuples(dictionary)
print("List of tuples:", result)

# List of tuples: [('a', 1), ('b', 2), ('c', 3)]

  • Использует понимание списка с itemsметодом словаря для создания списка кортежей.

def dict_to_tuples(d):
    return list(d.items())

dictionary = {'a': 1, 'b': 2, 'c': 3}
result = dict_to_tuples(dictionary)
print("List of tuples:", result)

  • Использует itemsметод словаря для получения пар ключ-значение в виде кортежей и преобразует результат в список.

from operator import itemgetter

def dict_to_tuples(d):
    return sorted(d.items(), key=itemgetter(0))

dictionary = {'a': 1, 'b': 2, 'c': 3}
result = dict_to_tuples(dictionary)
print("List of tuples:", result)

  • Определяет функцию dict_to_tuplesдля преобразования словаря в список кортежей.
  • Использует itemsметод словаря для получения пар ключ-значение в виде кортежей и сортирует результат на основе ключей.

Новичок:

def find_max_min(numbers):
    max_value = max(numbers)
    min_value = min(numbers)
    return max_value, min_value

numbers = [1, 2, 3, 4, 5]
max_value, min_value = find_max_min(numbers)
print("Maximum value:", max_value)
print("Minimum value:", min_value)

# Maximum value: 5
# Minimum value: 1

  • Использует встроенные функции maxи minдля нахождения максимального и минимального значений.

def find_max_min(numbers):
    return max(numbers), min(numbers)

numbers = [1, 2, 3, 4, 5]
max_value, min_value = find_max_min(numbers)
print("Maximum value:", max_value)
print("Minimum value:", min_value)

  • Использует встроенные функции maxи minдля поиска максимального и минимального значений и возвращает их в виде кортежа.

from functools import reduce

def find_max_min(numbers):
    return reduce(lambda acc, x: (max(acc[0], x), min(acc[1], x)), numbers, (float('-inf'), float('inf')))

numbers = [1, 2, 3, 4, 5]
max_value, min_value = find_max_min(numbers)
print("Maximum value:", max_value)
print("Minimum value:", min_value)

  • Определяет функцию find_max_minдля поиска максимального и минимального значений в списке чисел.
  • Использует reduceфункцию с лямбда-функцией для вычисления максимального и минимального значений путем сравнения каждого элемента с накопленными значениями.
  • Инициализирует аккумулятор отрицательной и положительной бесконечностью для обработки пограничных случаев.
  • Изображение автора

Новичок:

def calculate_mean(numbers):
    return sum(numbers) / len(numbers)

def calculate_median(numbers):
    numbers.sort()
    n = len(numbers)
    if n % 2 == 0:
        return (numbers[n // 2 - 1] + numbers[n // 2]) / 2
    else:
        return numbers[n // 2]

def calculate_mode(numbers):
    counts = {}
    for num in numbers:
        if num in counts:
            counts[num] += 1
        else:
            counts[num] = 1
    return max(counts, key=counts.get)

numbers = [4, 6, 4, 7, 4, 5, 6, 4, 7, 8, 5, 4]
mean = calculate_mean(numbers)
median = calculate_median(numbers)
mode = calculate_mode(numbers)
print(f"Mean: {mean}, Median: {median}, Mode: {mode}")

#Mean: 5.333333333333333, Median: 5.0, Mode: 4

  • Функция calculate_meanнаходит среднее значение путем деления суммы чисел на длину списка.
  • Функция calculate_medianсортирует список и находит средний элемент (элементы) для вычисления медианы.
  • Функция calculate_modeиспользует словарь для подсчета вхождений каждого числа и находит число с наибольшим количеством.

from statistics import mean, median, mode

def calculate_mean_median_mode(numbers):
    return mean(numbers), median(numbers), mode(numbers)

numbers = [4, 6, 4, 7, 4, 5, 6, 4, 7, 8, 5, 4]
mean, median, mode = calculate_mean_median_mode(numbers)
print(f"Mean: {mean}, Median: {median}, Mode: {mode}")

  • Функция calculate_mean_median_modeвозвращает среднее значение, медиану и моду в виде кортежа.

from statistics import mean, median, mode
from typing import List, Tuple

def calculate_mean_median_mode(numbers: List[float]) -> Tuple[float, float, float]:
    return mean(numbers), median(numbers), mode(numbers)

def main():
    numbers = [4, 6, 4, 7, 4, 5, 6, 4, 7, 8, 5, 4]
    mean_val, median_val, mode_val = calculate_mean_median_mode(numbers)
    print(f"Mean: {mean_val}, Median: {median_val}, Mode: {mode_val}")

if __name__ == "__main__":
    main()

  • Функция использует statisticsмодуль для вычисления среднего значения, медианы и моды.
  • Код организован в mainфункцию, которая вызывается при выполнении скрипта.

Новичок:

def merge_sorted_lists(list1, list2):
    result = []
    i = j = 0
    while i < len(list1) and j < len(list2):
        if list1[i] < list2[j]:
            result.append(list1[i])
            i += 1
        else:
            result.append(list2[j])
            j += 1
    result.extend(list1[i:])
    result.extend(list2[j:])
    return result

list1 = [1, 3, 5, 7]
list2 = [2, 4, 6, 8]
merged_list = merge_sorted_lists(list1, list2)
print(merged_list)

  • Функция использует два указателя (i и j) для перебора двух входных списков и сравнения элементов для построения объединенного списка.
  • Остальные элементы из любого списка добавляются к результату.

from heapq import merge
from typing import List

def merge_sorted_lists(list1: List[int], list2: List[int]) -> List[int]:
    return list(merge(list1, list2))

def main():
    list1 = [1, 3, 5, 7]
    list2 = [2, 4, 6, 8]
    merged_list = merge_sorted_lists(list1, list2)
    print(merged_list)

if __name__ == "__main__":
    main()

  • Аннотации типов включены для входных параметров и возвращаемого типа.
  • Код организован в mainфункцию, которая вызывается при выполнении скрипта.

Новичок:

def factorial(n):
    if n == 0:
        return 1
    return n * factorial(n - 1)

number = 5
result = factorial(number)
print(f"The factorial of {number} is {result}.")
#The factorial of 5 is 120.

  • Функция включает в себя базовый случай, когда nзначение равно нулю, возвращая 1.
  • В рекурсивном случае факториал вычисляется путем умножения nна факториал n - 1.

from functools import lru_cache
from typing import Optional

@lru_cache(maxsize=None)
def factorial(n: int) -> Optional[int]:
    if n < 0:
        print("Error: Factorial is not defined for negative numbers.")
        return None
    if n == 0:
        return 1
    return n * factorial(n - 1)

def main():
    number = 5
    result = factorial(number)
    if result is not None:
        print(f"The factorial of {number} is {result}.")
    else:
        print("Could not calculate factorial.")

if __name__ == "__main__":
    main()

  • Декоратор @lru_cacheиспользуется для запоминания функции факториала, кэширования промежуточных результатов для повышения производительности.
  • Функция проверяет отрицательные входные значения и выдает сообщение об ошибке для недопустимых входных данных.
  • Код использует mainфункцию для организации кода и для обработки возможных случаев, когда факториал не может быть вычислен.

Новичок:

import pandas as pd

def load_csv(file_path):
    return pd.read_csv(file_path)

file_path = "data.csv"
df = load_csv(file_path)
print(df.head())

  • Определяет функцию load_csvдля загрузки CSV-файла в DataFrame с использованием read_csvметода изpandas
  • Печатает первые несколько строк DataFrame, используя headметод

import pandas as pd

def load_csv(file_path, use_cols=None, parse_dates=None):
    return pd.read_csv(file_path, usecols=use_cols, parse_dates=parse_dates)

file_path = "data.csv"
selected_columns = ['column1', 'column3']
date_columns = ['date_column']
df = load_csv(file_path, use_cols=selected_columns, parse_dates=date_columns)
print(df.head())

  • Определяет функцию load_csvс необязательными параметрами use_colsи parse_datesдля выбора столбцов и столбцов даты синтаксического анализа соответственно.
  • Загружает указанные столбцы из CSV-файла, анализируя столбцы даты как объекты даты и времени.
  • Печатает первые несколько строк DataFrame

def max_product(arr):
    max_product = float('-inf')
    for i in range(len(arr)):
        for j in range(i + 1, len(arr)):
            product = arr[i] * arr[j]
            if product > max_product:
                max_product = product
    return max_product

arr = [1, 3, 5, 2, 6, 4]
max_product_result = max_product(arr)
print("Maximum product of two integers:", max_product_result)
#30

  • Функция использует вложенные циклы для рассмотрения всех возможных пар целых чисел в массиве.
  • Для каждой пары рассчитывается продукт, и соответственно обновляется максимальное значение продукта.

from typing import List

def max_product(arr: List[int]) -> int:
    arr.sort(reverse=True)
    return arr[0] * arr[1]

def main():
    arr = [1, 3, 5, 2, 6, 4]
    max_product_result = max_product(arr)
    print("Maximum product of two integers:", max_product_result)

if __name__ == "__main__":
    main()

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

from typing import List
from heapq import nlargest

def max_product(arr: List[int]) -> int:
    largest_nums = nlargest(2, arr)
    return largest_nums[0] * largest_nums[1]

def main():
    arr = [1, 3, 5, 2, 6, 4]
    max_product_result = max_product(arr)
    print("Maximum product of two integers:", max_product_result)

if __name__ == "__main__":
    main()

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

Новичок:

def binary_search(arr, target):
    low, high = 0, len(arr) - 1
    while low <= high:
        mid = (low + high) // 2
        if arr[mid] == target:
            return mid
        elif arr[mid] < target:
            low = mid + 1
        else:
            high = mid - 1
    return -1

arr = [1, 2, 4, 5, 6, 7, 9, 10]
target = 7
index = binary_search(arr, target)
print(f"Index of {target}:", index)

  • Функция использует whileцикл для многократного сужения диапазона поиска на основе значения среднего элемента.
  • Если целевое значение найдено, функция возвращает индекс среднего элемента; в противном случае возвращается -1.

from typing import List
from bisect import bisect_left

def binary_search(arr: List[int], target: int) -> int:
    index = bisect_left(arr, target)
    return index if index != len(arr) and arr[index] == target else -1

def main():
    arr = [1, 2, 4, 5, 6, 7, 9, 10]
    target = 7
    index = binary_search(arr, target)
    print(f"Index of {target}:", index)

if __name__ == "__main__":
    main()

  • Функция проверяет, существует ли целевое значение по найденному индексу, и возвращает индекс, если он соответствует целевому; в противном случае возвращается -1.
  • Код организован в mainфункцию, которая вызывается при выполнении скрипта.

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

Использованная литература:

  1. Официальная документация Python.org:
    Ссылка:https://docs.python.org/3/tutorial/index.html
  2. Курс Codecademy по Python:
    Ссылка:https://www.codecademy.com/learn/learn-python-3
  3. Python от Coursera для всех:
    Ссылка:https://www.coursera.org/specializations/python
  4. Класс Google Python:
    Ссылка:https://developers.google.com/edu/python
  5. LeetCode:
    Ссылка:https://leetcode.com
  6. Хакер Ранг:
    Ссылка:https://www.hackerrank.com/domains/tutorials/10-days-of-python
  7. Кодварс:
    Ссылка:https://www.codewars.com
  8. Переполнение стека:
    Ссылка:https://stackoverflow.com/questions/tagged/python
  9. Сообщество Python Reddit (r/Python):
    Ссылка:https://www.reddit.com/r/Python/
  10. Сообщество Python Discord:
    Ссылка:https://pythondiscord.com

Спасибо, что являетесь частью нашего сообщества! Перед тем, как ты уйдешь:

  • Хлопайте за историю и подписывайтесь на автора
  • Смотрите больше контента в публикации Level Up Coding
  • Бесплатный курс собеседования по программированию ⇒ Посмотреть курс
  • Подписывайтесь на нас: Твиттер | Линкедин | Новостная рассылка