实验四 Python字符串与正则表达式

4.1 字符串相关操作

1.统计所输入字符串中单词的个数,单词之间用空格分隔。其运行效果如下图所示。

s=input('请输入字符串:')
sum=1
for i in s:
    if i==' ':
        sum+=1
print('方法一:',end='')
print('其中的单词总数有:',sum)

list=s.split(' ')
print('方法二:',end='')
print('其中的单词总数有:',len(list))

2. 编写程序,给出一个字符串,将其中的字符“E”用空格替换后输出。str.replace(old, new)

a = input('请输入一个字符串:')
print('替换前:',a)
a = a.replace('E',' ')
print('替换后:',a)

3. 从键盘交互式输人一个人的 18 位的身份证号,以类似于“2001 年 09 月 12 日”的形式输出该人的出生日期。

idc = input("请输入身份证号:")
print(f'出生日期:{idc[6:10]}年{idc[10:12]}月{idc[12:14]}日')

4.将字符串'abcdefg'使用函数的方式进行倒序输出

list = 'abcdefg'
print(list[::-1])

5. 在我们的生活中,节假日的问候是必不可少的,请使用字符串格式化的方式写一个新年问候语模板.

name = input("请输入姓名:")
print(f"祝{name}新年快乐!")

6. 用户输入一个字符串,将下标为偶数的字符提出来合并成一个新的字符串 A,再将下标为奇数的字符提出来合并成一个新的字符串 B,再将字符串 A 和 B 连接起来并输出。

s = input('请输入字符串:')
A = s[0::2]
B = s[1::2]
print('A=', A)
print('B=', B)
print(A + B)

7. 请根据下列需求,编写一个程序。用户输入一个字符串,请将字符串中的所有字母全部向后移动一位,最后一个字母放到字符开头,最后将新的字符串输出。

s = input('请输入字符串:')
s_new = s[-1] + s[:len(s) - 1]  # s[-1]表示s最后一位,s[:len(s)-1]表示切片到倒数第二位
print(s_new)

8. 基于 input 函数,对输入的字符串进行处理,并将返回替换了某些字符的字符串,规则如下:

  • 如果一个字母是大写辅音,请将该字符替换为“Iron”。
  • 如果字母是小写辅音或非字母字符,则对该字符不执行任何操作。
  • 如果一个字母是大写元音,请将该字符替换为“Iron Yard”。
  • 如果一个字母是小写元音,请用“Yard”替换该字符。

import re

text = input("请输入字符串:")
for i in text:
    if i == 'A' or i == 'O' or i == 'E' or i == 'I' or i == 'U':
        a = re.sub('[AOEIU]', 'Iron Yard', text)
    if i == 'a' or i == 'o' or i == 'e' or i == 'i' or i == 'u':
        a = re.sub('[aoeiu]', 'Yard', text)
    if i > 'A' and i < 'Z':
        a = re.sub('[A-Z-[AOEIU]]', 'Iron', text)
print("替换后的字符为:", a)

9. (选做)老王在一个"胖子健身俱乐部",每到月底老王就很担心,因为每个月都会公布一份成员体重列表,每个月他都是列表中的最后一 个,这意味着他是最重的。于是他就建议会长修改规则,比如新的规则如下:新的排序规则将是按照“权重”来进行排序,如果权重相同,则按照体重字符串来进行排序。(权重的计算规则:体重数字不同位数上的数字的总和)

给定某种正常顺序俱乐部的成员的体重字符串,如何实现按照新规则排序呢?测试用例:输入: "99 189 86 75"输出: "75 86 189 99"。

10. (选做)用五个六面骰子玩的骰子游戏,每投骰子组一次,就会出现 5 个数字的数组(数字:1-6),统计数组里每个数字出现的次数,将每个数字出现的次数拆分成 3 次和 1 次 的组合,然后按照下面的规则进行计数。注意:如果出现次数大于或者等于 3 次,那么必须至少有一个按照 3 次来计算,不能全部按照 1 次来计算 3 次 1 = = 1000 分 3 次 6 = = 600 分 3 次 5 = = 500 分 3 次 4 = = 400 分 3 次 3 = = 300 分 3 次 2 = = 200 分 1 次 1 => 100 分 1 次 5 => 50 分 1 次 2 => 0 分 1 次 3 => 0 分 1 次 4 => 0 分 1 次 6 => 0 分。 例如,5 出现了 5 次,那么应当做作 3 个 5、1 个 5 和 1 个 5 来计算得分;5 出现了 6 次,那么应当作 3 个 5、3 个 5 来计算得分,其他数字同理。

测试用例:扔骰子计算得分--------------------------- 5 1 3 4 1 50 + 2 * 100 = 250

1 1 1 3 1 1000 + 100 = 1100

2 4 4 5 4 400 + 50 = 450。

4.2 正则表达式相关操作

1. 写出能够匹配163 邮箱(@163.com)的正则表达式,并用 re.match 方法和邮箱 sda123(wer)u@163.com 作为测试验证。

import re

s = input("请输入邮箱:")
if re.match(r'.*?@163.com', s):
    print('是')
else:
    print('不是')

2. 利用 re 库中的 search、findall 或 search 函数从以下三个字符串中提取出所有的汉字,输出的结果分别为“大连理工大学”“重庆大学”以及“中南财经大学” 。(提示:字符串 st2,str3 中有空格)。

  • str1="""<td width="160">大连理工大学</td>"""
  • str2="""<td width="160"><a href="../news/list_117.html"class="keyWord" target="_blank">重庆</a>大学</td>"""
  • str3="""<td width="160"> 中南 <a href="../news/list_197.html"class="keyWord" target="_blank"> 财经 </a><ahref="../news/list_201.html" class="keyWord" target="_blank">政法</a>大学</td>"""

import re

str1 = """<td width="160">大连理工大学</td>"""
str2 = """<td width="160"><a href="../news/list_117.html" class="keyWord" target="_blank">重庆</a>大学</td>"""
str3 = """<td width="160">中南<a href="../news/list_197.html" class="keyWord" target="_blank">财经</a><a href="../news/list_201.html" class="keyWord" target="_blank">政法</a>大学</td>"""
re1 = re.search("""<td width="160">(.*?)</td>""",str1).group(1)
print(''.join(map(str,re1)))
re2 = re.search("""<td width="160"><a href="../news/list_117.html" class="keyWord" target="_blank">(.*?)</a>(.*?)</td>""",str2).group(1,2)
print(''.join(map(str,re2)))
re3 = re.search("""<td width="160">(.*?)<a href="../news/list_197.html" class="keyWord" target="_blank">(.*?)</a><a href="../news/list_201.html" class="keyWord" target="_blank">(.*?)</a>(.*?)</td>""",str3).group(1,2,3,4)
print(''.join(map(str,re3)))

2. 利用 re 库中的 finall 函数以及.*?与其他字符串的组合构成的正则化表达式从字符串 strs 中将所有汉字提取并依次输出。提示:

(1)将网页源代码复制并粘贴生成一个字符串 strs 或利用以下程序 获取网页源代码的字符串形式

import requests

url='http://www.baidu.com'

reponse = requests.get(url)

rts=reponse.text

(2)此字符串中含有回车符号使用 re.finall(正则表达式, strs,re.S) url='http://exercise.kingname.info/exercise_requests_get.html'

# http://exercise.kingname.info/exercise_xpath_1.html #(待选)

# http://exercise.kingname.info/exercise_bs_1.html

# http://exercise.kingname.info/exercise_xpath_3.html

# http://search.dangdang.com/?key=python&act=input

  • 8
    点赞
  • 37
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

再见以前说再见

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值