文件夹lab_6中存放着某班学生提交的一次实验报告,实验报告文件名中包含有学生的姓名、学号信息。请用正则表达式获取学生姓名、学号存入CBC.csv中。 (提示: ①共有35条记录,有一些文件命名未按规则; ②以下代码可输出指定目录中的所有文件的名称 import os for file in os.listdir(path): filename = str(file) )
时间: 2024-02-05 07:13:30 浏览: 122
可以使用Python中的re模块来实现正则表达式的匹配。以下是一个可能的实现过程:
```
import os
import re
path = "lab_6" # 目标文件夹路径
output_file = "CBC.csv" # 输出文件名
with open(output_file, "w") as f:
f.write("姓名,学号\n") # 写入表头
for file in os.listdir(path):
filename = str(file)
# 匹配姓名和学号信息
match_obj = re.match(r"(\D+)(\d+)", filename)
if match_obj:
name = match_obj.group(1)
student_id = match_obj.group(2)
# 写入CSV文件
f.write(f"{name},{student_id}\n")
```
在上面的代码中,我们首先打开一个CSV文件,写入表头。然后遍历目标文件夹中的所有文件,对于每个文件,使用正则表达式匹配出其中的姓名和学号信息,并将其写入CSV文件中。需要注意的是,如果某个文件的命名不符合规则,那么它将被忽略。
相关问题
文件夹lab_6中存放着某班学生提交的一次实验报告,实验报告文件名中包含有学生的姓名、学号信息。请用正则表达式获取学生姓名、学号存入CBC.csv中
假设实验报告的文件名格式为"学生姓名-学号-实验报告.xxx",可使用以下Python代码提取学生姓名、学号信息并存入CBC.csv文件中:
```python
import re
import os
import csv
# 定义正则表达式
pattern = r'(\w+)-(\d+)-实验报告\.\w+'
# 获取实验报告文件名列表
file_list = os.listdir('lab_6')
# 创建CSV文件并写入表头
with open('CBC.csv', 'w', newline='') as csvfile:
writer = csv.writer(csvfile)
writer.writerow(['姓名', '学号'])
# 遍历实验报告文件名列表
for file_name in file_list:
# 使用正则表达式匹配学生姓名、学号信息
match = re.match(pattern, file_name)
if match:
name = match.group(1)
id = match.group(2)
# 写入CSV文件
writer.writerow([name, id])
```
上述代码中,首先定义了正则表达式`pattern`,用于匹配文件名中的学生姓名、学号信息。然后使用Python内置模块`os`获取`lab_6`文件夹中的实验报告文件名列表,遍历列表并使用正则表达式匹配学生姓名、学号信息,最后将姓名、学号信息写入CSV文件中。
python文件夹lab_6中存放着某班学生提交的一次实验报告,实验报告文件名中包含有学生的姓名、学号信息。请用正则表达式获取学生姓名、学号存入CBC.csv中。
可以使用Python的re模块来进行正则表达式匹配,再使用csv模块将结果存入CSV文件中。下面是一个示例代码:
```python
import re
import csv
# 定义正则表达式匹配学生姓名和学号
name_pattern = re.compile(r'(\D+)_([0-9]+)\.txt')
# 打开CSV文件并准备写入
with open('CBC.csv', 'w', newline='') as csvfile:
writer = csv.writer(csvfile)
# 遍历lab_6文件夹下的所有文件
for filename in os.listdir('lab_6'):
# 使用正则表达式匹配学生姓名和学号
match = name_pattern.match(filename)
if match:
name = match.group(1)
student_id = match.group(2)
# 将学生姓名和学号写入CSV文件中
writer.writerow([name, student_id])
```
上述代码中,首先定义了一个正则表达式`name_pattern`,用于匹配学生姓名和学号。然后使用`os.listdir()`函数遍历`lab_6`文件夹下的所有文件,对于每个文件,使用正则表达式匹配学生姓名和学号,并将结果写入CSV文件中。最终生成的CSV文件中每行包含学生姓名和学号两个字段。
阅读全文