PYTHON: I need to get the avg statement out of the loop so that the output prints correctly.  Any suggestions. 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. 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 70 45 59 Bradshaw Reagan 96 97 88 Charlton Caius 73 94 80 Mayo Tyrese 88 61 36 Stern Brenda 90 86 45 the file report.txt should contain: Barrett Edan 70 45 59 F Bradshaw Reagan 96 97 88 A Charlton Caius 73 94 80 B Mayo Tyrese 88 61 36 D Stern Brenda 90 86 45 C Averages: midterm1 83.40, midterm2 76.60, final 61.60

Programming with Microsoft Visual Basic 2017
8th Edition
ISBN:9781337102124
Author:Diane Zak
Publisher:Diane Zak
Chapter8: Arrays
Section: Chapter Questions
Problem 14RQ
icon
Related questions
Question

PYTHON:

I need to get the avg statement out of the loop so that the output prints correctly.  Any suggestions.

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.

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 70 45 59

Bradshaw Reagan 96 97 88

Charlton Caius 73 94 80

Mayo Tyrese 88 61 36

Stern Brenda 90 86 45

the file report.txt should contain:

Barrett Edan 70 45 59 F

Bradshaw Reagan 96 97 88 A

Charlton Caius 73 94 80 B

Mayo Tyrese 88 61 36 D

Stern Brenda 90 86 45 C

Averages: midterm1 83.40, midterm2 76.60, final 61.60

 

 

Barrett Edan
70
45
59
F
Averages:
70.00
70.00
59.00
Bradshaw Reagan
96
97
88
A
Averages:
83.00
41.50
44.00
Charlton Caius
73
94
80 B
Averages:
52.00
17.33
26.67
Mayo Tyrese
88
61
36
Averages:
35.00
8.75
9.00
Stern Brenda
90
86
45
Averages:
25.00
5.00
9.00
Transcribed Image Text:Barrett Edan 70 45 59 F Averages: 70.00 70.00 59.00 Bradshaw Reagan 96 97 88 A Averages: 83.00 41.50 44.00 Charlton Caius 73 94 80 B Averages: 52.00 17.33 26.67 Mayo Tyrese 88 61 36 Averages: 35.00 8.75 9.00 Stern Brenda 90 86 45 Averages: 25.00 5.00 9.00
import csv
tsv_name
tsv_file
read_tsv
f =
input ()
open (tsv_name)
csv.reader(tsv_file, delimiter =
open('report.txt', 'w')
student_cnt
m1_avg
m2_avg
fexam_avg
for row in read_tsv:
student_cnt += 1
Iname
%3D
%3D
row[0]
%3D
fname = row[1]
m1 = int(row[2])
m2
fexam = int(row[4])
int (row[3])
avg
(m1 + m2 + fexam)/3
%3D
%3B
grade
if (avg >= 90):
grade = 'A'
elif (80 <= avg < 90):
grade
elif (70 <= avg < 80):
grade
elif (60 <= avg <70):
grade
else:
%3D
'B'
%3D
'C'
%3D
'D'
%3D
'F'
grade
m1_avg += m1
m2_avg += m2
fexam_avg += fexam
m1_avg
m2_avg
fexam_avg = (fexam/student_cnt)
print ('{} {} {} {} {} {}'.format(1name, fname, m1, m2, fexam, grade))
print ('Averages: {:.2f} {: .2f} {:.2f}'.format (m1_avg, m2_avg, fexam_avg))
f.close()
%3D
(m1_avg/student_cnt)
(m1_avg/student_cnt)
!!
Transcribed Image Text:import csv tsv_name tsv_file read_tsv f = input () open (tsv_name) csv.reader(tsv_file, delimiter = open('report.txt', 'w') student_cnt m1_avg m2_avg fexam_avg for row in read_tsv: student_cnt += 1 Iname %3D %3D row[0] %3D fname = row[1] m1 = int(row[2]) m2 fexam = int(row[4]) int (row[3]) avg (m1 + m2 + fexam)/3 %3D %3B grade if (avg >= 90): grade = 'A' elif (80 <= avg < 90): grade elif (70 <= avg < 80): grade elif (60 <= avg <70): grade else: %3D 'B' %3D 'C' %3D 'D' %3D 'F' grade m1_avg += m1 m2_avg += m2 fexam_avg += fexam m1_avg m2_avg fexam_avg = (fexam/student_cnt) print ('{} {} {} {} {} {}'.format(1name, fname, m1, m2, fexam, grade)) print ('Averages: {:.2f} {: .2f} {:.2f}'.format (m1_avg, m2_avg, fexam_avg)) f.close() %3D (m1_avg/student_cnt) (m1_avg/student_cnt) !!
Expert Solution
trending now

Trending now

This is a popular solution!

steps

Step by step

Solved in 4 steps with 3 images

Blurred answer
Knowledge Booster
File Input and Output Operations
Learn more about
Need a deep-dive on the concept behind this application? Look no further. Learn more about this topic, computer-science and related others by exploring similar questions and additional content below.
Similar questions
  • SEE MORE QUESTIONS
Recommended textbooks for you
Programming with Microsoft Visual Basic 2017
Programming with Microsoft Visual Basic 2017
Computer Science
ISBN:
9781337102124
Author:
Diane Zak
Publisher:
Cengage Learning
Oracle 12c: SQL
Oracle 12c: SQL
Computer Science
ISBN:
9781305251038
Author:
Joan Casteel
Publisher:
Cengage Learning