Question: 1 2 . 9 LAB: Course Grade 1 2 . 9 LAB: Course Grade Write a program that reads the student information from a tab

12.9 LAB: Course Grade12.9 LAB: Course Grade
Write a program that reads the student information from a tab separated values (tsv) file. The program then creates a text file that records the course grades of the students. Each row of the tsv file contains the Last Name, First Name, Midterm1 score, Midterm2 score, and the Final score of a student. A sample of the student information is provided in StudentInfo.tsv. Assume the number of students is at least 1 and at most 20. Assume also the last names and first names do not contain whitespaces.
The program performs the following tasks:
Read the file name of the tsv file from the user.
Open the tsv file and read the student information.
Compute the average exam score of each student.
Assign a letter grade to each student based on the average exam score in the following scale:
A: 90= x
B: 80= x 90
C: 70= x 80
D: 60= x 70
F: x 60
Compute the average of each exam.
Output the last names, first names, exam scores, and letter grades of the students into a text file named report.txt. Output one student per row and separate the values with a tab character.
Output the average of each exam, with two digits after the decimal point, at the end of report.txt. Hint: Use the format specification to set the precision of the output.
Ex: If the input of the program is:
StudentInfo.tsv
and the contents of StudentInfo.tsv are:
Barrett Edan 704559
Bradshaw Reagan 969788
Charlton Caius 739480
Mayo Tyrese 886136
Stern Brenda 908645
the file report.txt should contain:
Barrett Edan 704559 F
Bradshaw Reagan 969788 A
Charlton Caius 739480 B
Mayo Tyrese 886136 D
Stern Brenda 908645 C
Averages: midterm183.40, midterm276.60, final 61.60
Write a program that reads the student information from a tab separated values (tsv) file. The program then creates a text file that records the course grades of the students. Each row of the tsv file contains the Last Name, First Name, Midterm1 score, Midterm2 score, and the Final score of a student. A sample of the student information is provided in StudentInfo.tsv. Assume the number of students is at least 1 and at most 20. Assume also the last names and first names do not contain whitespaces.
The program performs the following tasks:
Read the file name of the tsv file from the user.
Open the tsv file and read the student information.
Compute the average exam score of each student.
Assign a letter grade to each student based on the average exam score in the following scale:
A: 90= x
B: 80= x 90
C: 70= x 80
D: 60= x 70
F: x 60
Compute the average of each exam.
Output the last names, first names, exam scores, and letter grades of the students into a text file named report.txt. Output one student per row and separate the values with a tab character.
Output the average of each exam, with two digits after the decimal point, at the end of report.txt. Hint: Use the format specification to set the precision of the output.
Ex: If the input of the program is:
StudentInfo.tsv
and the contents of StudentInfo.tsv are:
Barrett Edan 704559
Bradshaw Reagan 969788
Charlton Caius 739480
Mayo Tyrese 886136
Stern Brenda 908645
the file report.txt should contain:
Barrett Edan 704559 F
Bradshaw Reagan 969788 A
Charlton Caius 739480 B
Mayo Tyrese 886136 D
Stern Brenda 908645 C
Averages: midterm183.40, midterm276.60, final 61.60
my code: def calculate_grade(score):
if score >=90:
return 'A'
elif score >=80:
return 'B'
elif score >=70:
return 'C'
elif score >=60:
return 'D'
else:
return 'F'
def main():
file_name = input("Enter the name of the TSV file: ")
try:
with open(file_name, 'r') as file:
lines = file.readlines()
student_grades =[]
for line in lines:
parts = line.strip().split() # Changed this line
last_name, first_name, midterm1, midterm2, final = parts
midterm1= int(midterm1)
midterm2= int(midterm2)
final = int(final)
average_score =(midterm1+ midterm2+ final)/3
letter_grade = calculate_grade(average_score)
student_grades.append((last_name, first_name, midterm1, midterm2, final, letter_grade))
with open('report.txt','w') as report_file:
for student in student_grades:
report_file.write('\t'.join(map(str, student))+'
')
# Calculate averages
midterm1_avg = sum(student[2] for student in student_grades)/ len(student_grades)
midterm2_avg = sum(student[3] for student in student_grades)/ len(student_grades)
final_avg = sum(student[4] for student in student_grades)/ len(student_grades)
report_file.
error im getting in picture attached. in python please!
1 2 . 9 LAB: Course Grade 1 2 . 9 LAB: Course

Step by Step Solution

There are 3 Steps involved in it

1 Expert Approved Answer
Step: 1 Unlock blur-text-image
Question Has Been Solved by an Expert!

Get step-by-step solutions from verified subject matter experts

Step: 2 Unlock
Step: 3 Unlock

Students Have Also Explored These Related Programming Questions!