Use Vim Retab para resolver TabError: ¿uso inconsistente de pestañas y espacios en sangría?
Pide disculpas por la pregunta de novato, pero he leído el manual,esta pregunta, y lo intenté varias veces sin los resultados que esperaba.
Entonces estaba usando vim para editar un archivo (adjunto). Pero cuando ejecuté, obtuve el TabError: uso inconsistente de pestañas y espacios en error de sangría.
Esto es lo que he intentado:
Abre el archivo con Vim. tipo:retab
y:x
. Ejecute el archivo nuevamente. Todavía recibí el mensaje TabError.Abra el archivo nuevamente y escriba:retab!
y:x
. Ejecute el archivo nuevamente. Todavía recibí el mensaje TabError.Abra el archivo nuevamente y escriba:retab! 4
y:x
. Ejecute el archivo nuevamente. Esta vez funciona pero no tengo idea de por qué. Además, en los archivos, la sangría parece excesivamente larga. (Yo leoaquí que el editor puede mostrar 8 espacios para una pestaña)Mis preguntas son:
Que hace:retab
, :retab!
y:retab! 4
¿media?
Por qué no:retab
trabajar en mi archivo?
#!/usr/bin/env python
#Reduce function for computing matrix multiply A*B
#Input arguments:
#variable n should be set to the inner dimension of the matrix product (i.e., the number of columns of A/rows of B)
import sys
import string
import numpy
#number of columns of A/rows of B
n = int(sys.argv[1])
#Create data structures to hold the current row/column values (if needed; your code goes here)
currentkey = None
alist = [] # list for elelents in A
blist = [] # list ,for elements in B
# input comes from STDIN (stream data that goes to the program)
for line in sys.stdin:
#Remove leading and trailing whitespace
line = line.strip()
#Get key/value
key, value = line.split('\t',1)
print(key, value)
#Parse key/value input (your code goes here)
key = (key.split(',', 1)[0], key.split(',',1)[1])
value = (value.split(',', 1)[0], value.split(',',1)[1], value.split(',',1)[2])
#If we are still on the same key...
if key==currentkey:
#Process key/value pair (your code goes here)
# store all values in a lisl
if value[0]=='A':
alist.append([value[1], value[2]])
else:
blist.append([value[1], value[2]])
#Otherwise, if this is a new key...
else:
#If this is a new key and not the first key we've seen, i.e. currentkey!=None
if currentkey:
#compute/output result to STDOUT (your code goes here)
alist = sorted(alist)
blist = sorted(blist)
newlist = [a[1]*b[1] for a,b in zip(alist, blist)]
res = newlist.sum()
print(currentkey, res)
currentkey = key
#Process input for new key (your code goes here)