Ti stai dividendo b1
In singoli spazi e questo può portare a valori vuoti:
>>> '88 89 '.split(' ')
['88', '', '89', '']
Sono le stringhe vuote extra qui che causano int()
Per lanciare un'eccezione:
>>> int('')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: invalid literal for int() with base 10: ''
Uso str.split()
insieme a No argomento invece; Viene quindi spogliato di spazio bianco extra:
>>> '88 89 '.split()
['88', '89']
Hai anche altri problemi nel tuo codice. Dai un'occhiata:
def lab8():
userinput= "Lab8.txt"
lenoffile= len(userinput)
print "There is", lenoffile, "lines"
File= open (userinput, "r")
studentscores1= File.read()
studentlist= studentscores1.split("\n")
return studentlist, lenoffile
Qui, lenoffile
è non il numero di righe nel file. È il numero di caratteri in 'Lab8.txt'
; entrambi valori accadere essere 8
, ma aggiungi o rimuovi alcune righe da quel file e il numero sarà sbagliato per il resto del codice.
Se dovresti tenere questi numeri insieme ai nomi e scrivere di nuovo i calcoli, dovrai fare un po 'di lavoro mantenimento i nomi insieme.
Ecco una versione alternativa per risolvere la stessa attività:
outputfile = raw_input("What is the output filename? :")
with open('Lab8.txt') as infile, open(outputfile, 'w') as outtfile:
for name in infile:
scores = next(infile).split() # next() grabs the next line from infile here
scores = map(int, scores)
quiztotal = sum(scores[:4]) / 5
midtermtotal = sum(scores[5:7]) / 2
finaltotal = scores[7]
score = quiztotal * .3 + midtermtotal * .4 + finaltotal * .3
outfile.write(name)
outfile.write('{0:0.2f}\n'.format(score))