Te estas dividiendo b1
En espacios individuales, y esto puede conducir a valores vacíos:
>>> '88 89 '.split(' ')
['88', '', '89', '']
Son las cuerdas adicionales vacías aquí las que causan int()
Para lanzar una excepción:
>>> int('')
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
ValueError: invalid literal for int() with base 10: ''
Usar str.split()
con no argumento en su lugar; Se despoja el espacio en blanco adicional:
>>> '88 89 '.split()
['88', '89']
También tiene otros problemas en su código. Mira bien:
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
Aquí, lenoffile
es no El número de líneas en el archivo. Es el número de caracteres en 'Lab8.txt'
; ambos valores suceder ser - estar 8
, pero agregue o elimine algunas líneas de ese archivo y el número estará mal para el resto de su código.
Si se supone que debe mantener estos números junto con los nombres y volver a escribir los cálculos, tendrá que hacer algo de trabajo acuerdo los nombres juntos.
Aquí hay una versión alternativa para resolver la misma tarea:
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))