Perché questa stampare lo stesso elementare per tutto?
-
02-01-2020 - |
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()
. 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"
...
.