Como usuario (en lugar de diseñador) de Python, hay tres razones por las que estoy satisfecho con estas decisiones:
Principalmente, se lee mejor. Por supuesto, tengo que decidir conscientemente introducir una nueva variable al escribir , pero el código se lee con mucha más frecuencia de lo que se escribe. Una gran cantidad de código es simple en el sentido de que el flujo de control y el anidamiento no influyen en el significado y la existencia de variables. Cuando leo
it = Snark()
message = "A letter, not signed"
if random.random() > 0.5:
hunt(it)
message += " (by the Knave)"
return [it, message]
entonces, por lo general, no me importa qué mención (si es que hay alguna) de un nombre lo introduce primero, solo me importa que esté allí y qué le suceda.
Tenga en cuenta que un cuerpo significativo de pseudocódigo utiliza la misma convención (sin declaración, introducción implícita a través de la asignación), y Python a menudo se describe como pseudocódigo ejecutable, solo en broma. Cuatro caracteres adicionales para cada variable local hace, a mis ojos en mal estado, se sienten como el desorden significativo en el contexto de Python, especialmente cuando no se siente como que añade ningún valor (véase más adelante); esto sería disminuido por un :=
operador como en Go.
En segundo lugar, todavía tengo que encontrar un error tipográfico (debido a esta característica específica) que tampoco se mostró de otra manera clara. Tal vez cambie de opinión en unos años más cuando encuentre algunos errores de este tipo, pero hasta ahora está muy, muy abajo en mi lista de cosas que causan errores. Hay un buen número de preguntas sobre el tema UnboundLocalError
y es un poco difícil de explicar a los principiantes, pero la frecuencia y popularidad de esas preguntas, en comparación con otras trampas (parámetros predeterminados mutables, semántica de referencia, variables de clase versus instancia) indica que es un problema poco común.
Finalmente, la intención ... lo siento, pero realmente no puedo entender esto. Al leer y escribir Python, siempre está perfectamente claro: lo que se asigna se pretende como un local, a menos que se declare lo contrario en voz alta y explícita. No hay duda al respecto. Además, dado que (al menos en Python) una variable es local para toda la función o para nada , no puede tener un código complicado que use una variable local en una rama y una global en otra. ¿Ves un nombre asignado? Al instante sabes que siempre fue local desde el principio. Bueno, a menos que el código se rompa de una manera muy especial (y arrojará el temido UnboundLocalError
en tiempo de ejecución, al ingresar esos casos).