在实际项目或者面试中会遇到一些常用的python小技巧,其实就是所谓的内置模块,方便了开发。
s = 'ASDFGH' print(s[-1::-1]) print(s[::-1])
HGFDSA HGFDSA
data = 'my name is tom' print(data.title()) print(data)
My Name Is Tom my name is tom
data = 'aaasssssaafffeffgrtgssffg' print(''.join(set(data)))
sertfga
data = 'aaasssssaafffeffgrtgssffg' ret = [] for item in data: if ret.count(item) == 0: ret.append(item) print(''.join(ret))
asfegrt
data = 'aaasssssaafffeffgrtgssffg' data_list = list(data) lists = list(set(data_list)) print(lists) lists.sort(key=data_list.index) print(lists) print(''.join(lists))
['s', 'f', 'g', 'a', 'e', 'r', 't'] ['a', 's', 'f', 'e', 'g', 'r', 't'] asfegrt
data = 'hello, everyone, world\nhello, everyone, world' print(data.split(',')) # 以换行符为分割,默认不显示换行符 print(data.splitlines()) print(data.splitlines(True))
['hello', ' everyone', ' world\nhello', ' everyone', ' world'] ['hello, everyone, world', 'hello, everyone, world'] ['hello, everyone, world\n', 'hello, everyone, world']
import os path = os.path.join(os.path.dirname(__file__), 'test.text') # 分割文件后缀名 print(os.path.splitext(path)) # 以系统平台分割 print(path.split(os.sep))
('/home/ts/flask_study/python常用技巧/test', '.text') ['', 'home', 'ts', 'flask_study', 'python常用技巧', 'test.text']
l = ['my', 'name', 'is', 'tom'] print(' '.join(l))
my name is tom
words = [ "look", "into", "my", "eyes", "look", "into", "my", "eyes", "the", "eyes", "the", "eyes", "the", "eyes", "the", "eyes", "my", "eyes", "you're", "under", "my", "eyes", "you're", "under" ] # 使用collection的counter from collections import Counter ret = Counter(words) print(ret) # 次数出现最多的前三个 print(ret.most_common(3)) # 查看ret的所有的数量 print(sum(ret.values())) # 列表推导式/列表生成式 ret = [(item,words.count(item)) for item in words] print(set(ret))
Counter({'eyes': 8, 'my': 4, 'the': 4, 'look': 2, 'into': 2, "you're": 2, 'under': 2}) [('eyes', 8), ('my', 4), ('the', 4)] 24 {("you're", 2), ('look', 2), ('my', 4), ('into', 2), ('eyes', 8), ('under', 2), ('the', 4)}
dict_1 = {'apple': 9, 'banana': 6} dict_2 = {'grape': 4, 'orange': 8} # 将字典解包成对应元素并进行合成 combined_dict = {**dict_1, **dict_2} print(combined_dict) # 使用自带的update print(dict_1.update(dict_2)) print(dict_1) # 并集 print(dict(dict_1.items() | dict_2.items())) # 交集,只显示最后 print(dict(dict_1.items() & dict_2.items()))
{'apple': 9, 'banana': 6, 'grape': 4, 'orange': 8} None {'apple': 9, 'banana': 6, 'grape': 4, 'orange': 8} {'banana': 6, 'orange': 8, 'apple': 9, 'grape': 4} {'grape': 4, 'orange': 8}
一个列表中有多个列表嵌套。
from iteration_utilities import deepflatten l = [[1,2,3],[4,[5],[6,7]],[8,[9,[10]]]] print(list(deepflatten(l, depth=3)))
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
l = [[1,2,3],[4,[5],[6,7]],[8,[9,[10]]]] def unfold_list(list_data): for item in list_data: if isinstance(item, list): yield from unfold_list(item) else: yield item print(list(unfold_list(l)))
[1, 2, 3, 4, 5, 6, 7, 8, 9, 10]
l1 = [1,2,3,4] l2 = [2,2,1,3] l3 = [1,2,3,3] def unique(l): return not len(l) == len(set(l)) def unique2(l): for item in l: if l.count(item) > 1: return True return False import time start = time.time() print(unique(l1)) print(unique(l2)) print(unique(l3)) print(time.time() - start) start = time.time() print(unique2(l1)) print(unique2(l2)) print(unique2(l3)) print(time.time() - start)
False True True 2.2172927856445312e-05 False True True 6.67572021484375e-06
array = [['a', 'b'], ['c', 'd'], ['e', 'f']] print(*array) print(list(zip(*array)))
['a', 'b'] ['c', 'd'] ['e', 'f'] [('a', 'c', 'e'), ('b', 'd', 'f')]
l1 = [1,2,3,4] l2 = [2,2,1,3,5] print(set(l1).difference(set(l2))) print(set(l2).difference(set(l1))) print(set(l1).difference(set(l2)) | set(l2).difference(set(l1)))
{4} {5} {4, 5}
l1 = ['A','B','C','D'] l2 = [2,2,1,3] print(dict(zip(l1,l2)))
{'A': 2, 'B': 2, 'C': 1, 'D': 3}
d = {'apple': 9, 'grape': 4, 'banana': 6, 'orange': 8} # 以键排序 print(dict(sorted(d.items(), key=lambda d:d[0]))) # 以值排序 print(dict(sorted(d.items(), key=lambda d:d[1]))) import operator # 以键排序 # operator.itemgetter获取第一个下标的元素 print(dict(sorted(d.items(), key=operator.itemgetter(0)))) # 以值排序 print(dict(sorted(d.items(), key=operator.itemgetter(1))))
{'apple': 9, 'banana': 6, 'grape': 4, 'orange': 8} {'grape': 4, 'banana': 6, 'orange': 8, 'apple': 9} {'apple': 9, 'banana': 6, 'grape': 4, 'orange': 8} {'grape': 4, 'banana': 6, 'orange': 8, 'apple': 9}
list1 = [20, 30, 50, 70, 90] def max_index(list_test): return max(range(len(list_test)), key = list_test.__getitem__) def min_index(list_test): return min(range(len(list_test)), key = list_test.__getitem__) print(max_index(list1)) print(min_index(list1))
4 0