Python Programming: An Introduction to Computer Science, 3rd Ed.
Python Programming: An Introduction to Computer Science, 3rd Ed.
3rd Edition
ISBN: 9781590282755
Author: John Zelle
Publisher: Franklin, Beedle & Associates
bartleby

Concept explainers

bartleby

Videos

Question
Book Icon
Chapter 11, Problem 2PE
Program Plan Intro

Modified gpasort program

Program plan:

  • Import the necessary modules in “grade_sort.py” file.
  • Define the “make_Student()” function,
    • Returns student record values to the caller.
  • Define the “read_Students()” function,
    • Returns the list of student record to the caller.
  • Define the “write_Students()” function,
    • Write the student record.
  • Define the “main()” function,
    • Get the input file.
    • Read the students record for the input file.
    • Make a “while” loop for “True”.
      • Get the type of input to sort.
        • Check whether the type is “GPA” using “if”.
          • If it is true, sort the data based on the “GPA”.
          • Use “break” to exit.
        • Check whether the type is “name” using “elif”.
          • If it is true, sort the data based on the “name”.
          • Use “break” to exit.
        • Check whether the type is “credits” using “if”.
          • If it is true, sort the data based on the “credits”.
          • Use “break” to exit.
            • Write the data into the output file.
  • Create a class Student in “gpa.py” file,
    • Define the “_init_()” method.
      • Assign name hours and GPoints.
            • Define the “get_Name()” method.
              • Return the name.
            • Define the “get_Hours()” method.
              • Return hours.
            • Define the “getQ_Points()” method.
              • Return GPoints.
            • Define the “gpa()” method.
              • Return gpa
            • Define the “make_Student()” method.
              • Return name, hours, and grade points.
            • Define the main() function.
  • Call the “main()” function.

Expert Solution & Answer
Check Mark

Explanation of Solution

Program:

File name: “gpasort.py

#Import required module

from gpa import Student

#Deine the function make_Student()

def make_Student(info_Str):

    #Make multiple assignment

    Name, Hours, Gpoints = info_Str.split("\t")

    #Return constructor

    return Student(Name, Hours, Gpoints)

#Define the function read_Students()

def read_Students(file_name):

    #Openthe input file for reading

    in_file = open(file_name, 'r')

    #Create an empty list

    Students = []

    #Create ffor loop to iterate over all lines in a file

    for line in in_file:

        #Append the line in a list

        Students.append(make_Student(line))

    #Close the input file

    in_file.close()

    #Return the list

    return Students

#Define the function write_Students()

def write_Students(Students, file_name):

    #Open output file to write

    out_file = open(file_name, 'w')

    #Create a for loop to iterate over list

    for s in Students:

        #Print output

        print("{0}\t{1}\t{2}".format(s.get_Name(), s.get_Hours(), s.getQ_Points()), file = out_file)

    #Close the output file

    out_file.close()

#Define the main() function

def main():

    #Print the string

    print("This program sorts student grade information by GPA, name, or credits.")

    #Get the input file

    file_name = 'gpa1.txt'

    #Assign the data return from read_Students()

    data = read_Students(file_name)

    #Create "while" loop

    while True:

        #Get the type

        x = (input('Type "GPA", "name", or "credits" >>>  '))

        #Check whether the type is "GPA"

        if x == 'GPA':

            #Sort the data based on the gpa

            data.sort(key=Student.gpa)

            s = "_(GPA)"

            #Use break to exit

            break

        #Check whether the type is "name"

        elif x == 'name':

            #Sort the data based on the name

            data.sort(key=Student.get_Name)

            s = "_(name)"

            #Use break to exit

            break

        #Check whether the type is "credits"

        elif x == 'credits':

            #Sort the data based on the credit points

            data.sort(key=Student.getQ_Points)

            s = "_(credits)"

            #Use break to exit

            break

        #Otherwise

        else:

            #Print the string

  print("Please try again.")

    #Assign the output file

    file_name = "GPA2" + s + ".py"

    #Writ the data into output file

    write_Students(data, file_name)

    #Print the output file

    print("The data has been written to", file_name)

#Call main() function

if __name__ == '__main__': main()

File name: “gpa.py”

#Create a class Student

class Student:

    #Define _init_() method

    def __init__(self, Name, Hours, Gpoints):

        self.Name = Name

        self.Hours = float(Hours)

        self.Gpoints = float(Gpoints)

    #Define get_Name() method

    def get_Name(self):

        #Return the name

        return self.Name

    #Define get_Hours()

    def get_Hours(self):

        #return hours

        return self.Hours

    #Define getQ_Points()

    def getQ_Points(self):

        #return grade points

        return self.Gpoints

    #Define the function gpa()

    def gpa(self):

        #return the value

        return self.Gpoints / self.Hours

#Define the function make_Student()

def make_Student(info_Str):

    #Make multiple assignment

    Name, Hours, Gpoints = info_Str.split("\t")

   #Return the constructor

    return Student(Name, Hours, Gpoints)

#Define the main() function

def main():

    #Open the input file for reading

    file_name = input("Enter the name of the grade file: ")

    in_file = open(file_name, 'r')

    #Set best to the record for the first student in the file

    best = make_Student(in_file.readline())

    #Process lines of the file using "for" loop

    for line in in_file:

        #Make the line of file into a student record

        s = make_Student(line)

        #Check whether the student is best so far

        if s.gpa() > best.gpa():

            #Assign the best student record

            best = s

    #Close the input file

    in_file.close()

    #Print information about the best student

    print("The best student is:", best.get_Name())

    print("Hours:", best.get_Hours())

    print("GPA:", best.gpa())

if __name__ == '__main__':

    #Call the main() function

    main()

Sample Output

Contents of “gpa1.txt”

Adams, Henry    127    228

Computewell, Susan    100    400

DibbleBit, Denny    18    41.5

Jones, Jim    48.5    155

Smith, Frank    37    125.33

Screenshot of output file “GPA2.py” before execution:

Python Programming: An Introduction to Computer Science, 3rd Ed., Chapter 11, Problem 2PE , additional homework tip  1

Output:

This program sorts student grade information by GPA, name, or credits.

Type "GPA", "name", or "credits" >>>  name

The data has been written to GPA2_(name).py

>>>

Screenshot of output file “GPA2_(name).py after execution:

Python Programming: An Introduction to Computer Science, 3rd Ed., Chapter 11, Problem 2PE , additional homework tip  2

Additional output:

This program sorts student grade information by GPA, name, or credits.

Type "GPA", "name", or "credits" >>>  GPA

The data has been written to GPA2_(GPA).py

>>>

Screenshot of output file “GPA2_(gpa).py after execution:

Python Programming: An Introduction to Computer Science, 3rd Ed., Chapter 11, Problem 2PE , additional homework tip  3   

Want to see more full solutions like this?

Subscribe now to access step-by-step solutions to millions of textbook problems written by subject matter experts!
Students have asked these similar questions
Using the following execution shown below, explain what is done in each of the ARIES recovery algorithm phases: LSN   LOG 00   begin_checkpoint 10 end_checkpoint 20 update: T1 writes P1 30 update: T2 writes P2 40 update: T3 writes P3 50 T2 commit 60 update: T3 writes P2 70 T2 end 80 update: T1 writes P5 90 T3 abort   CRASH, RESTART In addition to the execution shown here, the system crashes during recovery after writing two log records to stable storage and again after writing another two log records
A new application is being developed and will be using a database that includes a relation about items: Item (item_id:integer, item_name:string, color:string, price:real). Both the purchasing department in charge of obtaining raw material and the manufacturing department in charge of manufacturing the items can change the price of manufactured items according to changes that may happen in the raw material cost or production cost. The two departments use different transactions to update the price of items. The new application uses the following sequences of actions, listed in the order they are submitted to the DBMS: Sequence S1: T1:R(X), T2:W(X), T2:W(Y), T3:W(Y), T1:W(Y), T1:Commit, T2:Commit, T3:Commit Sequence S2: T1:R(X), T2:W(Y), T2:W(X), T3:W(Y), T1:W(Y), T1:Commit, T2:Commit, T3:Commit For each of the following concurrency control mechanisms, describe how they will handle each of the sequences (S1 & S2). Strict 2PL with timestamps used for deadlock prevention. Conservative…
As a database administrator of a large manufacturing organization, you are in charge of their website database that handles suppliers, parts, catalog, customers, and payments of delivered items. The following relations are part of the large database: Supplier(SID, Sname, Saddress, Stelephone)Customer(CID, Cname, Caddress, Ctelephone)Part(PID, Pname, Pmodel, Pcolor)Catalog(SID, PID, Price) (The Catalog relation lists the prices charged for parts by Suppliers). Because the application is web-based and the database is accessed by many users, you want to increase the concurrency usage without compromising the data quality. For each of the following transactions, state the minimum SQL isolation level you would use in order to avoid any conflict problems in them. Please explain your choice. A transaction that adds a new part to a supplier’s catalog. A transaction that increases the price that a supplier charges for a part. A transaction that determines the total number of items for a given…
Knowledge Booster
Background pattern image
Computer Science
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
Text book image
EBK JAVA PROGRAMMING
Computer Science
ISBN:9781337671385
Author:FARRELL
Publisher:CENGAGE LEARNING - CONSIGNMENT
Text book image
Programming Logic & Design Comprehensive
Computer Science
ISBN:9781337669405
Author:FARRELL
Publisher:Cengage
Text book image
Programming with Microsoft Visual Basic 2017
Computer Science
ISBN:9781337102124
Author:Diane Zak
Publisher:Cengage Learning
Text book image
Systems Architecture
Computer Science
ISBN:9781305080195
Author:Stephen D. Burd
Publisher:Cengage Learning
Text book image
C++ Programming: From Problem Analysis to Program...
Computer Science
ISBN:9781337102087
Author:D. S. Malik
Publisher:Cengage Learning
Text book image
C++ for Engineers and Scientists
Computer Science
ISBN:9781133187844
Author:Bronson, Gary J.
Publisher:Course Technology Ptr
Constants, Variables, Data types, Keywords in C Programming Language Tutorial; Author: LearningLad;https://www.youtube.com/watch?v=d7tdL-ZEWdE;License: Standard YouTube License, CC-BY