正则表达式、文件访问(Python实现)

一、主要目的

1.了解正则表达式的基本概念和处理过程。

2.掌握使用正则表达式模块 Re 进行字符串处理的方法。

3.了解文件的基本概念和类型。

4.掌握在 Python 中访问文本文件的方法和步骤。

5.熟悉在 Python 中访问二进制文件的方法和步骤。

二、主要内容和结果展示:

1.编写一个程序,使用正则表达式校验输入的手机号是否正确。

复制代码
import re

str = input("请输入手机号:")

reg = r"\b1[3-9]\d{9}\b"

res = re.match(reg, str, re.M)

if res:

    print("校验输入的手机号正确。")

else:

    print("校验输入的手机号不正确。")

2.编写一个程序,使用正则表达式校验输入的车牌号是否正确。

复制代码
import re

str = input("请输入车牌号:")

reg1 = r"\b[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z][A-HJ-NP-Z0-9]{5}\b"

flag1 = re.findall(r"[A-HJ-NP-Z]",str)

if len(flag1) > 3:

    print("校验输入的车牌号不正确。")

    exit(0)

reg2 = r"\b[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领]\d{6}\b"

reg3 = r"\b[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z]\d{5}\b"

reg4 = r"\b[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领]\d{5}[A-HJ-NP-Z]\b"

reg5 = r"\b[京津沪渝冀豫云辽黑湘皖鲁新苏浙赣鄂桂甘晋蒙陕吉闽贵粤青藏川宁琼使领][A-HJ-NP-Z]{2}\d{4}\b"

res1 = re.match(reg1, str, re.M)

res2 = re.match(reg2, str, re.M)

res3 = re.match(reg3, str, re.M)

res4 = re.match(reg4, str, re.M)

res5 = re.match(reg5, str, re.M)

if res1 or res2 or res3 or res4 or res5:

    print("校验输入的车牌号正确。")

else:

    print("校验输入的车牌号不正确。")

3.编写一个程序,通过键盘将曹操的《观沧海》写入文本文件gch.txt 中。

复制代码
str = input("请输入观沧海:")

with open("gch.txt","w") as file:

    num = file.write(str)

    if num != 0:

        print("写入字符串成功!")

4.编写一个程序实现如下功能:

(1)随机产生 20个1~100之间的随机整数,写入文本文件sjs.txt 中。

(2)从文本文件 sjs.txt 中读出数据,计算并输出标准方差。

复制代码
import random

list1 = []

sum = 0

d = 0

for x in range(20):

    list1.append(str(random.randint(1,100)))

with open("sjs.txt","w") as file:

    file.writelines(list1)

    print("写入20个1-100之间的随机整数成功!")

with open("sjs.txt","r") as f:

    str = f.readlines()

    for i in str:

        sum += int(i)

    aver = sum / 20

    for j in str:

        d += (int(j) - aver) ** 2

    d /= 20

    print("方差为",d)

5.编写一个程序,将文本文件 file1.txt 中的内容复制到文本文件file2.txt(空文件)中。

复制代码
with open("file1.txt","w") as file1:

    num1 = file1.write("此为文件file1!")

with open("file2.txt","w") as file1:

    num1 = file1.write("此为文件file2!")

with open("file2.txt","w") as file2:

    with open("file1.txt","r") as file1:

        str = file1.read()

    num2 = file2.write(str)

    print("file1复制成功!")

6.编写一个程序,将文本文件 filel.txt 中的内容连接到文本文件 file2.txt 的内容后面。

复制代码
with open("file1.txt","w") as file1:

    num1 = file1.write("此为文件file1!")

with open("file2.txt","w") as file1:

    num1 = file1.write("此为文件file2!")

with open("file2.txt","a") as file2:

    with open("file1.txt","r") as file1:

        str = file1.read()

    num2 = file2.write(str)

    print("file1复制成功!")

7.有两个文本文件(a.txt 和b.txt),各存放一行英文字母,要求把这两个文件中的信息合并(按字母顺序排列),写到一个新文件c.txt 中。

复制代码
with open("a.txt","w") as file1:

    num1 = file1.write("hello")

with open("b.txt","w") as file2:

    num2 = file2.write("welcome")

with open("c.txt","w") as file5:

    with open("a.txt","r") as file3:

        str1 = file3.read()

    with open("b.txt","r") as file4:

        str2 = file4.read()

    str3 = sorted(list(str1+str2))

    num3 = file5.write(" ".join(str3))

    print("两个文件中的信息合并成功!")

8.编写一个程序,分别将一个数字、字符串、列表、元组、字典和集合写入一个二进制文件bFile.dat 中,然后从二进制文件 bFile.dat 中读出并显示。

复制代码
import pickle

num1 = 2

str2 = "Hello world!"

list3 = [1,2,3,4,5]

tuple4 = (6,7,8)

dict5 = {1:"H",2:"i",3:"!"}

set6 = {9,10}

data = [num1, str2, list3, tuple4, dict5, set6]

with open("bFile.dat","wb") as pickle_file:

    for i in data:

        pickle.dump(i, pickle_file)

    print("写入数据成功!")

with open("bFile.dat","rb") as pickle_file:

    data1 = pickle.load(pickle_file)

    print("数字为",data1)

    data2 = pickle.load(pickle_file)

    print("字符串为", data2)

    data3 = pickle.load(pickle_file)

    print("列表为", data3)

    data4 = pickle.load(pickle_file)

    print("元组为", data4)

    data5 = pickle.load(pickle_file)

    print("字典为", data5)

    data6 = pickle.load(pickle_file)

    print("集合为", data6)

三、心得体会

在实验中,学习了如何使用正则表达式来验证中国的手机号和车牌号格式的正确性。这些任务演示了正则表达式强大的模式匹配能力,它能够识别符合特定规则的字符串。在这个过程中,意识到编写和理解正则表达式可能需要一些时间,但一旦掌握,它可以极大地简化字符串处理任务。同时,还操作了文本和二进制文件,实现了不同的功能,如数据写入、读取、计算标准方差、文件内容复制和合并等。你还使用了pickle模块来进行Python数据结构的序列化和反序列化,这是在二进制文件中存储复杂数据的有效方法。

  1. 正则表达式的强大:正则表达式在进行复杂字符串匹配和搜索时的强大功能。通过适当的模式,几乎可以识别和验证任何形式的字符串数据。

  2. 文件操作的灵活性:Python的文件操作非常灵活,可以很容易地处理文本和二进制数据。文本文件适用于人类可读的数据,而二进制文件则适用于存储和传输序列化数据。

  3. 数据持久化的重要性:通过实验,了解到了数据持久化的重要性。将数据写入文件,可以在程序关闭后保留数据,并且在以后可以重新加载和处理这些数据。

在实验中可能遇到了一些问题,通过查阅文档、编写和调试代码来解决这些问题,解决能力和逻辑思维能力也得到了提升。对Python语法和使用Python标准库中的模块(如`re`和`pickle`)也有了更深的理解和实践。

相关推荐
懒大王爱吃狼1 分钟前
Python绘制数据地图-MovingPandas
开发语言·python·信息可视化·python基础·python学习
数据小小爬虫5 分钟前
如何使用Python爬虫按关键字搜索AliExpress商品:代码示例与实践指南
开发语言·爬虫·python
东软吴彦祖19 分钟前
包安装利用 LNMP 实现 phpMyAdmin 的负载均衡并利用Redis实现会话保持nginx
linux·redis·mysql·nginx·缓存·负载均衡
martian66527 分钟前
第17篇:python进阶:详解数据分析与处理
开发语言·python
无码不欢的我31 分钟前
使用vscode在本地和远程服务器端运行和调试Python程序的方法总结
ide·vscode·python
五味香32 分钟前
Java学习,查找List最大最小值
android·java·开发语言·python·学习·golang·kotlin
金融OG38 分钟前
99.8 金融难点通俗解释:净资产收益率(ROE)
大数据·python·线性代数·机器学习·数学建模·金融·矩阵
fmdpenny1 小时前
Django的安装
后端·python·django
小爬菜1 小时前
Django学习笔记(启动项目)-03
前端·笔记·python·学习·django
慵懒的猫mi1 小时前
deepin分享-Linux & Windows 双系统时间不一致解决方案
linux·运维·windows·mysql·deepin