Python实验报告(第5章)
实验5:字符串及正则表达式
一、实验目的和要求
学会使用字符串的常用操作方法和正确应用正则表达式
二、实验环境
软件版本:Python 3.10 64_bit
三、实验过程
1、实例01:使用字符串拼接输出一个关于程序员的笑话
(1)在IDLE中创建一个名称为programmer_splice.py的文件,然后在该文件中定义两个字符串变量,分别记录两名程序员说的话,再将两个字符串拼接到一起,并且在中间拼接一个转义字符串(换行符),最后输出,代码如下:
1 programmer_1 = '程序员甲:搞IT太辛苦了,我想换行……怎么办?' #变量1赋值为字符串
2 programmer_2 = '程序员乙:敲一下回车键'
3 print(programmer_1 +'\n'+ programmer_2)
(2)运行结果如下:

2、实例02:截取身份证号中的出生日期
(1)在IDLE中创建一个名称为idcard.py的文件,然后在该文件中定义3个字符串变量,分别记录两名程序员说的话,再从程序员甲说的身份证号中截取出出生日期,并且组合成“YYYY年MM月DD日”格式的字符串,最后输出截取到的出生日期和生日,代码如下:
1 programmer_1 = '你知道我的生日吗?' #变量1赋值为字符串
2 print('程序员甲说:',programmer_1)
3 programmer_2 = '输入你的身份证号码。'
4 print('程序员乙说:',programmer_2)
5 idcard = '123456199006277890'
6 print('程序员甲说:',idcard)
7 birthday = idcard[6:10] +'年'+ idcard[10:12] +'月'+ idcard[12:14] +'日' #字符串连接
8 print('程序员乙说:','你是' + birthday +'出生的,所以你的生日是' + birthday[5:]) #字符串切片
(2)运行结果如下:

3、实例03:输出被@的好友名称
(1)在IDLE中创建一个名称为atfriend.py的文件,然后在该文件中定义一个字符串,内容为“@明日科技 @扎克伯格 @俞敏洪”,然后使用split()方法对该字符串进行分割,从而获得好友名称,并输出,代码如下:
1 str1 = '@明日科技 @扎克伯格 @俞敏洪'
2 list1 = str1.split(' ') #分割后的字符串列表['@明日科技',…]
3 print('您的好友有:')
4 for item in list1:
5 print(item[1:]) #输出列表中每个字符串从索引1开始的内容
(2)运行结果如下:

4、实例04:通过好友列表生成全部被@的好友
(1)在IDLE中创建一个名称为atfriend-join.py的文件,然后在该文件中定义一个列表,保存一些好友名称,然后使用join()方法将列表中的每个元素用空格+@符号进行连接,再在连接后的字符串前添加一个@符号,最后输出,代码如下:
1 list_friend = ['明日科技','扎克伯格','俞敏洪','马云','马化腾']
2 str_firend = ' @'.join(list_friend) #将列表的每一个元素用' @'连接起来(除了第一个元素)
3 at = '@' +str_firend #将上述字符串变量的第一个元素前用@连接起来
4 print('您要@的好友:',at)
(2)运行结果如下:

5、实例05:不区分大小写验证会员名是否唯一
(1)在IDLE中创建一个名称为checkusername.py的文件,然后在该文件中定义一个字符串,内容为已经注册的会员名称,以“|”进行分隔,然后使用lower()方法将字符串全部转换为小写字母,接下来再应用input()函数从键盘获取一个输入的注册名称,也将其全部转换为小写字母,再应用if…else…语句和in关键字判断转换后的会员名是否存在转换后的会员名成字符串中,并输出不同的判断结果,代码如下:
1 username_1 = '|MingRi|mr|mingrisoft|WGH|MRSoft|'
2 username_2 = username_1.lower() #将字符串统一成小写字母
3 regname_1 = input('输入要注册的会员名称:') #键盘输入新字符串
4 regname_2 = '|' + regname_1.lower() + '|' #将新字符串转成小写后,与原字符串连接
5 if regname_2 in username_2:
6 print('会员名', regname_1, '已经存在!') #判断字符串是否重复
7 else:
8 print('会员名', regname_1, '可以注册!')
(2)运行结果如下:(以mrsoft和python为例)


6、实例06:格式化不同的数值类型数据
(1)在IDLE中创建一个名称为formatnum.py的文件,然后在该文件中将不同类型的数据进行格式化,并输出,代码如下:
1 import math #导入python的math模块(文件)
2 print('1251+3950的结果是(以货币形式显示):¥{:,.2f}元'.format(1251+3950))
3 #{:,.2f}用,分隔+小数点后保留两位的flaot型数据
4 print('{0:.1f}用科学计数法表示:{0:E}'.format(120000.1)) #{0:}索引值从0开始,:E是用科学计数法表示
5 print('π取5位小数:{:.5f}'.format(math.pi))
6 print('{0:d}的16位进制结果是:{0:#x}'.format(100)) #10进制为d,16进制为#x
7 print('天才是由{:.0%}的灵感,加上{:.0%}的汗水。'.format(0.01,0.99)) #{:.0%}小数点后保留的形式
(2)运行结果如下:

7、实例07:验证输入的手机号码是否为中国移动的号码
(1)在IDLE中创建一个名称为checkmobile.py的文件,然后在该文件中导入Python的re模块,在定义一个验证手机号码的模式字符串,最后应用该模式字符串验证这两个手机号码,并输出验证结果,代码如下:
1 import re
2 pattern = r'(13[4-9]\d{8}$|15[01289]\d{8})$' #原生字符串表示 13开头 可选数字范围[] 数据类型及位数 结束符|
3 mobile = '13634222222'
4 match = re.match(pattern,mobile) #match变量重新赋值为 进行模式匹配后的结果值(True None)
5 if match == None:
6 print(mobile,'不是有效的中国移动手机号码。')
7 else:
8 print(mobile,'是有效的中国移动手机号码。')
9 mobile = '13144222221'
10 match = re.match(pattern,mobile)
11 if match == None:
12 print(mobile,'不是有效的中国移动手机号码。')
13 else:
14 print(mobile,'是有效的中国移动手机号码。')
(2)运行结果如下:

8、实例08:验证是否出现危险字符
(1)在IDLE中创建一个名称为checktnt.py的文件,然后在该文件中导入Python的re模块,在定义一个检验危险字符的模式字符串,最后应用该模式字符串验证两段文字,并输出检验结果,代码如下:
1 import re
2 pattern = r'(黑客)|(抓包)|(监听)|(Trojan)' #模式字符串
3 about = '我是一名程序员,我喜欢看黑客方面的图书,想研究一下Trojan。'
4 match = re.search(pattern,about) #进行模式匹配,查找是否出现模式字符串中的字符,返回匹配值
5 if match == None: #匹配值为None时,about表示的字符串后加''的内容
6 print(about,'@ 安全!')
7 else:
8 print(about,'@ 出现了危险词汇!')
9 about = '我是一名程序员,我喜欢看计算机网络方面的图书,喜欢开发网站。'
10 match = re.match(pattern,about)
11 if match == None:
12 print(about,'@ 安全!')
13 else:
14 print(about,'@ 出现了危险词汇!')
(2)运行结果如下:

9、实例09:替换出现的危险字符
(1)在IDLE中创建一个名称为checktnt.py的文件,然后在该文件中,导入Python的re模块,再定义一个验证危险字符的模式字符串,最后应用该模式字符串验证两段文字,并输出验证结果,代码如下:
1 import re
2 pattern = r'(黑客)|(抓包)|(监听)|(Trojan)' #模式字符串
3 about = '我是一名程序员,我喜欢看黑客方面的图书,想研究一下Trojan。\n'
4 sub = re.sub(pattern,'@_@',about) #re.sub()可替换字符串,匹配到pattern中的字符串后,将其替换成''的内容
5 print(sub) #输出sub的值(被替换后的字符串)
6 about = '我是一名程序员,我喜欢看计算机网络方面的图书,喜欢开发网站。'
7 sub = re.sub(pattern,'@_@',about)
8 print(sub)
(2)运行结果如下:

10、实例10:输出被@的好友名称(应用正则表达式)
(1)在IDLE中创建一个名称为atfriendsplit1.py的文件,然后在该文件中定义一个字符串,内容为“@明日科技 @扎克伯格 @俞敏洪”,然后使用re模块的split()方法对该字符串进行分割,从而获取出好友名称,并输出,代码如下:
1 import re
2 str1 = '@明日科技 @扎克伯格 @俞敏洪'
3 pattern = r'\s*@' #模式字符串:\s和@
4 list1 = re.split(pattern,str1) #用@分割字符串,得出一个一维列表[@… @… @…]
5 print('您@的好友有:')
6 for item in list1:
7 if item !="": #列表元素不是空格时输出元素
8 print(item)
(2)运行结果如下:

11、实战01:打印象棋口诀
(1)在IDLE中创建一个名称为checktnt.py的文件,然后在该文件中应用字符串输出象棋口诀,代码如下:
1 str1 = '马走日'
2 str2 = '象走田'
3 str3 = '车走直路炮翻山'
4 str4 = '士走斜线护将边'
5 str5 = '小卒一去不回还'
6 str6 = ','
7 str7 = '。'
8 print('象棋口诀:')
9 print(str1+str6)
10 print(str2+str6)
11 print(str3+str6)
12 print(str4+str6)
13 print(str5+str7)
(2)运行结果如下:

12、实战02:判断车牌归属地
(1)在IDLE中创建一个名称为carplace.py的文件,然后在该文件中实现输出指定车牌的归属地功能,代码如下:
1 import re
2 chepai = ('津A·12345','沪A·23456','京A·34567')
3 for i in range(len(chepai)):
4 print("第"+str(i+1)+"张车牌号码:"+"\n"+chepai[i]) #按照序列输出车牌
5 if chepai[i][0] == '津': #第i个元素按照字符分割成8个小元素
6 print("这张号牌的归属地:天津")
7 if chepai[i][0] == '沪':
8 print("这张号牌的归属地:上海")
9 if chepai[i][0] == '京':
10 print("这张号牌的归属地:北京")
(2)运行结果如下:

13、实战03:模拟微信抢红包
(1)在IDLE中创建一个名称为qianghongbao.py的文件,然后在该文件中应用输出随机数的random模块和设定小数位的decimal模块,代码如下:
1 import random
2 import decimal
3 print("——————————模拟微信抢红包——————————")
4 money = input("请输入要装入红包的总金额(元):")
5 nums = int(input("请输入红包的个数(个):"))
6 money_total = decimal.Decimal(money)
7 for num in range(1,nums+1): #循环输出
8 if num == nums:
9 last = money_total #最后一个人的金额=总金额-last
10 else:
11 last = money_total/2*decimal.Decimal(str(random.random())) #限制单个红包不超出总额的一半【可不设置】
12 last = last.quantize(decimal.Decimal('0.00')) #四舍五入,保留两位小数
13 money_total = money_total - last
14 print("第%d个红包:%s" %(num,str(last))) #%字符输出形式【类似C语言】
(2)运行结果如下:

14、实战04:显示实时天气预报
(1)在IDLE中创建一个名称为weathereport.py的文件,然后在该文件中应用字符串的format()方法格式化输出实时天气预报,代码如下:
1 weather = '2018年4月17日\t 天气预报:{:s}\t {:d}℃~{:d}℃\t 微风转西风3~4级'
2 print(weather.format('晴',20,7))
3 print('08:00\t 天气预报:{:s}\t {:d}℃\t 微风'.format('晴',13))
4 print('12:00\t 天气预报:{:s}\t {:d}℃\t 微风'.format('晴',19))
5 print('16:00\t 天气预报:{:s}\t {:d}℃\t 微风'.format('晴',18))
6 print('20:00\t 天气预报:{:s}\t {:d}℃\t 微风'.format('晴',15))
7 print('00:00\t 天气预报:{:s}\t {:d}℃\t 微风'.format('晴',12))
8 print('04:00\t 天气预报:{:s}\t {:d}℃\t 微风'.format('晴',9))
(2)运行结果如下:

Python实验报告(第5章)的更多相关文章
- Python实验报告——第4章 序列的应用
实验报告 [实验目的] 1.掌握python中序列及序列的常用操作. 2.根据实际需要选择使用合适的序列类型. [实验条件] 1.PC机或者远程编程环境. [实验内容] 1.完成第四章 序列的应用 实 ...
- Python实验报告——第3章 流程控制语句
实验报告 [实验目的] 1.掌握python中流程控制语句的使用,并能够应用到实际开发中. [实验条件] 1.PC机或者远程编程环境 [实验内容] 1.完成第三章流程控制语句实例01-09,实战一到实 ...
- Python实验报告——第2章 Python语言基础
实验报告 [实验目的] 1.熟悉在线编程平台. 2.掌握基本的 python 程序编写.编译与运行程序的方法. [实验条件] 1.PC机或者远程编程环境 [实验内容] 1.完成第二章实例01-07,实 ...
- python实验报告(第11章)
实验11:使用Python操作数据库 一.实验目的和要求 1.学会数据库编程接口: 2.学会使用SQLite: 3.学会使用MySQL. 二.实验环境 软件版本:Python 3.10 64_bit ...
- python实验报告(第12章)
实验12:GUI界面编程 一.实验目的和要求 1.学会应用常用控件: 2.学会使用BoxSizer布局: 3.学会事件处理. 二.实验环境 软件版本:Python 3.10 64_bit 三.实验过程 ...
- Python实验报告(第8章)
实验8:模块 一.实验目的和要求 1.了解模块的内容: 2.掌握模块的创建和导入方式: 3.了解包结构的创建和使用. 二.实验环境 软件版本:Python 3.10 64_bit 三.实验过程 1.实 ...
- Python实验报告(第13章)
实验13:Pygame游戏编程 一.实验目的和要求 学会Pygame的基本应用 二.Pygame的优点及应用 使用Python进行游戏开发的首选模块就是Pygame,专为电子游戏设计(包括图像.声音) ...
- Python实验报告(第10章)
实验10:文件及目录操作 一.实验目的和要求 1.掌握基本文件操作(创建.打开.关闭.写入): 2.掌握目录操作的基本操作(创建.删除.遍历): 3.了解高级文件操作(删除文件.获取文件基本信息). ...
- Python实验报告(第9章)
实验9:异常处理及程序调试 一.实验目的和要求 1.了解代码异常知识: 2.掌握异常处理的try-except语句.try-except-else语句.try-except-finally语句.rai ...
- Python实验报告(第6章)
实验6:函数 一.实验目的和要求 1.掌握函数的创建和调用: 2.了解不同的参数如何进行传递: 3.了解返回值的应用: 4.学习变量的作用域: 5.学习匿名函数(lambda). 二.实验环境 软件版 ...
随机推荐
- 关于aws账单数据中几个重要的与费用相关的字段的意义分析
今天在看aws账号的详细信息时,看到字段很多,大多数字段,根据名称可以知道代表的意义 对于如下几个字段的概念有点模糊(位于"UsageStartDate","UsageE ...
- 使用 Spring Security 手动验证用户
1.概述 在这篇快速文章中,我们将重点介绍如何在 Spring Security 和 Spring MVC 中手动验证用户的身份. 2.Spring Security 简单地说,Spring Secu ...
- 插件化编程之WebAPI统一返回模型
WebApi返回数据我们一般包裹在一个公共的模型下面的,而不是直接返回最终数据,在返回参数中,显示出当前请求的时间戳,是否请求成功,如果错误那么错误的消息是什么,状态码(根据业务定义的值)等等.我们常 ...
- vivo互联网机器学习平台的建设与实践
vivo 互联网产品团队 - Wang xiao 随着广告和内容等推荐场景的扩展,算法模型也在不断演进迭代中.业务的不断增长,模型的训练.产出迫切需要进行平台化管理.vivo互联网机器学习平台主要业务 ...
- TomCat之负载均衡
TomCat之负载均衡 本文讲述了tomcat当nginx负载均衡服务器配置步骤 以下是Tomcat负载均衡配置信息 1.修改nginx的nginx.conf文件 添加如下属性:localhost是名 ...
- 『现学现忘』Git基础 — 37、标签tag(二)
目录 5.共享标签 6.删除标签 7.修改标签指定提交的代码 8.标签在.git目录中的位置 9.本文中所使用到的命令 提示:接上一篇文章内容. 5.共享标签 默认情况下,git push 命令并不会 ...
- python和C语言从路径中获取文件名
1.Python import os file_name = os.path.basename(filepath)#带后缀的文件名(不含路径) file_name_NoExtension = os.p ...
- Python基础部分:10、数据类型的内置方法和字符编码
目录 一.数据类型内置方法 1.字典dict内置方法 1.1.类型转换 2.字典必须要掌握的方法 2.1.取值方式 2.2.修改内部数据值 2.3.删除数据 2.4.统计字典中键值对个数 2.5.字典 ...
- shardingsphere-jdbc 水平分表学习记录
放在自己博客里搬过来一份~ 前司使用的是自己魔改的TDDL,在家时间比较多就尝试学一些业内比较常用的中间件. 这里记录一下学习中遇到的一些问题. 环境 设置的比较简单(太懒了就测试了几个表), 两个分 ...
- SpringBoot 08: SpringBoot综合使用 MyBatis, Dubbo, Redis
业务背景 Student表 CREATE TABLE `student` ( `id` int(11) NOT NULL AUTO_INCREMENT, `name` varchar(255) COL ...