前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >2个Python入门级的实战项目

2个Python入门级的实战项目

作者头像
stormwen
发布2019-08-09 16:36:28
4200
发布2019-08-09 16:36:28
举报
文章被收录于专栏:公众号:googpy

这两天后台收到一些读者朋友的消息,问我有没有字符串的实战项目,我仔细思考了一下,觉得对于入门的朋友来说,不仅需要熟悉字符串的实战项目,还应该掌握Python的其他两种数据类型——列表和字典。今天我就给大家介绍两个关于Python基本数据类型的实战项目。

1.字符串趣味实战

题目:替换1-20内的数字,3的倍数和5的倍数用不同的数字代替。列出1到20的数字,若是3的倍数就用apple代替,若是5的倍数就用orange代替,若既是3的倍数又是5的倍数就用appleorange代替。

代码思路:

第一种普通解法,循环1-20,然后用多个if/else进行判断:

代码语言:javascript
复制
def replace_num(i):
    if i%3 == 0 and i%5 ==0:
        return "banana"
    if i%3 ==0:
        return 'apple'
    if i%5 ==0:
        return 'orange'
    else:
        return i

for i in range(1,20):
      print(replace_num(i))

第二种牛逼解法:巧妙的利用列表切片

代码语言:javascript
复制
'apple'[i%3*len('apple')::]+'orange'[i%5*len('orange')::]or i

先说一下这道题的这种解法,犹如天外有天,令人拍案叫绝!

慢动作分解1:

代码语言:javascript
复制
print ('apple'[1::])
>>'pple' 表示从第2个位置开始切片

慢动作分解2:

代码语言:javascript
复制
既然明白了上面的,来一个稍微复杂一点的
>>print ('apple'[1*5::])

为空
为啥因为1*5是5,也就是要从第6个字符开始,apple一共就5个字符,所以输出为空

慢动作分解3:

代码语言:javascript
复制
for i in range(1,10):
print ('apple'[i%3::])
>>
pple
ple
apple
pple
ple
apple
pple
ple
apple

会发现只有3的倍数的地方会出现完整的apple,其他地方都是残缺,但是我们怎么把非3的倍数的地方变成空呢,简单乘以一个偏移量,这招对3的倍数没有任何影响,但是对于其他的非3的倍数有很大的影响。

慢动作分解4:

代码语言:javascript
复制
for i in range(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. 列表、字典——综合实战应用

题目:寻找班级名字最长的人

现有一字符串人名:

代码语言:javascript
复制
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:

首先我们要做的是对字符串进行分割去掉‘,’,然后就变成了一个长的列表,最后对列表进行排序(注意名字前后有多余空格去掉),第一个问题就解决了。

代码语言:javascript
复制
def sort_names(names):
return (sorted([name.strip()for name in names.split(',')]))

分析问题2:

我们需要找出姓“ZHANG”,因为名字里面有英文名字和中文名字,有的后面还跟E/Y,所以我们先定义一个函数,从分割后的新名字列表取出每一个名字,然后解析、翻转,用推导列表形成一个新的名字列表,然后再用字符串里的.startswitch(‘ZHANG’)取出符合的名字。

代码语言:javascript
复制
def get_chinese_names(names):
    chinese_names=[]
    for name in sort_names(names):
        if len(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 = []
    for i in chinese_names:
        if i.startswith('Zhang'):
            list_temp.append(i)
    print("姓'ZHANG'的有%s个,分别是:%s" % (len(list_temp), list_temp))
    return chinese_names

分析问题3:

找出名字里面字符串最长的人,我们先定义一个函数,然后从从问题1形成的新列表中取出每一个名字,然后用max方法,用推导列表取出符合的名字。

代码语言:javascript
复制
def longest_name(names):
    long_names = []
    for name in sort_names(names):
        if len(name) == max(len(name) for name in sort_names(names)):
            long_names.append(name)
    print("名字最长的有%s个,分别是:%s" % (len(long_names), long_names))
    return long_names

完整代码:

代码语言:javascript
复制
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')
def sort_names(names):
    names_list = sorted([name.strip()for name in names.split(',')])
    return names_list

def get_chinese_names(names):
    chinese_names=[]
    for name in sort_names(names):
        if len(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 = []
    for i in chinese_names:
        if i.startswith('Zhang'):
            list_temp.append(i)
    print("姓'ZHANG'的有%s个,分别是:%s" % (len(list_temp), list_temp))
    return chinese_names

def longest_name(names):
    long_names = []
    for name in sort_names(names):
        if len(name) == max(len(name) for name in sort_names(names)):
            long_names.append(name)
    print("名字最长的有%s个,分别是:%s" % (len(long_names), long_names))
    return long_names

print(sort_names(names))
get_chinese_names(names)
longest_name(names)

今天给大家介绍的这两个实战项目,都非常经典,希望Python入门的朋友能好好看看。最近也刚好有点时间,准备写一写Python入门的一些实战项目,大家觉得怎么样呢?

本文参与 腾讯云自媒体同步曝光计划,分享自微信公众号。
原始发表:2019-08-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 googpy 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档