赞
踩
目录
输出格式
本关任务:完成学号分配。
第一行输出该学生的学号、学生姓名、学生性别、学院、专业名称、行政班、入学年级信息,各项之间空格分隔;
其后分行输出该班级所有同学的学号、学生姓名、学生性别、学院、专业名称、行政班、入学年级信息,各项之间空格分隔。
读取文件中的内容为字符串可以用以下函数实现:
# 读文件,返回字符串
def read_file(filename):
with open(filename, 'r', encoding='utf-8') as file: # 只读模式打开文件
file_to_list = [line.strip().split(',') for line in file] # 文件全部内容读取出来放入列表中,每个元素为一行字符串
return file_to_list # 以列表形式返回文件中的数据
string.strip()
去掉字符串所有空格;
string.count(str, beg=0, end=len(string))
返回 str
在 string
里面出现的次数,如果 beg
或者 end
指定则返回指定范围内 str 出现的次数;
string.decode(encoding='UTF-8', errors='strict')
用于将 bytes
类型的二进制数据转换为 str
类型,这个过程也称为“解码”;
string.encode(encoding='UTF-8', errors='strict')
用于将 str
类型的数据转换为 byte
二进制数据,这个过程也称为“编码”;
string.format()
格式化字符串;
string.join(seq)
以 string
作为分隔符,将 seq
中所有的元素(的字符串表示)合并为一个新的字符串;
string.lstrip()
截掉 string
左边的空格;
string.replace(str1, str2, num=string.count(str1))
把 string
中的 str1
替换成 str2
,如果 num
指定,则替换不超过 num
次;
string.rstrip()
删除 string
字符串末尾的空格;
string.split(str="", num=string.count(str))
以 str
为分隔符切片 string
,如果 num
有指定值,则仅分隔 num+1
个子字符串;
string.startswith(obj, beg=0,end=len(string))
检查字符串是否是以 obj
开头,是则返回 True
,否则返回 False
。如果 beg
和 end
指定值,则在指定范围内检查。
列表推导式可以利用 range 区间、元组、列表、字典和集合等数据类型,快速生成一个满足指定需求的列表。
student_detail = [info for info in ls_student if info[1] == stu_name]
对于字典,它和列表、元组一样,也可以使用字典推导式来快速的生成一个字典,它的表现形式和列表推导式类似,只不过将列表推导式中的中括号 []
改为大括号{}
。
dic_school = {x[0]: x[1] for x in ls_school}
在右侧编辑器中的 Begin-End 区间补充代码,完成学号分配。具体要求如下:
假如本科的学生层次编号为012,请为“studentList.csv”中的数据增加学号;
学号创建规则是:学生层次+入学年份后两位+学院代码+专业代码+班级号+班中排名;
例如:012171985170110 表示本科生、2017年入学、文法学院、 编辑出版专业、1701班、排名为10的同学。
平台会对你编写的代码进行测试:
测试输入:
段宁
金融gj1701
预期输出:
012142172140101 段宁 女 国际学院 金融 金融gj1401 2014
012172172170101 罗愚 女 国际学院 金融 金融gj1701 2017
012172172170102 卢佳 女 国际学院 金融 金融gj1701 2017
012172172170103 张郁 女 国际学院 金融 金融gj1701 2017
- # read_file()函数帮助你读取文件到列表,直接调用就可以,此段不需修改
- def read_file(filename):
- """接收一个文件名为参数,数据类型为字符串类型,文件编码为utf-8,
- 返回值为列表,列表元素为将文件每一行根据逗号切分成的列表"""
- with open(filename, 'r', encoding='utf-8') as file:
- file_to_list = [line.strip().split(',') for line in file]
- # 文件全部内容读取出来放入列表中,每个元素为一行字符串
- return file_to_list # 以列表形式返回文件中的数据
-
-
- def student_id(ls_student, ls_school, ls_major):
- """参数为三个文件对象,依序分别由读学生信息、学院信息和专业信息文件获得。返回值为列表,为包含了新生成的学号的学生信息列表。"""
- dic_school = {x[0]: x[1] for x in ls_school} # 构建学院字典
- dic_major = {x[0]: x[1] for x in ls_major} # 构建专业字典
- student_detail = []
- ###########################Begin###########################
- for student in ls_student:
- id = '012'
- id = id + student[5][2:] + dic_school[student[2]] + dic_major[student[3]] + student[4][-4:]
- id = id + '{0:0>2}'.format([x[0] for x in ls_student if student[4] == x[4]].index(student[0]) + 1)
- student_detail.append([id] + student)
- ############################End############################
- return student_detail # 返回加了学号的学生信息列表
-
-
- def student_info(stu_name, ls_student):
- """参数为学生名字字符串和学生的信息列表,返回值为该学生的详细信息"""
- ###########################Begin###########################
- info = [info for info in ls_student if info[1] == stu_name][0]
- return info
- ############################End############################
-
- def classmate(stu_class, ls_student):
- """参数为学生班级和学生信息列表,返回值为同班同学的信息列表"""
- ###########################Begin###########################
- classmate = [info for info in ls_student if info[5] == stu_class]
- return classmate
- ############################End############################
-
- if __name__ == '__main__':
- stuName = input() # 输入学生姓名
- stuClass = input() # 输入班级
- student_list = read_file('step1/studentList.csv')[1:] # 获得学生信息列表
- school_code = read_file('step1/schoolCode.csv') # 获得学院信息列表
- major_code = read_file('step1/MajorCode.csv') # 获得专业信息列表
- studentDetail = student_id(student_list, school_code, major_code) # 调用函数计算ID并插入到列表中
- print(*student_info(stuName, studentDetail)) # 输出学生信息
- ls_classmate = classmate(stuClass, studentDetail) # 返回同班同学信息列表
- for classmate in ls_classmate: # 逐个输出同学信息
- print(*classmate)
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。