Полезные фрагменты или 30 секунд кода на Python

МЕНЮ


Искусственный интеллект
Поиск
Регистрация на сайте
Помощь проекту

ТЕМЫ


Новости ИИРазработка ИИВнедрение ИИРабота разума и сознаниеМодель мозгаРобототехника, БПЛАТрансгуманизмОбработка текстаТеория эволюцииДополненная реальностьЖелезоКиберугрозыНаучный мирИТ индустрияРазработка ПОТеория информацииМатематикаЦифровая экономика

Авторизация



RSS


RSS новости


2019-05-10 22:00

разработка по

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

1) Chunk

Разбиение массива на меньшие списки указанного размера. Для создания списка желаемого размера используется range, а заполняется список при помощи map.

Python

1

2

3

4

5

6

7

frommathimportceil

defchunk(arr,size):

returnlist(

map(lambdax:arr[x*size:x*size+size],

list(range(0,ceil(len(arr)/size)))))

Пример:

Python

1

chunk([1,2,3,4,5],2)# [[1,2],[3,4],5]

2) Compact

Удаление ложных значений (False, None, 0, и «») из списка при помощи filter().

Python

1

2

defcompact(arr):

returnlist(filter(lambdax:bool(x),arr))

Пример:

Python

1

compact([0,1,False,2,'',3,'a','s',34])# [ 1, 2, 3, 'a', 's', 34 ]

3) Count_by

Этот кусок кода на Python группирует элементы списка и возвращает количество элементов в каждой группе.

Используется map() для сопоставления значений списка со значениями функции. За каждую итерацию счетчик увеличивается.

Python

1

2

3

4

5

6

defcount_by(arr,fn=lambdax:x):

key={}

forel inmap(fn,arr):

key[el]=0ifel notinkey elsekey[el]

key[el]+=1

returnkey

Пример:

Python

1

2

3

frommathimportfloor

count_by([6.1,4.2,6.3],floor)# {4: 1, 6: 2}

count_by(['one','two','three'],len)# {3: 2, 5: 1}

4) Сount_occurences

Считает количество повторений заданного значения.

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

Python

1

2

3

4

5

6

7

fromfunctoolsimportreduce

defcount_occurences(arr,val):

returnreduce(

(lambdax,y:x+1ify==val andtype(y)==type(val)elsex+0),

arr)

Пример:

Python

1

count_occurrences([1,1,2,1,2,3],1)# 3

5) deep_flatten

Выравнивание списка при помощи рекурсии. Используется list.extend() вместе с пустым массивом (result) и функция spread для сглаживания каждого элемента списка.

Python

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

defspread(arg):

ret=[]

foriinarg:

ifisinstance(i,list):

ret.extend(i)

else:

ret.append(i)

returnret

defdeep_flatten(arr):

result=[]

result.extend(

spread(list(map(lambdax:deep_flatten(x)iftype(x)==listelsex,arr))))

returnresult

Пример:

Python

1

deep_flatten([1,[2],[[3],4],5])# [1,2,3,4,5]

6) difference

Возвращает разницу между двумя массивами. Создает set из b и сохраняет только те значения, которые не содержатся в b.

Python

1

2

3

defdifference(a,b):

b=set(b)

return[item foritem inaifitem notinb]

Пример:

Python

1

difference([1,2,3],[1,2,4])# [3]

7) difference_by

Возвращает разницу между двумя списками, после применения функции к обоим спискам. Создает set, применяя fn к каждому элементу в b, затем использует сочетание fn и a, чтобы сохранить только значения, не содержащиеся в ранее созданном set.

Python

1

2

3

defdifference_by(a,b,fn):

b=set(map(fn,b))

return[item foritem inaiffn(item)notinb]

Пример:

Python

1

2

3

frommathimportfloor

difference_by([2.1,1.2],[2.3,3.4],floor)# [1.2]

difference_by([{'x':2},{'x':1}],[{'x':1}],lambdav:v['x'])# [ { x: 2 } ]

8) insertion_sort

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

Python

1

2

3

4

5

6

7

8

9

definsertion_sort(arr):

foriinrange(1,len(arr)):

key=arr[i]

j=i-1

whilej>=0andkey<arr[j]:

arr[j+1]=arr[j]

j-=1

arr[j+1]=key

Пример:

Python

1

2

3

arr=[7,4,9,2,6,3]

insertionsort(arr)

print('Sorted %s' %arr)# sorted [2, 3, 4, 6, 7, 9]

9) shuffle

Рандомизирует порядок значений списка, возвращая новый список. Использует алгоритм Фишера-Йейтса для изменения порядка элементов списка.

Python

1

2

3

4

5

6

7

8

9

10

11

12

fromcopyimportdeepcopy

fromrandomimportrandint

defshuffle(arr):

temp_arr=deepcopy(arr)

m=len(temp_arr)

while(m):

m-=1

i=randint(0,m)

temp_arr[m],temp_arr[i]=temp_arr[i],temp_arr[m]

returntemp_arr

Пример:

Python

1

2

foo=[1,2,3]

shuffle(foo)# [2,3,1] , foo = [1,2,3]

10) spread

Заимствует [].concat(…arr) из Javascript. Сглаживает список (не глубоко) и возвращает новый список.

Python

1

2

3

4

5

6

7

8

defspread(arg):

ret=[]

foriinarg:

ifisinstance(i,list):

ret.extend(i)

else:

ret.append(i)

returnret

Пример:

Python

1

spread([1,2,3,[4,5,6],[7],8,9])# [1,2,3,4,5,6,7,8,9]

11) zip

Создает список элементов, группируя их на основании позиции в оригинальном списке. Используется max вместе с list comprehension для получения длины самого длинного списка в аргументах. В качестве длины lists используется значение fill_value. По умолчанию значение fill_value равно None.

Python

1

2

3

4

5

6

7

8

defzip(*args,fillvalue=None):

max_length=max([len(arr)forarr inargs])

result=[]

foriinrange(max_length):

result.append([

args[k][i]ifi<len(args[k])elseNoneforkinrange(len(args))

])

returnresult

Пример:

Python

1

2

3

zip(['a','b'],[1,2],[True,False])# [['a', 1, True], ['b', 2, False]]

zip(['a'],[1,2],[True,False])# [['a', 1, True], [None, 2, False]]

zip(['a'],[1,2],[True,False],fill_value='_')# [['a', 1, True], ['_', 2, False]]

Продолжаем список фрагментов кода на Python реализацией некоторых математических функций.

1) average

Возвращает среднее от двух и более чисел. Происходит деление на len(args) суммы всех элементов args. Второй аргумент 0.0 используется для операций с плавающей точкой в python2.

Python

1

2

defaverage(*args):

returnsum(args,0.0)/len(args)

Пример:

Python

1

2

average(*[1,2,3])# 2.0

average(1,2,3)# 2.0

2) factorial

Вычисляется факториал числа.

Используется рекурсия. Если num меньше или равно 1, возвращается 1, а иначе – произведение num и factorial из num — 1. Сработает исключение, если num будет отрицательным или числом с плавающей точкой.

Python

1

2

3

4

5

deffactorial(num):

ifnot((num>=0)&(num%1==0)):

raiseException(

f"Number( {num} ) can't be floating point or negative ")

return1ifnum==0elsenum*factorial(num-1)

Пример:

Python

1

factorial(6)# 720

3) gcd

Вычисляется наибольший общий делитель между двумя или более числами / списками.

В helperGcdfunction используется рекурсия. Базовый случай, когда y равно 0. В этом случае возвращается x. В противном случае возвращается y и остаток от деления x/y. Используется reduce из встроенного модуля functools.

Python

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

fromfunctoolsimportreduce

defspread(arg):

ret=[]

foriinarg:

ifisinstance(i,list):

ret.extend(i)

else:

ret.append(i)

returnret

defgcd(*args):

numbers=[]

numbers.extend(spread(list(args)))

def_gcd(x,y):

returnxifnotyelsegcd(y,x%y)

returnreduce((lambdax,y:_gcd(x,y)),numbers)

Пример:

Python

1

gcd(8,36)# 4

4) lcm

Возвращает наименьшее общее кратное из двух или более чисел. Используется формула greatest common divisor (GCD) и lcm(x,y) = x * y / gcd(x,y) для определения наименьшего общего кратного. Формула GCD использует рекурсию, а также reduce из встроенного модуля functools.

Python

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

fromfunctoolsimportreduce

defspread(arg):

ret=[]

foriinarg:

ifisinstance(i,list):

ret.extend(i)

else:

ret.append(i)

returnret

deflcm(*args):

numbers=[]

numbers.extend(spread(list(args)))

def_gcd(x,y):

returnxifnotyelse_gcd(y,x%y)

def_lcm(x,y):

returnx*y/_gcd(x,y)

returnreduce((lambdax,y:_lcm(x,y)),numbers)

Пример:

Python

1

2

lcm(12,7)# 84

lcm([1,3,4],5)# 60

5) max_n

Возвращает n максимальных элементов из списка. Если n больше или равно длине списка, возвращается исходный список, отсортированный в порядке убывания.

Используется list.sort() в сочетании с функцией deepcopy из встроенного модуля copy, чтобы создать клон списка и отсортировать его в порядке возрастания, а затем list.reverse(), чтобы отсортировать по убыванию. Для получения указанного количества элементов используется [:n]. Второй аргумент n опускается, чтобы получить одноэлементный массив.

Python

1

2

3

4

5

6

7

8

fromcopyimportdeepcopy

defmax_n(arr,n=1):

numbers=deepcopy(arr)

numbers.sort()

numbers.reverse()

returnnumbers[:n]

Пример:

Python

1

2

max_n([1,2,3])# [3]

max_n([1,2,3],2)# [3,2]

6) min_n

Возвращает n минимальных элементов из списка. Если n больше или равно длине списка, возвращается исходный список, отсортированный в порядке возрастания.

Используется list.sort() в сочетании с функцией deepcopy из встроенного модуля copy, чтобы создать клон списка и отсортировать его в порядке возрастания, а затем list.reverse(), чтобы отсортировать по убыванию. Для получения указанного количества элементов используется [:n]. Второй аргумент n опускается, чтобы получить одноэлементный массив.

Python

1

2

3

4

5

6

fromcopyimportdeepcopy

defmin_n(arr,n=1):

numbers=deepcopy(arr)

numbers.sort()

returnnumbers[:n]

Пример:

Python

1

2

min_n([1,2,3])# [1]

min_n([1,2,3],2)# [1,2]

Последние фрагменты кода на Python на тему работы со строками.

1) byte_size

Возвращает длину строки в байтах. Заданная строка кодируется utf-8, а потом находится ее длина.

Python

1

2

defbyte_size(string):

return(len(string.encode('utf-8')))

Пример:

Python

1

2

byte_size('?')# 4

byte_size('Hello World')# 11

2) capitalize

Делает первую букву строки заглавной.

Делает первую букву строки заглавной, а затем добавляет ее к остальной части строки. Параметр lower_rest опускается, чтобы сохранить остальную часть строки нетронутой, или для нее устанавливается значение true, чтобы преобразовать в нижний регистр.

Python

1

2

defcapitalize(string,lower_rest=False):

returnstring[:1].upper()+(string[1:].lower()iflower_rest elsestring[1:])

Пример:

Python

1

2

capitalize('fooBar')# 'FooBar'

capitalize('fooBar',True)# 'Foobar'

3) capitalize_every_word

Делает первую букву заглавной каждого слова строки. Используется str.title.

Python

1

2

defcapitalize_every_word(string):

returnstring.title()

Пример:

Python

1

capitalize_every_word('hello world!')# 'Hello World!'

4) count_vowels

Возвращает number гласных в string. При помощи регулярного выражения, вычисляется количество гласных (A, E, I, O, U) в строке.

Python

1

2

3

4

importre

defcount_vowels(str):

returnlen(len(re.findall(r'[aeiou]',str,re.IGNORECASE)))

Пример:

Python

1

2

count_vowels('foobar')# 3

count_vowels('gym')# 0

5) decapitalize

Делает первую букву строки строчной, а затем добавляет ее к остальной части строки. Параметр upper_rest опускается, чтобы сохранить остальную часть строки нетронутой, или для нее устанавливается значение true, чтобы преобразовать в верхний регистр.

Python

1

2

defdecapitalize(string,upper_rest=False):

returnstr[:1].lower()+(str[1:].upper()ifupper_rest elsestr[1:])

Пример:

Python

1

2

decapitalize('FooBar')# 'fooBar'

decapitalize('FooBar',True)# 'fOOBAR'

6) is_lower_case

Преобразует строку в верхний регистр при помощи метода str.lower() и сравнивает ее с оригиналом.

Python

1

2

defis_lower_case(str):

returnstr==str.lower()

Пример:

Python

1

2

3

is_lower_case('abc')# True

is_lower_case('[email protected]$')# True

is_lower_case('Ab4')# False

7) is_upper_case

Преобразует строку в нижний регистр при помощи метода str.upper() и сравнивает ее с оригиналом.

Python

1

2

defis_upper_case(str):

returnstr==str.upper()

Пример:

Python

1

2

3

is_upper_case('ABC')# True

is_upper_case('[email protected]$')# True

is_upper_case('aB4')# False

8) palindrome

Возвращает True если строка является палиндромом, иначе False.

Преобразует строку str.lower() и использует re.sub  для удаления не алфавитно-цифровых символов. Потом сравнивает новую строку с реверсивной строкой.

Python

1

2

3

4

defpalindrome(string):

fromreimportsub

s=sub('[W_]','',string.lower())

returns==s[::-1]

Пример:

Python

1

palindrome('taco cat')# True

Оригинал


Источник: github.com

Комментарии: