这两天后台收到一些读者朋友的消息,问我有没有字符串的实战项目,我仔细思考了一下,觉得对于入门的朋友来说,不仅需要熟悉字符串的实战项目,还应该掌握Python的其他两种数据类型——列表和字典。今天我就给大家介绍两个关于Python基本数据类型的实战项目。
1.字符串趣味实战
题目:替换1-20内的数字,3的倍数和5的倍数用不同的数字代替。列出1到20的数字,若是3的倍数就用apple代替,若是5的倍数就用orange代替,若既是3的倍数又是5的倍数就用appleorange代替。
代码思路:
第一种普通解法,循环1-20,然后用多个if/else进行判断:
def replace_num(i):
ifi%3 ==0andi%5 ==0:
return"banana"
ifi%3 ==0:
return'apple'
ifi%5 ==0:
return'orange'
else:
returni
fori in range(1,20):
print(replace_num(i))
第二种牛逼解法:巧妙的利用列表切片
'apple'[i%3*len('apple')::]+'orange'[i%5*len('orange')::]ori
先说一下这道题的这种解法,犹如天外有天,令人拍案叫绝!
慢动作分解1:
print ('apple'[1::])
>>'pple'表示从第2个位置开始切片
慢动作分解2:
既然明白了上面的,来一个稍微复杂一点的
>>print ('apple'[1*5::])
为空
为啥因为1*5是5,也就是要从第6个字符开始,apple一共就5个字符,所以输出为空
慢动作分解3:
foriinrange(1,10):
print ('apple'[i%3::])
>>
pple
ple
apple
pple
ple
apple
pple
ple
apple
会发现只有3的倍数的地方会出现完整的apple,其他地方都是残缺,但是我们怎么把非3的倍数的地方变成空呢,简单乘以一个偏移量,这招对3的倍数没有任何影响,但是对于其他的非3的倍数有很大的影响。
慢动作分解4:
foriinrange(1,10):
print ('apple'[i%3*len('apple')::])
>>
apple
apple
apple
这个时候虽然把非3的过滤掉了,但是我们要输出数字啊,怎么办呢?这里又用了一个非常巧妙的or for i in range(1,20):print(‘apple’[i%3*len(‘apple’)::]ori)
这道题的技巧性非常高,而且很巧妙,希望零基础的同学仔细看明白每一步!
2. 列表、字典——综合实战应用
题目:寻找班级名字最长的人
现有一字符串人名:
names=(' Kunpen Ji, Li XIAO, Caron Li, Donl SHI, Ji ZHAO,Fia YUAN Y, Weue
DING, Xiu XU, Haiying WANG, Hai LIN,Jey JIANG, Joson WANG E, Aiyang ZHANG,Hay
MENG, Jak ZHANG E, Chang Zhang, Coro ZHANG'
)
需要实现下面3个要求:
(1):排序,按照名字A-Z排序
(2):找出里面姓“ZHANG”的人数
(3):找出名字里面最长的人
代码思路:
分析问题1:
首先我们要做的是对字符串进行分割去掉‘,’,然后就变成了一个长的列表,最后对列表进行排序(注意名字前后有多余空格去掉),第一个问题就解决了。
defsort_names(names):
return(sorted([name.strip()fornameinnames.split(',')]))
分析问题2:
我们需要找出姓“ZHANG”,因为名字里面有英文名字和中文名字,有的后面还跟E/Y,所以我们先定义一个函数,从分割后的新名字列表取出每一个名字,然后解析、翻转,用推导列表形成一个新的名字列表,然后再用字符串里的.startswitch(‘ZHANG’)取出符合的名字。
defget_chinese_names(names):
chinese_names=[]
fornameinsort_names(names):
iflen(name)>=2:
first_name=name.split()[0].capitalize()
last_name=name.split()[1].capitalize()
chinese_names.append(last_name+' '+first_name)
else:
chinese_names.append(name)
list_temp = []
foriinchinese_names:
ifi.startswith('Zhang'):
list_temp.append(i)
print("姓'ZHANG'的有%s个,分别是:%s"% (len(list_temp), list_temp))
returnchinese_names
分析问题3:
找出名字里面字符串最长的人,我们先定义一个函数,然后从从问题1形成的新列表中取出每一个名字,然后用max方法,用推导列表取出符合的名字。
deflongest_name(names):
long_names = []
fornameinsort_names(names):
iflen(name) == max(len(name)fornameinsort_names(names)):
long_names.append(name)
print("名字最长的有%s个,分别是:%s"% (len(long_names), long_names))
returnlong_names
完整代码:
names = ('Kunpen Ji, Li XIAO, Caron Li,'
'Dongjian SHI, Ji ZHAO, Fia YUAN Y,'
'Wenxue DING, Xiu XU, Haiying WANG, Hai LIN,'
'Jey JIANG, Joson WANG E,'
'Aiyang ZHANG, Haiying MENG,'
'Jack ZHANG E, Chang Zhang, Coron ZHANG')
defsort_names(names):
names_list = sorted([name.strip()fornameinnames.split(',')])
returnnames_list
defget_chinese_names(names):
chinese_names=[]
fornameinsort_names(names):
iflen(name)>=2:
first_name=name.split()[0].capitalize()
last_name=name.split()[1].capitalize()
chinese_names.append(last_name+' '+first_name)
else:
chinese_names.append(name)
list_temp = []
foriinchinese_names:
ifi.startswith('Zhang'):
list_temp.append(i)
print("姓'ZHANG'的有%s个,分别是:%s"% (len(list_temp), list_temp))
returnchinese_names
deflongest_name(names):
long_names = []
fornameinsort_names(names):
iflen(name) == max(len(name)fornameinsort_names(names)):
long_names.append(name)
print("名字最长的有%s个,分别是:%s"% (len(long_names), long_names))
returnlong_names
print(sort_names(names))
get_chinese_names(names)
longest_name(names)
今天给大家介绍的这两个实战项目,都非常经典,希望Python入门的朋友能好好看看。最近也刚好有点时间,准备写一写Python入门的一些实战项目,大家觉得怎么样呢?