22 сниппета на Python для повседневных задач

22 сниппета на Python для повседневных задач

Daniil Lebedev

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

1. Прием нескольких входных значений, разделенных пробелами

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

## Прием двух целых чисел в качестве входных данных
a,b = map(int,input().split())
print("a:",a)
print("b:",b)

## Прием списка в качестве входных данных
arr = list(map(int,input().split()))
print("Input List:",arr)

2. Одновременный доступ к индексу и значению

Одновременный доступ к индексу и значению в цикле позволяет получить встроенная функция enumerate():

arr = [2,4,6,3,8,10]

for index,value in enumerate(arr):
  print(f"At Index {index} The Value Is -> {value}")

'''Output
At Index 0 The Value Is -> 2
At Index 1 The Value Is -> 4
At Index 2 The Value Is -> 6
At Index 3 The Value Is -> 3
At Index 4 The Value Is -> 8
At Index 5 The Value Is -> 10
'''

3. Проверка использования памяти

Этот фрагмент используется для проверки использования памяти объекта:

import sys
a = 20
print(sys.getsizeof(a)) #28

4. Проверка существования файла

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

# Метод перебора
import os.path
from os import path

def check_for_file():
 print("File exists: ",path.exists("data.txt"))

if __name__=="__main__":
   check_for_file()
    
'''
File exists:  False
'''

5. Вывод уникального идентификатора переменной

Уникальный идентификатор переменной находится с помощью метода id(). Для этого нужно просто передать в метод имя переменной:

a = 20
name = 'Karl'
deci = 5.5

print(id(a))     # 2557830785936
print(id(name))  # 2557830785956
print(id(deci))  # 2557830785996

6. Вычисление времени выполнения в оболочке

Иногда важно знать время выполнения в оболочке или в блоке кода для получения лучшего алгоритма с минимальным количеством затраченного им времени:

# МЕТОД 1
import datetime
start = datetime.datetime.now()
"""
CODE
"""
print(datetime.datetime.now()-start)

# МЕТОД 2
import time
start_time = time.time()
main()
print(f"Total Time To Execute The Code is {(time.time() - start_time)}" )

# МЕТОД 3
import timeit
code = '''
## Фрагмент кода, чье время выполнения подлежит измерению
[2,6,3,6,7,1,5,72,1].sort()
'''
print(timeit.timeit(stmy = code,number = 1000))

7. Цепочка вызовов функций

В Python есть возможность вызывать несколько функций в одной строке:

def add(a,b):
  return a+b

def sub(a,b):
  return a-b

a,b = 9,6
print((sub if a > b else add)(a, b))

8. Перестановка значений

Быстрый способ поменять местами две переменные без использования дополнительной:

a,b = 5,7

# Метод 1
b,a = a,b

# Метод 2
def swap(a,b):
  return b,a
swap(a,b)

9. Калькулятор без if-else

Этот фрагмент кода показывает, как просто написать калькулятор без использования каких-либо условных операторов if-else:

import operator

action = {
  "+" : operator.add,
  "-" : operator.sub,
  "/" : operator.truediv,
  "*" : operator.mul,
  "**" : pow
}

print(action['*'](5, 5))    # 25

10. Обработка ошибок

В Python, как и в языках Java и C++, имеется способ обработки исключений с помощью блоков tryexcept и finally:

# Пример 1
try:  
    a = int(input("Enter a:"))    
    b = int(input("Enter b:"))    
    c = a/b  
    print(c)
except:  
    print("Can't divide with zero") 
    
# Пример 2
try:    
    #если файл не существует, будет выброшено исключение.     
    fileptr = open("file.txt","r")    
except IOError:    
    print("File not found")    
else:    
    print("The file opened successfully")    
    fileptr.close()

# Пример 3
try:
  fptr = open("data.txt",'r')
  try:
    fptr.write("Hello World!")
  finally:
    fptr.close()
    print("File Closed")
except:
  print("Error")

11. Проверка наличия анаграммы

Анаграмма — это слово, которое образуется путем перестановки букв другого слова, причем каждая буква используется только один раз.

def check_anagram(first_word, second_word):
  return sorted(first_word) == sorted(second_word)
  
print(check_anagram("silent", "listen"))   # True
print(check_anagram("ginger", "danger"))   # False

12. Проверка наличия подстрок в строке списка

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

addresses = [
  "12/45 Elm street",
  '34/56 Clark street',
  '56,77 maple street',
  '17/45 Elm street'

]
street = 'Elm street'
for i in addresses:
  if street in i:
    print(i)

'''output
12/45 Elm street
17/45 Elm street
'''

13. Форматирование строки

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

name = "Abhay"
age = 21

## МЕТОД 1: конкатенация
print("My name is "+name+", and I am "+str(age)+ " years old.")

## МЕТОД 2: форматированные строки (F-строки в Python 3+)
print(f"My name is {name}, and I am {age} years old")

## МЕТОД 3: join
print(''.join(["My name is ", name, ", and I am ", str(age), " years old"]))

## МЕТОД 4: оператор модуля
print("My name is %s, and I am %d years old." % (name, age))

## МЕТОД 5: format (Python 2 и 3)
print("My name is {}, and I am {} years old".format(name, age))Списки

14. Сортировка списка строк

Этот фрагмент кода пригодится, например при упорядочении всех имен студентов в списке:

list1 = ["Karl","Larry","Ana","Zack"]

# Метод 1: sort()
list1.sort()

# Метод 2: sorted()
sorted_list = sorted(list1)

# Метод 3: метод перебора 
size = len(list1)
for i in range(size): 
  for j in range(size): 
    if list1[i] < list1[j]: 
       temp = list1[i] 
       list1[i] = list1[j] 
       list1[j] = temp
print(list1)

15. Генератор списков с If и Else

А этот фрагмент кода будет очень полезен при проведении фильтрации структуры данных на основе некоторых условий:

## List Comprehension with if and else
["Divided by 5" if i%5=0 else i for i in range(1,20)]

### FizzBuzz Implementation Threw the same
['FizzBuzz' if i%3=0 and i%5=0 else 'Fizz' if i%3=0 else 'Buzz' if i%5=0 else i for i in range(1,20)]

'''output
[1, 2, 'Fizz', 4, 'Buzz', 'Fizz', 7, 8, 'Fizz', 'Buzz', 11, 'Fizz', 13, 14, 'FizzBuzz', 16, 17, 'Fizz', 19]
'''

16. Сложение элементов двух списков

Допустим, у вас есть два списка, которые надо объединить в один, суммировав их элементы. Это пригодится, например в таком сценарии:

maths = [59, 64, 75, 86]
physics = [78, 98, 56, 56]

# Метод перебора
list1 = [
  maths[0]+physics[0],
  maths[1]+physics[1],
  maths[2]+physics[2],
  maths[3]+physics[3]
]

# Генератор списков
list1 = [x + y for x,y in zip(maths,physics)]

# Использование методов map
import operator 
all_devices = list(map(operator.add, maths, physics))

# Использование библиотеки Numpy
import numpy as np
list1 = np.add(maths,physics)

'''Output
[137 162 131 142]
'''

17. Самые часто встречающиеся в списке

Этот метод возвращает элементы, появляющиеся в списке наиболее часто:

def most_frequent(nums):
  return max(set(nums), key = nums.count)

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

В этом фрагменте для нахождения квадрата каждого целого числа в заданном диапазоне прибегнем к помощи встроенной функции itertools:

# МЕТОД 1
from itertools import repeat

n = 5
squares = list(map(pow, range(1, n+1), repeat(2)))
print(squares)

# МЕТОД 2
n = 6
squares = [i**2 for i in range(1,n+1)]
print(squares)

"""Output
  [1, 4, 9, 16, 25]
"""

19. Поиск дублей

Эти фрагменты кода позволяют проверить, есть ли в списке повторяющиеся значения:

def has_duplicates(lst):
    return len(lst) ≠ len(set(lst))

x = [1,2,2,4,3,5]
y = [1,2,3,4,5]
has_duplicates(x) # True
has_duplicates(y) # False

20. Преобразование двух списков в словарь

Здесь используются следующие методы:

list1 = ['karl','lary','keera']
list2 = [28934,28935,28936]

# Метод 1: zip()
dictt0 = dict(zip(list1,list2))

# Метод 2: генераторы словарей
dictt1 = {key:value for key,value in zip(list1,list2)}

# Метод 3: использование цикла For (не рекомендуется)
tuples = zip(list1, list2) 
dictt2 = {} 
for key, value in tuples: 
  if key in dictt2: 
    pass
  else: 
    dictt2[key] = value
print(dictt0, dictt1, dictt2, sep = "\n")

21. Сортировка списка словарей

Бывают задачи, в которых требуется упорядочить список словарей, чтобы получить с помощью ключа отсортированный в определенном порядке список:

dict1 = [
    {"Name":"Karl",
     "Age":25},
     {"Name":"Lary",
     "Age":39},
     {"Name":"Nina",
     "Age":35}
]

## Использование sort()
dict1.sort(key=lambda item: item.get("Age"))

# Сортировка списка с помощью itemgetter
from operator import itemgetter
f = itemgetter('Name')
dict1.sort(key=f)

# Функция sorted для итерируемых элементов
dict1 = sorted(dict1, key=lambda item: item.get("Age"))

'''Output
[{'Age': 25, 'Name': 'Karl'},
 {'Age': 35, 'Name': 'Nina'},
 {'Age': 39, 'Name': 'Lary'}]
'''

22. Объединение двух словарей

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

basic_information = {"name":['karl','Lary'],"mobile":["0134567894","0123456789"]}
academic_information = {"grade":["A","B"]}
details = dict() ## Объединяет словари

## Метод генераторов словарей
details = {key: value for data in (basic_information, academic_information) for key,value in data.items()}
print(details)

## Распаковывание словарей
details = {**basic_information ,**academic_information}
print(details)

## Метод копирования и обновления
details = basic_information.copy()
details.update(academic_information)
print(details)

Оригинал на английском: Abhay Parashar22 Python Code Snippets for Everyday Problems

Report Page