Domanda

Il mio compito è quello di creare un programma che si apre e letture da un file di testo, calcola i gradi, inclusi i pesi medi, fornisce un voto finale, modificarlo in un grado di lettere e lo scrive in un nuovo file di testo.Tutto ha funzionato bene fino alla conversione dei punti per lettere.Tutti i gradi sono tra il 70-89, quindi non mi preoccupo di mettere qualsiasi altro codice per A, B, o E (F).Ogni volta che cerco di convertire il voto per la lettera, cambia il voto di tutti per un C. Dove sono andato storto?

infile = open("c:\\Python34\\MyFiles\\ClassGradebook.txt","r")  
outfile = open("c:\\Python34\\myfiles\\ClassGrades.txt","w") 

aline = infile.readline()  # uses readline method to read the first line of the file

def quizsum():
        quizsum1 = quiz1 + quiz2 + quiz3
        quizavg = (quizsum1 / 30) * .3
        return float(quizavg)

def midtermsum():
        midtermsum1 = midterm1 + midterm2
        midtermavg = (midtermsum1 / 200) * .4
        return float(midtermavg)

def finalsum():
        finalsum1 = final1
        finalavg = (finalsum1 / 100) * .3
        return float(finalavg)
def lettergrade():
        if printedgrade >= 70 <= 79:
                return "C"
        else:
                return "B"       

while aline:
        items = aline.split()   
        dataline = items[0] + " " + items[1] 
        quiz1 = int(items[2])
        quiz2 = int(items[3])
        quiz3 = int(items[4])
        midterm1 = int(items[5])
        midterm2 = int(items[6])
        final1 = int(items[7])
        quizavg = quizsum()
        midtermavg = midtermsum()
        finalavg = finalsum()
        gradetotal = quizavg + midtermavg + finalavg
        printedgrade = gradetotal * 100
        printedgrade2 = lettergrade()
        print(dataline)
        print(printedgrade2)
        outfile.write(printedgrade2 + '\n')   newline character
        aline = infile.readline()   

infile.close()  
outfile.close()  
.

È stato utile?

Soluzione

Poiché il tuo if viene sempre valutato è vero perché è fuori ordine.Dovrebbe essere:

70 <= printedgrade <= 79

La tua dichiarazione viene sempre valutata come vera perché come hai detto che tutti i voti sono 70-89 in modo che printedgrade sarà maggiore o uguale a 70 e 70 è inferiore a 79, quindi sarà sempre True.

Anche se suggerirei fortemente rendere il tuo codice il lavoro per tutti i gradi.Non puoi supporre perché questa volta i gradi sono in una certa gamma che saranno sempre.

Altri suggerimenti

if printedgrade >= 70 <= 79:
.

dovrebbe essere

if printedgrade >= 70 and printedgrade <= 79:
.

Potresti anche fare qualcosa come:

if printedgrade >= 90:
    return "A"
elif printedgrade >= 80:
    return "B"
elif printedgrade >= 70:
    return "C"
...
.

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top