Shing-gyl

导航

Python第五章实验报告

一、实验题目

Python第五章实例和实战作业

二、实验目的和要求

1.熟悉Pycharm的运行环境

2.学习并掌握Python的字符串及正则表达式

三、主要仪器设备

联想小新air15

硬件:AMD R7 5700U

软件:Windows11操作系统

四、实验内容

完成第五章实例01-10,5.7实战

利用Pycharm完成Python实验报告

实例01:使用字符串拼接输出一个关于程序员的笑话

代码如下:

#----------实例01:使用字符串拼接输出一个关于程序员的笑话----------#
programmer_1 = '程序员甲:搞IT太辛苦了,我想换行……怎么办?'
programmer_2 = '程序员乙:敲一下回车键'
print(programmer_1 + '\n' + programmer_2)

代码运行结果如下:

 

实例02:截取身份证号码中的出生日期

代码如下:

#----------实例02:截取身份证号码中的出生日期----------#
programmer_1 = '你知道我的生日吗?'       #程序员甲问程序员乙的台词
print('程序员甲说:',programmer_1)       #输出程序员甲的台词
programmer_2 = '输入你的身份证号码。'      #程序员乙的台词
print('程序员乙说:',programmer_2)       #输出程序员乙的台词
idcard = '123456199006277890'          #定义保存身份证号码的字符串
print('程序员甲说:',idcard)             #程序员甲说出身份证号码
birthday = idcard[6:10] + '' + idcard[10:12] + '' + idcard[12:14] + ''   #截取生日
print('程序员乙说:','你是' + birthday + '出生的,所以你的生日是' + birthday[5:])

代码运行结果如下:

 

实例03:输出被@的好友名称
代码如下:
#----------实例03:输出被@的好友名称----------#
str1 = '@明日科技 @扎克伯格 @俞敏洪'
list1 = str1.split(' ')     #用空格分割字符串
print('您@的好友有:')
for item in list1:
    print(item[1:])         #输出每个好友名时,去掉@符号
代码运行结果如下:

实例04:通过好友列表生成全部被@的好友
代码如下:
#----------实例04:通过好友列表生成全部被@的好友----------#
list_friend = ['明日科技','扎克伯格','俞敏洪','马云','马化腾']      #好友列表
str_friend = ' @'.join(list_friend)     # 用空格+@符号进行连接
at = '@' + str_friend                   #由于使用join()方法时,第一个元素前不加分隔符,所偶一需要在前面加上@符号
print('您要@的好友:',at)
代码运行结果如下:

 

实例05:不区分大小写验证会员是否唯一
代码如下:
#----------实例05:不区分大小写验证会员是否唯一----------#
#假设已经注册的会员名称保存在一个字符串中,以“|”进行分隔
username_1 = '|MingRi|mr|mingrisoft|WGH|MrSoft|'
username_2 = username_1.lower()             #将会员名称字符串全部转换为小写
regname_1 = input('输入要注册的会员名称:')
regname_2 = '|' + regname_1.lower() + '|'   #将要注册的会员名称全部转换为小写
if regname_2 in username_2:                 #判断输入的会员名称是否存在
    print('会员名',regname_1,'已经存在!')
else:
    print('会员名',regname_1,'可以注册!')
代码运行结果如下:

 

实例06:格式化不同的数值类型数据
代码如下:
#----------实例06:格式化不同的数值类型数据----------#
import math             #导入Python的数学模块
#以货币形式显示
print('1251+3950的结果是(以货币形式显示):¥{:,.2f}元'.format(1251+3950))
print('{0:.1f}用科学计数法表示:{0:E}'.format(120000.1))     #用科学计数法表示
print('Π取5位小数:{:.5f}'.format(math.pi))                #输出小数点后五位
print('{0:d}的16进制结果是:{0:#x}'.format(100))            #输出十六进制数
#输出百分比,并且不带小数
print('天才是由{:.0%}的灵感,加上{:.0%}的汗水。'.format(0.01,0.99))
代码运行结果如下:

 

实例07:验证输入的手机号码是否为中国移动的号码
代码如下:
#----------实例07:验证输入的手机号码是否为中国移动的号码----------#
import re           #导入Python的re模块
pattern = r'(13[4-9]\d{8})$|(15[01289]\d{8})$'
mobile = '13634222222'
match = re.match(pattern,mobile)        #进行模式匹配
if match == None:                       #判断是否为None,为真表示匹配失败
    print(mobile,'不是有效的中国移动手机号码。')
else:
    print(mobile,'是有效的中国移动手机号码。')
mobile = '13144222221'
match = re.match(pattern,mobile)        #进行模式匹配
if match == None:                       #判断是否为None,为真表示匹配失败
    print(mobile,'不是有效的中国移动手机号码。')
else:
    print(mobile,'是有效的中国移动手机号码。')
代码运行结果如下:

 

实例08:验证是否出现危险字符
代码如下:
#----------实例08:验证是否出现危险字符----------#
import re                                   #导入Python的re模块
pattern = r'(黑客)|(抓包)|(监听)|(Trojan)'    #模式字符串
about = '我是一名程序员,我喜欢看黑客方面的图书,想研究一下Trojan。'
match = re.search(pattern,about)              #进行模式匹配
if match == None:                             #判断是否为None,为真表示匹配失败
    print(about,'@ 安全!')
else:
    print(about, '@ 出现了危险词汇!')
about = '我是一名程序员,我喜欢看计算机网络方面的图书,喜欢开发网站。'
match = re.match(pattern,about)              #进行模式匹配
if match == None:                             #判断是否为None,为真表示匹配失败
    print(about, '@ 安全!')
else:
    print(about, '@ 出现了危险词汇!')
代码运行结果如下:

 

 

实例09:替换出现的危险字符
代码如下:
#-----------实例09:替换出现的危险字符----------#
import re                                   #导入Python的re模块
pattern = r'(黑客)|(抓包)|(监听)|(Trojan)'    #模式字符串
about = '我是一名程序员,我喜欢看黑客方面的图书,想研究一下Trojan。\n'
sub = re.sub(pattern, '@_@',about)          #进行模式替换
print(sub)
about = '我是一名程序员,我喜欢看计算机网络方面的图书,喜欢开发网站。'
sub = re.sub(pattern, '@_@',about)          #进行模式替换
print(sub)
代码运行结果如下:

 

实例10:输出被@的好友名称(应用正则表达式)
代码如下:
#----------实例10:输出被@的好友名称(应用正则表达式)----------#
import re
str1 = '@明日科技 @扎克伯格 @俞敏洪'
pattern = r'\s*@'
list1 = re.split(pattern,str1)          #用空格和@或单独的@分割字符串
print('您@的好友有:')
for item in list1:
    if item != "":                      #输出不为空的元素
        print(item)                     #输出每个好友名
代码运行结果如下:


实战一:打印象棋口诀
代码如下:
#----------实战一:打印象棋口诀----------#
str1 = '马走日'
str2 = '象走田'
str3 = '车走直路炮翻山'
str4 = '士走斜线护将边'
str5 = '小卒一去不复返'
str6 = ''
str7 = ''
print('象棋口诀:')
print(str1 + str6)
print(str2 + str6)
print(str3 + str6)
print(str4 + str6)
print(str5 + str7)
代码运行结果如下:

 


 

实战二:判断车牌归属地
代码如下:
#----------实战二:判断车牌归属地----------#
string = '津A·12345',\
         '沪A·23456',\
         '京A·34567'
for i in range(len(string)):
    print('' + str(i+1) + '张车牌号码:\n' + string[i])
    if string[i][0] == '':
        print('这张号牌的归属地:天津')
    if string[i][0] == '':
        print('这张号牌的归属地:上海')
    if string[i][0] == '':
        print('这张号牌的归属地:北京')
代码运行结果如下:


 

实战三:模拟微信抢红包
代码如下:
#----------实战三:模拟微信抢红包----------#
import random
import decimal
print('----------模拟微信抢红包----------')
money = input("请输入要装入红包的总金额:")
nums = int(input("请输入红包的个数(个):"))
money_all = decimal.Decimal(money)
for num in range(1,nums+1):
    if num == nums:
        last = money_all
    else:
        last = money_all/2*decimal.Decimal(str(random.random()))
        last = last.quantize(decimal.Decimal('0.00'))
    money_all = money_all - last
    print('第%d个红包:%s' %(num,str(last)))
代码运行结果如下:

 


 

实战四:显示实时天气预报
代码如下:
#----------实战四:显示实时天气预报----------#
weather = '2018年4月17日 \t天气预报:{:s} \t{:d}℃~{:d}℃ \t微风转西风3~4级'
print(weather.format('',20,7))
print('08:00 \t天气预报:{:s} \t{:d}℃ \t微风'.format('',13))
print('12:00 \t天气预报:{:s} \t{:d}℃ \t微风'.format('',19))
print('16:00 \t天气预报:{:s} \t{:d}℃ \t西风3~4级'.format('',18))
print('20:00 \t天气预报:{:s} \t{:d}℃ \t西风3~4级'.format('',15))
print('00:00 \t天气预报:{:s} \t{:d}℃ \t微风'.format('',12))
print('04:00 \t天气预报:{:s} \t{:d}℃ \t微风'.format('',9))
代码运行结果如下:

课后作业:
1.匹配8位密码,既要有数字,又要有字母,也要有字符
代码如下:
#----匹配8位密码,既要有数字,又要有字母,也要有字符----#
import re
pattern = r'^\w{8}$'
print('请输入8位密码:')
string = input()
match = re.match(pattern,string,re.I)
print(match)
print('匹配值的起始位置:',match.start())
print('匹配值的结束位置:',match.end())
print('匹配位置的元组:',match.span())
print('要匹配的字符串:',match.string)
print('匹配值数据:',match.group())
代码运行结果如下:

 

 2.匹配身份证号码是属于广东省的

代码如下:

 

#----------匹配身份证号码是属于广东省的----------#
import re
pattern = r'(44[0-9]{4}\d{12})'
print('请输入18位身份证:')
string = input()
match = re.match(pattern,string)
if match == None:
    print(string,'不属于广东省身份证')
else:
    print(string, '属于广东省身份证')

 

代码运行结果如下:

 

 

 

 

 


 

 

 

posted on 2022-09-29 22:02  Shing-  阅读(435)  评论(0)    收藏  举报