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

编程入门 行业动态 更新时间:2024-10-08 22:16:15

实验四 Python<a href=https://www.elefans.com/category/jswz/34/1771434.html style=字符串与正则表达式"/>

实验四 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 retext = 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)的正则表达式,并用 re.match 方法和邮箱 sda123(wer)u@163 作为测试验证。

import res = input("请输入邮箱:")
if re.match(r'.*?@163', 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 restr1 = """<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=''

reponse = requests.get(url)

rts=reponse.text

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

# .html #(待选)

# .html

# .html

# /?key=python&act=input

更多推荐

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

本文发布于:2024-02-07 02:33:51,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1752692.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:字符串   正则表达式   Python

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!