1、判断字符list中是否有重复
思路:通过集合去重,然后对比list长度,重复返回False,不重复返回True
#检查是否有重复元素
def check_repeat(list):
return len(list)==len(set(list))
2、两个字符串每个字符出现次数均相等,顺序可以不同
counter方法可以统计字符出现次数
#检测两个字符串是否互为变位词(即互相颠倒字符顺序)
from collections import Counter
def counter_str(first,second):
return Counter(first)==Counter(second)
3、以字节为单位返回字符串长度
思路:字符串编码格式改为UTF-8,然后统计长度
#以字节为单位返回字符串长度
def byte_size(str):
return len(str.encode('utf-8')) #一个汉字占3个字节
4、重复打印字符串
思路:乘以n,实现多次的效果
#重复打印字符串N次 n=7 str='zhao' print(str*n)
5、字符串中每个词首字母大写
#首字母大写,字符串每个词进行首字母大写 s='count your awesome' print(s.title()) #字符串内每个词进行首字母大写
6、删除list中错误的数据
bool函数,错误的数就是FALSE,0,none,filter相当于迭代器,把list中的每个值传给bool方法
#以下方法使用fliter()删除列表中的错误值(如:false,none,0和"")
def compact(lst):
return list(filter(bool,lst))
print(compact([0,1,False,2,3,None,4,5]))
7、间隔数--转换二维数组
思路:通过解包函数,把array数组每个二维数组解包,重新组合
#间隔数--转换一个二维数组
array=[['a','b'],['c','d'],['e','f']]
transposed=list(zip(*array))
print(transposed) #[('a', 'c', 'e'), ('b', 'd', 'f')]
8、字符串列表转换为单个字符串,列表中的每个元素用逗号分隔
#字符串列表转换为单个字符串,列表中的每个元素用逗号分隔
hobbies=['your','jeans','swimming']
print(','.join(hobbies))
9、计算元音字母数
思路:通过正则匹配,然后统计得出数组的长度就是元音字母数
import re
def word_num(str):
return len(re.findall('[aeiou]',str)) #正则匹配,然后统计个数
10、字符串首字母转小写
#首字母恢复小写 ----给定字符串的第一个字母转为小写
def decapitalize(str):
return str[:1].lower()+str[1:]
11、多维数组变一维数组
#多维数组变一维数组
def spread(arg):
ret=[]
for i in arg:
if isinstance(i,list):
ret.extend(i)
else:
ret.append(i)
return ret
def deep_spread(lst):
rets=[]
rets.extend(spread(list(map(lambda x:deep_spread(x) if type(x)==list else x ,lst ))))
return rets
print(deep_spread([1,[3],[[3],4],5]))
12、找出两个数组中不同的字符
#差异--找出两个数组中不同的数
def difference(a,b):
set_a=set(a)
set_b=set(b)
comparison=set_b.symmetric_difference(set_a)
return list(comparison)
print(difference([3,4,5],[2,3,4]))
13、链式函数,以下方法可在一行中调用多个函数
def add(a,b):
return a+b
def substract(a,b):
return a-b
a,b=4,5
print((substract if a>b else add)(a,b)) #一行调用多个函数
14、合并两个字典
def merge_two_dicts(a,b): #第一种方法
c=a.copy()
c.update(b)
return c
def merge_dictionaries(a,b): #第二种方法
return {**a,**b}
a = { 'x' : 1, 'y' : 2}
b = { 'y' : 3, 'z' : 4}
print(merge_two_dicts(a, b))
print(merge_dictionaries(a,b))
15、两个列表变为字典
思路:解包函数
def to_dic(keys,values):
return dict(zip(keys,values))
print(to_dic([3,4,5],[6,7,8]))
16、枚举函数
list=['a','b','c','d','e']
for index,values in enumerate(list):
print("value:%s , index:%s "%(values,index))
17、try-else
#try else ---你可以将ELSE子句作为try/except块的一部分,如果没有抛出异常,则执行该子句
try:
2*3
except TypeError:
print('aaa')
else:
print('bbb')
18、找出列表中出现次数最多的元素
def most_frequent(list):
return max(set(list),key=list.count)
list=[1,2,3,4,1,2]
print(most_frequent(list))
19、没有if-else语句的简单计算器
#没有if-else语句的简单计算器
import operator
action={
"+":operator.add,
"-":operator.sub,
"/":operator.truediv,
"*":operator.mul,
"**":pow
}
print(action["+"](50,34))
来源:https://www.cnblogs.com/xiaokuangnvhai/p/11613139.html