Location via proxy:   [ UP ]  
[Report a bug]   [Manage cookies]                

Python 3

Descargar como pdf o txt
Descargar como pdf o txt
Está en la página 1de 78

La función print() - los caracteres de escape y nueva

línea
Hemos modificado el código de nuevo. Obsérvalo con cuidado.

Hay dos cambios muy sutiles: hemos insertado un par extraño de caracteres dentro del
texto. Se ven así: \n .

Curiosamente, mientras tu ves dos caracteres, Python ve solo uno.

La barra invertida ( \ ) tiene un significado muy especial cuando se usa dentro de las
cadenas, es llamado el carácter de escape.

La palabra escape debe entenderse claramente- significa que la serie de caracteres en la


cadena se escapa (detiene) por un momento (un momento muy corto) para introducir una
inclusión especial.

En otras palabras, la barra invertida no significa nada, sino que es solo un tipo de anuncio,
de que el siguiente carácter después de la barra invertida también tiene un significado
diferente.

La letra n colocada después de la barra invertida proviene de la palabra newline (nueva


linea).

Tanto la barra diagonal inversa como la n forman un símbolo especial


denominado carácter de nueva línea (newline character), que incita a la consola a iniciar
una nueva línea de salida.

Ejecuta el código. La consola ahora debería verse así:

La Witsi Witsi Araña


subió a su telaraña.

Vino la lluvia
y se la llevó.

Como se puede observar, aparecen dos nuevas líneas en la canción infantil, en los lugares
donde se ha utilizado \n .
La función print() los caracteres de escape y nueva línea
El utilizar la diagonal invertida tiene dos características importantes:

1. Si deseas colocar solo una barra invertida dentro de una cadena, no olvides su
naturaleza de escape: tienes que duplicarla, por ejemplo, la siguiente invocación causará
un error:

print("\")

Mientras que esta no lo hará:

print("\\")

2. No todos los pares de escape (la barra invertida junto con otro carácter) significan algo.

Experimenta con el código en el editor, ejecútalo y observa lo que sucede.

La función print() utilizando argumentos múltiples


Hasta ahora se ha probado el comportamiento de la función print() sin argumentos y
con un argumento. También vale la pena intentar alimentar la función print() con más de
un argumento.

Mira la ventana del editor. Esto es lo que vamos a probar ahora:

print("Witsi witsi araña" , "subió" , "su telaraña.")

Hay una invocación de la función print() pero contiene tres argumentos. Todos ellos
son cadenas.

Los argumentos están separados por comas. Se han rodeado de espacios para hacerlos
más visibles, pero no es realmente necesario y no se hará más.
En este caso, las comas que separan los argumentos desempeñan un papel
completamente diferente a la coma dentro de la cadena. El primero es una parte de la
sintaxis de Python, el segundo está destinado a mostrarse en la consola.

Si vuelves a mirar el código, verás que no hay espacios dentro de las cadenas.

Ejecuta el código y observa lo que pasa.

La consola ahora debería mostrar el siguiente texto:

La Witsi witsi araña subió su telaraña.

Los espacios, removidos de las cadenas, han vuelto a aparecer. ¿Puedes explicar porque?

Dos conclusiones surgen de este ejemplo:

 Una función print() invocada con más de un argumento genera la salida en una
sola línea.
 La función print() pone un espacio entre los argumentos emitidos por iniciativa
propia.

La función print() utilizando argumentos múltiples


Hasta ahora se ha probado el comportamiento de la función print() sin argumentos y
con un argumento. También vale la pena intentar alimentar la función print() con más de
un argumento.

Mira la ventana del editor. Esto es lo que vamos a probar ahora:

print("Witsi witsi araña" , "subió" , "su telaraña.")

Hay una invocación de la función print() pero contiene tres argumentos. Todos ellos
son cadenas.

Los argumentos están separados por comas. Se han rodeado de espacios para hacerlos
más visibles, pero no es realmente necesario y no se hará más.

En este caso, las comas que separan los argumentos desempeñan un papel
completamente diferente a la coma dentro de la cadena. El primero es una parte de la
sintaxis de Python, el segundo está destinado a mostrarse en la consola.
Si vuelves a mirar el código, verás que no hay espacios dentro de las cadenas.

Ejecuta el código y observa lo que pasa.

La consola ahora debería mostrar el siguiente texto:

La Witsi witsi araña subió su telaraña.

Los espacios, removidos de las cadenas, han vuelto a aparecer. ¿Puedes explicar porque?

Dos conclusiones surgen de este ejemplo:

 Una función print() invocada con más de un argumento genera la salida en una
sola línea.
 La función print() pone un espacio entre los argumentos emitidos por iniciativa
propia.

La función print() - los argumentos de palabras clave


Python ofrece otro mecanismo para transmitir o pasar los argumentos, que puede ser útil
cuando se desea convencer a la función print() de que cambie su comportamiento un
poco.

No se va a explicar en profundidad ahora. Se planea hacer esto cuando se trate el tema


de funciones. Por ahora, simplemente queremos mostrarte como funciona. Siéntete libre
de utilizarlo en tus propios programas.

El mecanismo se llama argumentos de palabras clave. El nombre se deriva del hecho de


que el significado de estos argumentos no se toma de su ubicación (posición) sino de la
palabra especial (palabra clave) utilizada para identificarlos.

La función print() tiene dos argumentos de palabras clave que se pueden utilizar para
estos propósitos. El primero de ellos se llama end .

En la ventana del editor se puede ver un ejemplo muy simple de como utilizar un
argumento de palabra clave.
Para utilizarlo es necesario conocer algunas reglas:

 Un argumento de palabra clave consta de tres elementos: una palabra clave que
identifica el argumento ( end -termina aquí); un signo de igual ( = ); y
un valor asignado a ese argumento.
 Cualquier argumento de palabra clave debe ponerse después del último
argumento posicional (esto es muy importante).

En nuestro ejemplo, hemos utilizado el argumento de palabra clave end y lo hemos


igualado a una cadena que contiene un espacio.

Ejecuta el código para ver como funciona.

La consola ahora debería mostrar el siguiente texto:

Mi nombre es Python. Monty Python.

Como puedes ver, el argumento de palabra clave end determina los caracteres que la
función print() envía a la salida una vez que llega al final de sus argumentos posicionales.

El comportamiento predeterminado refleja la situación en la que el argumento de la


palabra clave end se usa implícitamente de la siguiente manera: end="\n" .
La función print() - los argumentos de palabras clave
Y ahora, es el momento de intentar algo más difícil.

Si observas detenidamente, verás que hemos utilizado el argumento end , pero su cadena
asignada está vacía (no contiene ningún carácter).

¿Qué pasará ahora? Ejecuta el programa en el editor para averiguarlo.

Ya que al argumento end se le ha asignado a nada, la función print() tampoco genera


nada, una vez que se hayan agotado los argumentos posicionales.

La consola ahora debería mostrar el siguiente texto:

Mi nombre es Monty Python.

Nota: No se han enviado nuevas líneas a la salida..

La cadena asignada al argumento de la palabra clave end puede ser de cualquier longitud.
Experimenta con ello si gustas.

La función print() - los argumentos de palabras clave


Se estableció anteriormente que la función print() separa los argumentos generados con espacios.
Este comportamiento también puede ser cambiado.

El argumento de palabra clave que puede hacer esto se denomina sep (como separador).

Mira el código en el editor y ejecútalo.

El argumento sep entrega el siguiente resultado:

Mi-nombre-es-Monty-Python.

La función print() ahora utiliza un guión, en lugar de un espacio, para separar los argumentos
generados.

Nota: el valor del argumento sep también puede ser una cadena vacía. Pruébalo tu mismo.


Sandbox

Code
print("Mi", "nombre", "es", "Monty", "Python.", sep="-")

1
print("Mi", "nombre", "es", "Monty", "Python.", sep=" ")

 Console


Mi-nombre-es-Monty-Python.
MinombreesMontyPython.
Mi nombre es Monty Python.
Prev Next
La función print() - los argumentos de palabras clave
Ambos argumentos de palabras clave pueden mezclarse en una invocación, como aquí en
la ventana del editor.

El ejemplo no tiene mucho sentido, pero representa visiblemente las interacciones


entre end y sep .

¿Puedes predecir la salida?

Ejecuta el código y ve si coincide con tus predicciones.

Ahora que comprendes la función print() , estás listo para considerar aprender cómo
almacenar y procesar datos en Python.

Sin print() , no se podría ver ningún resultado.


Tiempo Estimado
5 minutos

Nivel de dificultad
Muy fácil

Objetivos
 Familiarizarse con la función de print() y sus capacidades de formato.
 Experimentar con el código de Python.

Escenario
Modifica la primera línea de código en el editor, utilizando las palabras clave sep y end ,
para que coincida con el resultado esperado. Recuerda, utilizar dos funciones print() .

No cambies nada en la segunda invocación de print() .

Resultado Esperado
Fundamentos***Programación***en...Python
Escenario
Recomendamos que juegues con el código que hemos escrito para ti y que realices
algunas correcciones (quizás incluso destructivas). Siéntete libre de modificar cualquier
parte del código, pero hay una condición: aprende de tus errores y saca tus propias
conclusiones.

Intenta:

 Minimizar el número de invocaciones de la función print() insertando la


secuencia \n en las cadenas.
 Hacer la flecha dos veces más grande (pero mantener las proporciones).
 Duplicar la flecha, colocando ambas flechas lado a lado; nota: una cadena se
puede multiplicar usando el siguiente truco: "string" *
2 producirá "stringstring" (te contaremos más sobre ello pronto).
 Elimina cualquiera de las comillas y observa detenidamente la respuesta de
Python; presta atención a donde Python ve un error: ¿es el lugar en donde
realmente existe el error?
 Haz lo mismo con algunos de los paréntesis.
 Cambia cualquiera de las palabras print en otra cosa (por ejemplo de minuscula
a mayuscula, Print ) - ¿Qué sucede ahora?
 Reemplaza algunas de las comillas por apóstrofes; observa lo que pasa
detenidamente.

print(" *"," * *", " * *", " * *", "*** ***", " * *", " * *", " *****", sep="\n")
Literales - los datos en si mismos
Ahora que tienes un poco de conocimiento acerca de algunas de las poderosas
características que ofrece la función print() , es tiempo de aprender sobre cuestiones
nuevas, y un nuevo término - el literal.

Un literal se refiere a datos cuyos valores están determinados por el literal mismo.

Debido a que es un concepto un poco difícil de entender, un buen ejemplo puede ser muy
útil.

Observa los siguientes dígitos:

123

¿Puedes adivinar qué valor representa? claro que puedes - es ciento veintitrés.

Que tal este:

¿Representa algún valor? Tal vez. Puede ser el símbolo de la velocidad de la luz, por
ejemplo. También puede representar la constante de integración. Incluso la longitud de
una hipotenusa en el Teorema de Pitágoras. Existen muchas posibilidades.

No se puede elegir el valor correcto sin algo de conocimiento adicional.

Y esta es la pista: 123 es un literal, y c no lo es.

Se utilizan literales para codificar datos y ponerlos dentro del código. Ahora mostraremos
algunas convenciones que se deben seguir al utilizar Python.

Literales - los datos en si mismos


Comencemos con un sencillo experimento, observa el fragmento de código en el editor.
La primera línea luce familiar. La segunda parece ser errónea debido a la falta visible de
comillas.

Intenta ejecutarlo.

Si todo salió bien, ahora deberías de ver dos líneas idénticas.

¿Qué paso? ¿Qué significa?

A través de este ejemplo, encuentras dos tipos diferentes de literales:

 Una cadena, la cual ya conoces.


 Y un número entero, algo completamente nuevo.

La función print() los muestra exactamente de la misma manera. Sin embargo,


internamente, la memoria de la computadora los almacena de dos maneras
completamente diferentes. La cadena existe como eso, solo una cadena, una serie de
letras.

El número es convertido a una representación maquina (una serie de bits). La


función print() es capaz de mostrar ambos en una forma legible para humanos.

Vamos a tomar algo de tiempo para discutir literales numéricas y su vida interna.

Enteros
Quizá ya sepas un poco acerca de como las computadoras hacen cálculos con números.
Tal vez has escuchado del sistema binario, y como es que ese es el sistema que las
computadoras utilizan para almacenar números y como es que pueden realizar cualquier
tipo de operaciones con ellos.

No exploraremos las complejidades de los sistemas numéricos posicionales, pero se


puede afirmar que todos los números manejados por las computadoras modernas son de
dos tipos:

 Enteros, es decir, aquellos que no tienen una parte fraccionaria.


 Y números punto-flotantes (o simplemente flotantes), los cuales contienen (o son
capaces de contener) una parte fraccionaría.

Esta definición no es tan precisa, pero es suficiente por ahora. La distinción es muy
importante, y la frontera entre estos dos tipos de números es muy estricta. Ambos tipos
difieren significativamente en como son almacenados en una computadora y en el rango
de valores que aceptan.
La característica del valor numérico que determina el tipo, rango y aplicación se denomina
el tipo.

Si se codifica un literal y se coloca dentro del código de Python, la forma del literal
determina la representación (tipo) que Python utilizará para almacenarlo en la memoria.

Por ahora, dejemos los números flotantes a un lado (regresaremos a ellos pronto) y
analicemos como es que Python reconoce un numero entero.

El proceso es casi como usar lápiz y papel, es simplemente una cadena de dígitos que
conforman el número, pero hay una condición, no se deben insertar caracteres que no
sean dígitos dentro del número.

Tomemos por ejemplo, el número once millones ciento once mil ciento once. Si tomaras
ahorita un lápiz en tu mano, escribirías el siguiente numero: 11,111,111 , o
así: 11.111.111 , incluso de esta manera: 11 111 111 .

Es claro que la separación hace que sea más fácil de leer, especialmente cuando el
número tiene demasiados dígitos. Sin embargo, Python no acepta estas cosas.
Esta prohibido. ¿Qué es lo que Python permite? El uso de guion bajo en los literales
numéricos.*

Por lo tanto, el número se puede escribir ya sea así: 11111111 , o como


sigue: 11_111_111 .

NOTA *Python 3.6 ha introducido el guion bajo en los literales numéricos, permitiendo
colocar un guion bajo entre dígitos y después de especificadores de base para mejorar la
legibilidad. Esta característica no está disponible en versiones anteriores de Python.

¿Cómo se codifican los números negativos en Python? Como normalmente se hace,


agregando un signo de menos. Se puede escribir: -11111111 , o -11_111_111 .

Los números positivos no requieren un signo positivo antepuesto, pero es permitido, si se


desea hacer. Las siguientes líneas describen el mismo número: +11111111 y 11111111 .
Enteros: números octales y hexadecimales
Existen dos convenciones adicionales en Python que no son conocidas en el mundo de las
matemáticas. El primero nos permite utilizar un número en su representación octal.

Si un numero entero esta precedido por un código 0O o 0o (cero-o), el numero será


tratado como un valor octal. Esto significa que el número debe contener dígitos en el
rango del [0..7] únicamente.

0o123 es un número octal con un valor (decimal) igual a 83 .

La función print() realiza la conversión automáticamente. Intenta esto:

print(0o123)

La segunda convención nos permite utilizar números en hexadecimal. Dichos números


deben ser precedidos por el prefijo 0x o 0X (cero-x).

0x123 es un número hexadecimal con un valor (decimal) igual a 291 . La función print()
puede manejar estos valores también. Intenta esto:

print(0x123)
Flotantes
Ahora es tiempo de hablar acerca de otro tipo, el cual esta designado para representar y almacenar los
números que (como lo diría un matemático) tienen una parte decimal no vacía.

Son números que tienen (o pueden tener) una parte fraccionaria después del punto decimal, y aunque
esta definición es muy pobre, es suficiente para lo que se desea discutir.

Cuando se usan términos como dos y medio o menos cero punto cuatro, pensamos en números que la
computadora considera como números punto-flotante:

2.5
-0.4

Nota: dos punto cinco se ve normal cuando se escribe en un programa, sin embargo si tu idioma nativo
prefiere el uso de una coma en lugar de un punto, se debe asegurar que el número no contenga más
comas.
Python no lo aceptará, o (en casos poco probables) puede malinterpretar el número, debido a que la
coma tiene su propio significado en Python.

Si se quiere utilizar solo el valor de dos punto cinco, se debe escribir como se mostró anteriormente.
Nota que hay un punto entre el 2 y el 5 - no una coma.

Como puedes imaginar, el valor de cero punto cuatro puede ser escrito en Python como:

0.4

Pero no hay que olvidar esta sencilla regla, se puede omitir el cero cuando es el único dígito antes del
punto decimal.

En esencia, el valor 0.4 se puede escribir como:

.4

Por ejemplo: el valor de 4.0 puede ser escrito como:

4.

Esto no cambiará su tipo ni su valor.

Enteros vs. Flotantes


El punto decimal es esencialmente importante para reconocer números punto-flotantes en Python.

Observa estos dos números:

4.0

Se puede pensar que son idénticos, pero Python los ve de una manera completamente distinta.

4 es un número entero, mientras que 4.0 es un número punto-flotante .

El punto decimal es lo que determina si es flotante.


Por otro lado, no solo el punto hace que un número sea flotante. Se puede utilizar la letra e .

Cuando se desea utilizar números que son muy pequeños o muy grandes, se puede implementar
la notación científica.

Por ejemplo, la velocidad de la luz, expresada en metros por segundo. Escrita directamente se vería de la
siguiente manera: 300000000 .

Para evitar escribir tantos ceros, los libros de texto emplean la forma abreviada, la cual probablemente
hayas visto: 3 x 108 .

Se lee de la siguiente manera: tres por diez elevado a la octava potencia.

En Python, el mismo efecto puede ser logrado de una manera similar, observa lo siguiente:

3E8

La letra E (también se puede utilizar la letra minúscula e - proviene de la palabra exponente) la cual
significa por diez a la n potencia.

Nota:

 El exponente (el valor después de la E) debe ser un valor entero.


 La base (el valor antes de la E) puede o no ser un valor entero.

Codificando Flotantes
Veamos ahora como almacenar números que son muy pequeños (en el sentido de que están muy cerca
del cero).

Una constante de física denominada "La Constante de Planck" (denotada como h), de acuerdo con los
libros de texto, tiene un valor de: 6.62607 x 10-34.

Si se quisiera utilizar en un programa, se debería escribir de la siguiente manera:

6.62607E-34
Nota: el hecho de que se haya escogido una de las posibles formas de codificación de un valor flotante
no significa que Python lo presentará de la misma manera.

Python podría en ocasiones elegir una notación diferente.

Por ejemplo, supongamos que se ha elegido utilizar la siguiente notación:

0.0000000000000000000001

Cuando se corre en Python:

print(0.0000000000000000000001)

Este es el resultado:

1e-22

salida

Python siempre elige la presentación más corta del número, y esto se debe de tomar en consideración
al crear literales.

Cadenas
Las cadenas se emplean cuando se requiere procesar texto (como nombres de cualquier tipo, direcciones,
novelas, etc.), no números.

Ya conoces un poco acerca de ellos, por ejemplo, que las cadenas requieren comillas así como los
flotantes necesitan punto decimal.

Este es un ejemplo de una cadena: "Yo soy una cadena."

Sin embargo, hay una cuestión. ¿Cómo se puede codificar una comilla dentro de una cadena que ya está
delimitada por comillas?

Supongamos que se desea mostrar un muy sencillo mensaje:


Me gusta "Monty Python"

¿Cómo se puede hacer esto sin generar un error? Existen dos posibles soluciones.

La primera se basa en el concepto ya conocido del carácter de escape, el cual recordarás se utiliza
empleando la diagonal invertida. La diagonal invertida puede también escapar de la comilla. Una
comilla precedida por una diagonal invertida cambia su significado, no es un limitador, simplemente es
una comilla. Lo siguiente funcionará como se desea:

print("Me gusta \"Monty Python\"")

Nota: ¿Existen dos comillas con escape en la cadena, puedes observar ambas?

La segunda solución puede ser un poco sorprendente. Python puede utilizar una apóstrofe en lugar de
una comilla. Cualquiera de estos dos caracteres puede delimitar una cadena, pero para ello se debe
ser consistente.

Si se delimita una cadena con una comilla, se debe cerrar con una comilla.

Si se inicia una cadena con un apóstrofe, se debe terminar con un apóstrofe.

Este ejemplo funcionará también:

print('Me gusta "Monty Python"')

Nota: en este ejemplo no se requiere nada de escapes.


Puntos Clave
1. Literales son notaciones para representar valores fijos en el código. Python tiene varios tipos de
literales, es decir, un literal puede ser un número por ejemplo, 123 ), o una cadena (por ejemplo, "Yo soy
un literal.").

2. El Sistema Binario es un sistema numérico que emplea 2 como su base. Por lo tanto, un número
binario está compuesto por 0s y 1s únicamente, por ejemplo, 1010 es 10 en decimal.

Los sistemas de numeración Octales y Hexadecimales son similares pues emplean 8 y 16 como sus bases
respectivamente. El sistema hexadecimal utiliza los números decimales más seis letras adicionales.

3. Los Enteros (o simplemente int) son uno de los tipos numéricos que soporta Python. Son números
que no tienen una parte fraccionaria, por ejemplo, 256 , o -1 (enteros negativos).

4. Los números Punto-Flotante (o simplemente flotantes) son otro tipo numérico que soporta Python.
Son números que contienen (o son capaces de contener) una parte fraccionaria, por ejemplo, 1.27 .

5. Para codificar un apóstrofe o una comilla dentro de una cadena se puede utilizar el carácter de escape,
por ejemplo, 'I\'m happy.' , o abrir y cerrar la cadena utilizando un conjunto de símbolos distintos
al símbolo que se desea codificar, por ejemplo, "I'm happy." para codificar un apóstrofe, y 'Él
dijo "Python", no "typhoon"' para codificar comillas.
6. Los Valores Booleanos son dos objetos constantes Verdadero y Falso empleados para
representar valores de verdad (en contextos numéricos 1 es True , mientras que 0 es False ).

EXTRA

Existe un literal especial más utilizado en Python: el literal None . Este literal es llamado un objeto
de NonType (ningún tipo), y puede ser utilizado para representar la ausencia de un valor. Pronto se
hablará más acerca de ello.

Ejercicio 1

¿Qué tipos de literales son los siguientes dos ejemplos?

"Hola", "007"
Revisar

Ejercicio 2

¿Qué tipo de literales son los siguientes cuatro ejemplos?

"1.5", 2.0, 528, False


Revisar

El primero es una cadena, el segundo es numérico (flotante), el tercero es numérico (entero) y el cuarto
es booleano.

Ejercicio 3

¿Cuál es el valor en decimal del siguiente numero en binario?

1011
Revisar

Es 11 , porque (2**0) + (2**1) + (2**3) = 11


Python como una calculadora
Ahora, se va a mostrar un nuevo lado de la función print(). Ya se sabe que la función es
capaz de mostrar los valores de los literales que le son pasados por los argumentos.

De hecho, puede hacer algo más. Observa el siguiente fragmento de código:

print(2+2)

Reescribe el código en el editor y ejecútalo. ¿Puedes adivinar la salida?

Deberías de ver el número cuatro. Tómate la libertad de experimentar con otros


operadores.

Sin tomar esto con mucha seriedad, has descubierto que Python puede ser utilizado como
una calculadora. No una muy útil, y definitivamente no una de bolsillo, pero una
calculadora sin duda alguna.

Tomando esto más seriamente, nos estamos adentrado en el terreno de


los operadores y expresiones.

Los Operadores Básicos


Un operador es un símbolo del lenguaje de programación, el cual es capaz de realizar
operaciones con los valores.

Por ejemplo, como en la aritmética, el signo de + (mas) es un operador el cual es capaz


de sumar dos numeros, dando el resultado de la suma.

Sin embargo, no todos los operadores de Python son tan simples como el signo de mas,
veamos algunos de los operadores disponibles en Python, las reglas que se deben seguir
para emplearlos, y como interpretar las reglas que realizan.

Se comenzará con los operadores que están asociados con las operaciones aritméticas
más conocidas:

+ , - , * , / , // , % , **
El orden en el que aparecen no es por casualidad. Hablaremos más de ello cuando se
hayan visto todos.

Recuerda: Cuando los datos y operadores se unen, forman juntos expresiones. La


expresión más sencilla es el literal.

Operadores aritméticos: exponenciación


Un signo de ** (doble asterisco) es un operador de exponenciación (potencia). El
argumento a la izquierda es la base, el de la derecha, el exponente.

Las matemáticas clásicas prefieren una notación con superíndices, como el siguiente: 23.
Los editores de texto puros no aceptan esa notación, por lo tanto Python utiliza ** en
lugar de la notación matemática, por ejemplo, 2 ** 3 .

Observa los ejemplos en la ventana del editor.

Nota: En los ejemplos, los dobles asteriscos están rodeados de espacios, no es obligatorio
hacerlo pero hace que el código sea mas legible.

Los ejemplos muestran una característica importante de los operadores numéricos de


Python.

Ejecuta el código y observa cuidadosamente los resultados que arroja. ¿Puedes observar
algo?

Recuerda: Es posible formular las siguientes reglas con base en los resultados:

 Cuando ambos ** argumentos son enteros, el resultado es entero también.


 Cuando al menos un ** argumento es flotante, el resultado también es flotante.

Esta es una distinción importante que se debe recordar.


Operadores aritméticos: multiplicación
Un símbolo de * (asterisco) es un operador de multiplicación.

Ejecuta el código y revisa si la regla de entero vs flotante aún funciona.

print(2 * 3)

print(2 * 3.)

print(2. * 3)

print(2. * 3.)

Operadores aritméticos: división


Un símbolo de / (diagonal) es un operador de división.

El valor después de la diagonal es el dividendo, el valor antes de la diagonal es el divisor.

Ejecuta el código y analiza los resultados.

print(6 / 3)

print(6 / 3.)

print(6. / 3)

print(6. / 3.)

Deberías de poder observar que hay una excepción a la regla.

El resultado producido por el operador de división siempre es flotante, sin importar si a


primera vista el resultado es flotante: 1 / 2 , o si parece ser completamente entero: 2 /
1.

¿Esto ocasiona un problema? Sí, en ocasiones se podrá necesitar que el resultado de una
división sea entero, no flotante.

Afortunadamente, Python puede ayudar con eso.


Operadores aritméticos: división entera
Un símbolo de // (doble diagonal) es un operador de división entera. Difiere del operador
estándar / en dos detalles:

 El resultado carece de la parte fraccionaria, está ausente (para los enteros), o


siempre es igual a cero (para los flotantes); esto significa que los resultados
siempre son redondeados.
 Se ajusta a la regla entero vs flotante.

Ejecuta el ejemplo debajo y observa los resultados:

print(6 // 3)
print(6 // 3.)
print(6. // 3)
print(6. // 3.)

Como se puede observar, una división de entero entre entero da un resultado entero.
Todos los demás casos producen flotantes.

Hagamos algunas pruebas mas avanzadas.

Observa el siguiente fragmento de código:

print(6 // 4)
print(6. // 4)

Imagina que se utilizó / en lugar de // - ¿Podrías predecir los resultados?

Si, sería 1.5 en ambos casos. Eso esta claro.

Pero, ¿Qué resultado se debería esperar con una división // ?

Ejecuta el código y observa por ti mismo.


Lo que se obtiene son dos unos, uno entero y uno flotante.

El resultado de la división entera siempre se redondea al valor entero inferior mas


cercano del resultado de la división no redondeada.

Esto es muy importante: el redondeo siempre va hacia abajo.

Observa el código e intenta predecir el resultado nuevamente:

print(-6 // 4)
print(6. // -4)

Nota: Algunos de los valores son negativos. Esto obviamente afectara el resultado. ¿Pero
cómo?

El resultado es un par de dos negativos. El resultado real (no redondeado) es -1.5 en


ambo casos. Sin embargo, los resultados se redondean. El redondeo se hace hacia el valor
inferior entero, dicho valor es -2 , por lo tanto los resultados son: -2 y -2.0 .

NOTA

La division entera también se le suele llamar en inglés floor division. Más adelante te
cruzarás con este término.

Operadores: residuo (módulo)


El siguiente operador es uno muy peculiar, porque no tiene un equivalente dentro de los
operadores aritméticos tradicionales.

Su representación gráfica en Python es el símbolo de % (porcentaje), lo cual puede ser un


poco confuso.

Piensa en el como una diagonal (operador de división) acompañado por dos pequeños
círculos.
El resultado de la operación es el residuo que queda de la división entera.

En otras palabras, es el valor que sobra después de dividir un valor entre otro para
producir un resultado entero.

Nota: el operador en ocasiones también es denominado módulo en otros lenguajes de


programación.

Observa el fragmento de código – intenta predecir el resultado y después ejecútalo:

print(14 % 4)

Como puedes observar, el resultado es dos. Esta es la razón:

 14 // 4 da como resultado un 3 → esta es la parte entera, es decir el cociente.


 3 * 4 da como resultado 12 → como resultado de la multiplicación entre el
cociente y el divisor.
 14 - 12 da como resultado 2 → este es el residuo.

El siguiente ejemplo es un poco mas complicado:

print(12 % 4.5)

¿Cuál es el resultado?

Revisar

Operadores: como no dividir


Como probablemente sabes, la división entre cero no funciona.

No intentes:

 Dividir entre cero.


 Realizar una división entera entre cero.
 Encontrar el residuo de una división entre cero.
Operadores: suma
El símbolo del operador de suma es el + (signo de más), el cual esta completamente
alineado a los estándares matemáticos.

De nuevo, observa el siguiente fragmento de código:

print(-4 + 4)

print(-4. + 8)

El resultado no debe de sorprenderte. Ejecuta el código y revisa los resultados.

El operador de resta, operadores unarios y binarios


El símbolo del operador de resta es obviamente - (el signo de menos), sin embargo debes
notar que este operador tiene otra función - puede cambiar el signo de un número.

Esta es una gran oportunidad para mencionar una distinción muy importante entre
operadores unarios y binarios.

En aplicaciones de resta, el operador de resta espera dos argumentos: el izquierdo


(un minuendo en términos aritméticos) y el derecho (un sustraendo).

Por esta razón, el operador de resta es considerado uno de los operadores binarios, así
como los demás operadores de suma, multiplicación y división.

Pero el operador negativo puede ser utilizado de una forma diferente, observa la ultima
línea de código del siguiente fragmento:

print(-4 - 4)

print(4. - 8)

print(-1.1)

Por cierto: también hay un operador + unario. Se puede utilizar de la siguiente manera:
print(+2)

El operador conserva el signo de su único argumento, el de la derecha.

Aunque dicha construcción es sintácticamente correcta, utilizarla no tiene mucho sentido,


y sería difícil encontrar una buena razón para hacerlo.

Observa el fragmento de código que está arriba - ¿Puedes adivinar el resultado o salida?

Operadores y sus prioridades


Hasta ahora, se ha tratado cada operador como si no tuviera relación con los otros. Obviamente, dicha
situación tan simple e ideal es muy rara en la programación real.

También, muy seguido encontrarás más de un operador en una expresión, y entonces esta presunción ya
no es tan obvia.

Considera la siguiente expresión:

2 + 3 * 5

Probablemente recordaras de la escuela que las multiplicaciones preceden a las sumas.

Seguramente recordaras que primero se debe multiplicar 3 por 5, mantener el 15 en tu memoria y


después sumar el 2, dando como resultado el 17.

El fenómeno que causa que algunos operadores actúen antes que otros es conocido como la jerarquía
de prioridades.

Python define la jerarquía de todos los operadores, y asume que los operadores de mayor jerarquía deben
realizar sus operaciones antes que los de menor jerarquía.

Entonces, si se sabe que la * tiene una mayor prioridad que la + , el resultado final debe de ser obvio.

Operadores y sus enlaces


El enlace de un operador determina el orden en que se computan las operaciones de los operadores con
la misma prioridad, los cuales se encuentran dentro de una misma expresión.
La mayoría de los operadores de Python tienen un enlazado hacia la izquierda, lo que significa que el
calculo de la expresión es realizado de izquierda a derecha.

Este simple ejemplo te mostrará como funciona. Observa:

print(9 % 6 % 2)

Existen dos posibles maneras de evaluar la expresión:

 De izquierda a derecha: primero 9 % 6 da como resultado 3 , y entonces 3 % 2 da como


resultado 1 .
 De derecha a izquierda: primero 6 % 2 da como resultado 0 , y entonces 9 % 0 causa un
error fatal.

Ejecuta el ejemplo y observa lo que se obtiene.

El resultado debe ser 1 . El operador tiene un enlazado hacia la izquierda. Pero hay una excepción
interesante.

Operadores y sus enlaces: exponenciación


Repite el experimento, pero ahora con exponentes.

Utiliza este fragmento de código:

print(2 ** 2 ** 3)

Los dos posibles resultados son:

 2 ** 2 → 4 ; 4 ** 3 → 64
 2 ** 3 → 8 ; 2 ** 8 → 256

Ejecuta el código, ¿Qué es lo que observas?

El resultado muestra claramente que el operador de exponenciación utiliza enlazado


hacia la derecha.
Lista de prioridades
Como eres nuevo a los operadores de Python, no se presenta por ahora una lista completa de las
prioridades de los operadores.

En lugar de ello, se mostrarán solo algunos, y se irán expandiendo conforme se vayan introduciendo
operadores nuevos.

Observa la siguiente tabla:

Prioridad Operador

1 +, - unario

2 **

3 *, /, %

4 +, - binario

Nota: se han enumerado los operadores en orden de la mas alta (1) a la mas baja (4) prioridad.

Intenta solucionar la siguiente expresión:

print(2 * 3 % 5)

Ambos operadores ( * y % ) tienen la misma prioridad, el resultado solo se puede obtener conociendo el
sentido del enlazado. ¿Cuál será el resultado?

Revisar

Operadores y paréntesis
Por supuesto, se permite hacer uso de paréntesis, lo cual cambiará el orden natural del cálculo de la
operación.

De acuerdo con las reglas aritméticas, las sub-expresiones dentro de los paréntesis siempre se
calculan primero.

Se pueden emplear tantos paréntesis como se necesiten, y seguido son utilizados para mejorar la
legibilidad de una expresión, aun si no cambian el orden de las operaciones.

Un ejemplo de una expresión con múltiples paréntesis es la siguiente:

print((5 * ((25 % 13) + 100) / (2 * 13)) // 2)

Intenta calcular el valor que se calculará en la consola. ¿Cuál es el resultado de la función print() ?

Revisar

10.0

Puntos Clave
1. Una expresión es una combinación de valores (o variables, operadores, llamadas a funciones,
aprenderás de ello pronto) las cuales son evaluadas y dan como resultado un valor, por ejemplo, 1+2 .

2. Los operadores son símbolos especiales o palabras clave que son capaces de operar en los valores y
realizar operaciones matemáticas, por ejemplo, el * multiplica dos valores: x*y .

3. Los operadores aritméticos en Python: + (suma), - (resta), * (multiplicación), / (división clásica:


regresan un flotante si uno de los valores es de este tipo), % (módulo: divide el operando izquierdo entre
el operando derecho y regresa el residuo de la operación, por ejemplo, 5%2=1 ), ** (exponenciación: el
operando izquierdo se eleva a la potencia del operando derecho, por
ejemplo, 2**3=2*2*2=8 ), // (división entera: retorna el numero resultado de la división, pero
redondeado al numero entero inferior más cercano, por ejemplo, 3//2.0=1.0 ).

4. Un operador unario es un operador con solo un operando, por ejemplo, -1 , o +3 .

5. Un operador binario es un operador con dos operados, por ejemplo, 4+5 , o 12%5 .

6. Algunos operadores actúan antes que otros, a esto se le llama - jerarquía de prioridades:
 Unario + y - tienen la prioridad más alta.
 Después: ** , después: * , / , y % , y después la prioridad más baja: binaria + y - .

7. Las sub-expresiones dentro de paréntesis siempre se calculan primero, por ejemplo, 15-
1*(5*(1+2))=0 .

8. Los operadores de exponenciación utilizan enlazado hacia la derecha, por


ejemplo, 2**2**3=256 .

Ejercicio 1

¿Cuál es la salida del siguiente fragmento de código?

print((2**4), (2*4.), (2*4))


Revisar

16 8.0 8

Ejercicio 2

¿Cuál es la salida del siguiente fragmento de código?

print((-2/4), (2/4), (2//4), (-2//4))


Revisar

-0.5 0.5 0 -1

Ejercicio 3

¿Cuál es la salida del siguiente fragmento de código?

print((2%-4), (2%4), (2**3**2))


Revisar

-2 2 512
¿Qué son las Variables?
Es justo que Python nos permita codificar literales, las cuales contengan valores numéricos y cadenas.

Ya hemos visto que se pueden hacer operaciones aritméticas con estos números: sumar, restar, etc. Esto
se hará una infinidad de veces en un programa.

Pero es normal preguntar como es que se pueden almacenar los resultados de estas operaciones, para
poder emplearlos en otras operaciones, y así sucesivamente.

¿Cómo almacenar los resultados intermedios, y después utilizarlos de nuevo para producir resultados
subsecuentes?

Python ayudará con ello. Python ofrece "cajas" (contenedores) especiales para este propósito, estas cajas
son llamadas variables - el nombre mismo sugiere que el contenido de estos contenedores puede variar
en casi cualquier forma.

¿Cuáles son los componentes o elementos de una variable en Python?

 Un nombre.
 Un valor (el contenido del contenedor).

Comencemos con lo relacionado al nombre de la variable.

Las variables no aparecen en un programa automáticamente. Como desarrollador, tu debes decidir


cuantas variables deseas utilizar en tu programa.

También las debes de nombrar.

Si se desea nombrar una variable, se deben seguir las siguientes reglas:

 El nombre de la variable debe de estar compuesto por MAYUSCULAS, minúsculas, dígitos, y


el carácter _ (guion bajo).
 El nombre de la variable debe comenzar con una letra.
 El carácter guion bajo es considerado una letra.
 Las mayúsculas y minúsculas se tratan de forma distinta (un poco diferente que en el mundo
real - Alicia y ALICIA son el mismo nombre, pero en Python son dos nombres de variable
distintos, subsecuentemente, son dos variables diferentes).
 El nombre de las variables no pueden ser igual a alguna de las palabras reservadas de Python (se
explicará más de esto pronto).
Nombres correctos e incorrectos de variables
Nota que la misma restricción aplica a los nombres de funciones.

Python no impone restricciones en la longitud de los nombres de las variables, pero eso no significa que
un nombre de variable largo sea mejor que uno corto.

Aquí se muestran algunos nombres de variable que son correctos, pero que no siempre son convenientes:

MiVariable , i , t34 , Tasa_Cambio , contador , DiasParaNavidad , ElNombreEsTanLargo


QueSeCometeranErroresConEl , _ .
Además, Python permite utilizar no solo las letras latinas, sino caracteres específicos de otros idiomas
que utilizan otros alfabetos.

Estos nombres de variables también son correctos:

Adiós_Señora , sûr_la_mer , Einbahnstraße , переменная .

Ahora veamos algunos nombres incorrectos:

10t (no comienza con una letra), Tasa Cambio (contiene un espacio).

Palabras Clave
Observa las palabras que juegan un papel muy importante en cada programa de Python.

['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class',


'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for',
'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal',
'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with',
'yield']

Son llamadas palabras clave o (mejor dicho) palabras reservadas. Son reservadas porque no se deben
utilizar como nombres: ni para variables, ni para funciones, ni para cualquier otra cosa que se desee
crear.

El significado de la palabra reservada está predefinido, y no debe cambiar.

Afortunadamente, debido al hecho de que Python es sensible a mayúsculas y minúsculas, cualquiera de


estas palabras se pueden modificar cambiando una o varias letras de mayúsculas a minúsculas o
viceversa, creando una nueva palabra, la cual no esta reservada.

Por ejemplo - no se puede nombrar a la variable así:

import

No se puede tener una variable con ese nombre, esta prohibido, pero se puede hacer lo siguiente:

Import

Estas palabras podrían parecer un misterio ahorita, pero pronto se aprenderá acerca de su significado.
['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class',
'continue', 'def', 'del', 'elif', 'else', 'except', 'finally',
'for', 'from', 'global', 'if', 'import', 'in', 'is', 'lambda',
'nonlocal', 'not', 'or', 'pass', 'raise', 'return', 'try', 'while',
'with', 'yield']

Nombres correctos e incorrectos de variables


Nota que la misma restricción aplica a los nombres de funciones.

Python no impone restricciones en la longitud de los nombres de las variables, pero eso no significa que
un nombre de variable largo sea mejor que uno corto.

Aquí se muestran algunos nombres de variable que son correctos, pero que no siempre son convenientes:

MiVariable , i , t34 , Tasa_Cambio , contador , DiasParaNavidad , ElNombreEsTanLargo


QueSeCometeranErroresConEl , _ .

Además, Python permite utilizar no solo las letras latinas, sino caracteres específicos de otros idiomas
que utilizan otros alfabetos.

Estos nombres de variables también son correctos:

Adiós_Señora , sûr_la_mer , Einbahnstraße , переменная .

Ahora veamos algunos nombres incorrectos:


10t (no comienza con una letra), Tasa Cambio (contiene un espacio).

Palabras Clave
Observa las palabras que juegan un papel muy importante en cada programa de Python.

['False', 'None', 'True', 'and', 'as', 'assert', 'break', 'class',


'continue', 'def', 'del', 'elif', 'else', 'except', 'finally', 'for',
'from', 'global', 'if', 'import', 'in', 'is', 'lambda', 'nonlocal',
'not', 'or', 'pass', 'raise', 'return', 'try', 'while', 'with',
'yield']

Son llamadas palabras clave o (mejor dicho) palabras reservadas. Son reservadas porque no se deben
utilizar como nombres: ni para variables, ni para funciones, ni para cualquier otra cosa que se desee
crear.

El significado de la palabra reservada está predefinido, y no debe cambiar.

Afortunadamente, debido al hecho de que Python es sensible a mayúsculas y minúsculas, cualquiera de


estas palabras se pueden modificar cambiando una o varias letras de mayúsculas a minúsculas o
viceversa, creando una nueva palabra, la cual no esta reservada.

Por ejemplo - no se puede nombrar a la variable así:

import

No se puede tener una variable con ese nombre, esta prohibido, pero se puede hacer lo siguiente:

Import

Estas palabras podrían parecer un misterio ahorita, pero pronto se aprenderá acerca de su significado.

Creando variables
¿Qué se puede poner dentro de una variable?

Cualquier cosa.
Se puede utilizar una variable para almacenar cualquier tipo de los valores que ya se han mencionado, y
muchos mas de los cuales aun no se han explicado.

El valor de la variable en lo que se ha puesto dentro de ella. Puede variar tanto como se necesite o
requiera. El valor puede ser entero, después flotante, y eventualmente ser una cadena.

Hablemos de dos cosas importantes - como son creadas las variables, y como poner valores dentro de
ellas (o mejor dicho, como dar o pasarles valores).

RECUERDA

Una variable se crea cuando se le asigna un valor. A diferencia de otros lenguajes de programación,
no es necesario declararla.

Si se le asigna cualquier valor a una variable no existente, la variable será automáticamente creada. No
se necesita hacer algo más.

La creación (o su sintaxis) es muy simple: solo utiliza el nombre de la variable deseada, después el
signo de igual (=) y el valor que se desea colocar dentro de la variable.

Observa el siguiente fragmento de código:

var = 1
print(var)
Consiste de dos simples instrucciones:

 La primera crea una variable llamada var , y le asigna un literal con un valor entero de 1 .
 La segunda imprime el valor de la variable recientemente creada en la consola.

Nota: print() tiene una función más – puede manejar variables también. ¿Puedes predecir cual
será la salida (resultado) del código?

Revisar

Utilizando variables
Se tiene permitido utilizar cuantas declaraciones de variables sean necesarias para lograr el objetivo del
programa, por ejemplo:

var = 1

balance_cuenta = 1000.0

nombreCliente = 'John Doe'

print(var, balance_cuenta, nombreCliente)

print(var)

Sin embargo, no se permite utilizar una variable que no exista, (en otras palabras, una variable a la cual
no se le a dado un valor).

Este ejemplo ocasionara un error:

var = 1

print(Var)
Se ha tratado de utilizar la variable llamada Var , la cual no tiene ningún valor (nota: var y Var son
entidades diferentes, y no tienen nada en común dentro de Python).

RECUERDA

Se puede utilizar print() para combinar texto con variables utilizando el operador + para mostrar
cadenas con variables, por ejemplo:

var = "3.7.1"

print("Versión de Python: " + var)

¿Puedes predecir la salida del fragmento de código?

Revisar

Versión de Python: 3.7.1

Asignar un valor nuevo a una variable ya existente


¿Cómo se le asigna un valor nuevo a una variable que ya ha sido creada? De la misma manera. Solo se
necesita el signo de igual.

El signo de igual es de hecho un operador de asignación. Aunque esto suene un poco extraño, el
operador tiene una sintaxis simple y una interpretación clara y precisa.

Asigna el valor del argumento de la derecha al de la izquierda, aún cuando el argumento de la derecha
sea una expresión arbitraria compleja que involucre literales, operadores y variables definidas
anteriormente.

Observa el siguiente código:

var = 1

print(var)

var = var + 1
print(var)

El código envía dos líneas a la consola:

La primer línea del código crea una nueva variable llamada var y le asigna el valor de 1 .

La declaración se lee de la siguiente manera: asigna el valor de 1 a una variable llamada var .

De manera mas corta: asigna 1 a var .

Algunos prefieren leer el código así: var se convierte en 1 .

La tercera línea le asigna a la misma variable un nuevo valor tomado de la variable misma,
sumándole 1 . Al ver algo así, un matemático probablemente protestaría, ningún valor puede ser igualado
a si mismo mas uno. Esto es una contradicción. Pero Python trata el signo = no como igual a, sino
como asigna un valor.

Entonces, ¿Cómo se lee esto en un programa?

Toma el valor actual de la variable var , sumale 1 y guárdalo en la variable var .

En efecto, el valor de la variable var ha sido incrementado por uno, lo cual no está relacionado con
comparar la variable con otro valor.

¿Puedes predecir cuál será el resultado del siguiente fragmento de código?

var = 100

var = 200 + 300

print(var)
Revisar

500 - ¿Porque? Bueno, primero, la variable var es creada y se le asigna el valor de 100. Después, a la
misma variable se le asigna un nuevo valor: el resultado de sumarle 200 a 300, lo cual es 500.

Resolviendo problemas matemáticos simples


Ahora deberías de ser capaz de construir un corto programa el cual resuelva problemas matemáticos
sencillos como el Teorema de Pitágoras:

El cuadrado de la hipotenusa es igual a la suma de los cuadrados de los dos catetos.

El siguiente código evalúa la longitud de la hipotenusa (es decir, el lado más largo de un triangulo
rectángulo, el opuesto al ángulo recto) utilizando el Teorema de Pitágoras:

a = 3.0

b = 4.0

c = (a ** 2 + b ** 2) ** 0.5

print("c =", c)

Nota: se necesita hacer uso del operador ** para evaluar la raíz cuadrada:

√ (x) = x(½)
y

c = √ a2 + b2
¿Puedes predecir la salida del código?

Revisa abajo y ejecuta el código en el editor para confirmar tus predicciones.

Revisar

c = 5.0
Operadores Abreviados
Es tiempo de explicar el siguiente conjunto de operadores que harán la vida del
programador/desarrollador mas fácil.

Muy seguido, se desea utilizar la misma variable al lado derecho y al lado izquierdo del operador = .

Por ejemplo, si se necesita calcular una serie de valores sucesivos de la potencia de 2, se puede usar el
siguiente código:

x = x * 2

También, puedes utilizar una expresión como la siguiente si no puedes dormir y estas tratando de
resolverlo con alguno de los métodos tradicionales:

oveja = oveja + 1

Python ofrece una manera mas corta de escribir operaciones como estas, lo cual se puede codificar de la
siguiente manera:

x *= 2
oveja+= 1

A continuación se intenta presentar una descripción general para este tipo de operaciones.

Si op es un operador de dos argumentos (esta es una condición muy imporante) y el operador es


utilizado en el siguiente contexto:

variable = variable op expresión

Puede ser simplificado de la siguiente manera:

variable op= expresión

Observa los siguientes ejemplos. Asegúrate de entenderlos todos.

i = i + 2 * j ⇒ i += 2 * j

var = var / 2 ⇒ var /= 2

rem = rem % 10 ⇒ rem %= 10

j = j - (i + var + rem) ⇒ j -= (i + var + rem)

x = x ** 2 ⇒ x **= 2

Operadores Abreviados
Es tiempo de explicar el siguiente conjunto de operadores que harán la vida del
programador/desarrollador mas fácil.

Muy seguido, se desea utilizar la misma variable al lado derecho y al lado izquierdo del operador = .

Por ejemplo, si se necesita calcular una serie de valores sucesivos de la potencia de 2, se puede usar el
siguiente código:

x = x * 2
También, puedes utilizar una expresión como la siguiente si no puedes dormir y estas tratando de
resolverlo con alguno de los métodos tradicionales:

oveja = oveja + 1

Python ofrece una manera mas corta de escribir operaciones como estas, lo cual se puede codificar de la
siguiente manera:

x *= 2

oveja+= 1

A continuación se intenta presentar una descripción general para este tipo de operaciones.

Si op es un operador de dos argumentos (esta es una condición muy imporante) y el operador es


utilizado en el siguiente contexto:

variable = variable op expresión

Puede ser simplificado de la siguiente manera:

variable op= expresión

Observa los siguientes ejemplos. Asegúrate de entenderlos todos.

i = i + 2 * j ⇒ i += 2 * j

var = var / 2 ⇒ var /= 2

rem = rem % 10 ⇒ rem %= 10

j = j - (i + var + rem) ⇒ j -= (i + var + rem)

x = x ** 2 ⇒ x **= 2

LABORATORIO

Tiempo estimado
10 minutos
Nivel de dificultad
Fácil

Objetivos
 Familiarizarse con el concepto de variables y trabajar con ellas.
 Realizar operaciones básicas y conversiones.
 Experimentar con el código de Python.

Escenario
Millas y kilómetros son unidades de longitud o distancia.

Teniendo en mente que 1 equivale aproximadamente a 1.61 kilómetros, complemente el


programa en el editor para que convierta de:

 Millas a kilómetros.
 Kilómetros a millas.

No se debe cambiar el código existente. Escribe tu código en los lugares indicados


con ### . Prueba tu programa con los datos que han sido provistos en el código fuente.

Pon mucha atención a lo que esta ocurriendo dentro de la función print() . Analiza como
es que se proveen múltiples argumentos para la función, y como es que se muestra el
resultado.

Nota que algunos de los argumentos dentro de la función print() son cadenas (por
ejemplo "millas son" , y otros son variables (por ejemplo millas ).

CONSEJO

Hay una cosa interesante mas que esta ocurriendo. ¿Puedes ver otra función dentro de la
función print() ? Es la función round() . Su trabajo es redondear la salida del resultado
al numero de decimales especificados en el paréntesis, y regresar un valor flotante
(dentro de la función round() se puede encontrar el nombre de la variable, el nombre,
una coma, y el numero de decimales que se desean mostrar). Se hablará mas de esta
función muy pronto, no te preocupes si no todo queda muy claro. Solo se quiere impulsar
tu curiosidad.
Después de completar el laboratorio , abre Sandbox (el arenero), y experimenta más.
Intenta escribir diferentes convertidores, por ejemplo, un convertidor de USD a EUR, un
convertidor de temperatura, etc. – ¡deja que tu imaginación vuele! Intenta mostrar los
resultados combinando cadenas y variables. Intenta utilizar y experimentar con la
función round() para redondear tus resultados a uno, dos o tres decimales. Revisa que
es lo que sucede si no se provee un dígito al redondear. Recuerda probar tus programas.

Experimenta, saca tus propias conclusiones, y aprende. Se curioso.

Resultado Esperado
7.38 millas son 11.88 kilómetros

12.25 kilómetros son 7.61 millas

LABORATORIO

Tiempo Estimado
10-15 minutos
Nivel de Dificultad
Fácil

Objetivos
 Familiarizarse con los conceptos de números, operadores y operaciones
aritméticas en Python.
 Realizar cálculos básicos.

Escenario
Observa el código en el editor: lee un valor flotante , lo coloca en una variable llamada x ,
e imprime el valor de la variable llamada y . Tu tarea es completar el código para evaluar
la siguiente expresión:

3x3 - 2x2 + 3x - 1

El resultado debe ser asignado a y .

Recuerda que la notación algebraica clásica muy seguido omite el operador de


multiplicación, aquí se debe de incluir de manera explicita. Nota como se cambia el tipo
de dato para asegurarnos de que x es del tipo flotante .

Mantén tu código limpio y legible, y pruébalo utilizando los datos que han sido
proporcionados. No te desanimes por no lograrlo en el primer intento. Se persistente y
curioso.

Prueba de Datos
Datos de Muestra

x = 0

x = 1

x = -1

Salida Esperada

y = -1.0
y = 3.0

y = -9.0

Puntos Clave

1. Una variable es una ubicación nombrada reservada para almacenar valores en la memoria. Una
variable es creada o inicializada automáticamente cuando se le asigna un valor por primera vez.

2. Cada variable debe de tener un nombre único - un identificador. Un nombre valido debe ser aquel
que no contiene espacios, debe comenzar con un guion bajo ( _ ), o una letra, y no puede ser una palabra
reservada de Python. El primer carácter puede estar seguido de guiones bajos, letras, y dígitos. Las
variables en Python son sensibles a mayúsculas y minúsculas.

3. Python es un lenguaje de tipo dinámico, lo que significa que no se necesita declarar variables en él.
Para asignar valores a las variables, se utiliza simplemente el operador de asignación, es decir el signo de
igual ( = ) por ejemplo, var = 1 .

4. También es posible utilizar operadores de asignación compuesta (operadores abreviados) para


modificar los valores asignados a las variables, por ejemplo, var += 1 , or var /= 5 * 2 .

5. Se les puede asignar valores nuevos a variables ya existentes utilizando el operador de asignación o un
operador abreviado:

var = 2

print(var)

var = 3

print(var)

var += 1

print(var)

6. Se puede combinar texto con variables empleado el operador + , y utilizar la función print() para
mostrar o imprimir los resultados, por ejemplo:
var = "007"

print("Agente " + var)

Ejercicio 1

¿Cuál es el resultado del siguiente fragmento de código?

var = 2

var = 3

print(var)
Revisar

Ejercicio 2

¿Cuáles de los siguientes nombres de variables son ilegales en Python?

my_var

101

averylongvariablename

m101

m 101

Del

del
Revisar

my_var

m
101 # incorrecto (comienza con un digito)

averylongvariablename

m101

m 101 # incorrecto (contiene un espacio)

Del

del # incorrecto (es una palabra clave)

Ejercicio 3

¿Cuál es el resultado del siguiente fragmento de código?

a = '1'

b = "1"

print(a + b)
Revisar

11

Ejercicio 4

¿Cuál es el resultado del siguiente fragmento de código?

a = 6

b = 3

a /= 2 * b

print(a)
Revisar

1.0
2*b=6
a = 6 → 6 / 6 = 1.0
Poner comentarios en el código: ¿por qué, cuándo y
dónde?
Quizá en algún momento será necesario poner algunas palabras en el código dirigidas no a Python, sino
a las personas quienes estén leyendo el código con el fin de explicarles como es que funciona, o tal vez
especificar el significado de las variables, también para documentar quien es el autor del programa y en
que fecha fue escrito.

Un texto insertado en el programa el cual es, omitido en la ejecución, es denominado un comentario.

¿Cómo se colocan este tipo de comentarios en el código fuente? Tiene que ser hecho de cierta manera
para que Python no intente interpretarlo como parte del código.

Cuando Python se encuentra con un comentario en el programa, el comentario es completamente


transparente, desde el punto de vista de Python, el comentario es solo un espacio vacío, sin importar que
tan largo sea.

En Python, un comentario es un texto que comienza con el símbolo # y se extiende hasta el final de la
línea.

Si se desea colocar un comentario que abarca varias líneas, se debe colocar este símbolo en cada línea.

Justo como el siguiente código:

# Esta programa calcula la hipotenusa (c)


# a y b son las longitudes de los catetos

a = 3.0

b = 4.0

c = (a ** 2 + b ** 2) ** 0.5 # se utiliza ** en lugar de la raíz


cuadrada

print("c =", c)

Los desarrolladores buenos y responsables describen cada pieza importante de código, por ejemplo, el
explicar el rol de una variable; aunque la mejor manera de comentar una variable es dándole un nombre
que no sea ambiguo.

Por ejemplo, si una variable determinada esta diseñada para almacenar el área de un cuadrado, el
nombre areaCuadrado será muchísimo mejor que tiaJuana .

El primer nombre dado a la variable se puede definir como auto-comentable.

Los comentarios pueden ser útiles en otro aspecto, se pueden utilizar para marcar un fragmento de
código que actualmente no se necesita, cual sea la razón. Observa el siguiente ejemplo, sí
se descomenta la línea resaltada, esto afectara la salida o resultado del código:

# Este es un programa de prueba

x = 1

y = 2

# y = y + x

print(x + y)

Esto es frecuentemente realizado cuando se esta probando un programa, con el fin de aislar un fragmento
de código donde posiblemente se encuentra un error.
LABORATORIO

Tiempo Estimado
5 minutos

Nivel de Dificultad
Muy Fácil

Objetivos
 Familiarizarse con el concepto de comentarios en Python.
 Utilizar y no utilizar los comentarios.
 Reemplazar los comentarios con código.
 Experimentar con el código de Python.

Escenario
El código en el editor contiene comentarios. Intenta mejorarlo: agrega o quita
comentarios donde consideres que sea apropiado (en ocasiones el remover un
comentario lo hace mas legible), además, cambia el nombre de las variables donde
consideres que esto mejorará la comprensión del código.

NOTA

Los comentarios son muy importantes. No solo hacen que el programa sea más fácil de
entender, pero también sirven para deshabilitar aquellas partes de código que no son
necesarias (por ejemplo, cuando se necesita probar cierta parte del código, e ignorar el
resto). Los buenos programadores describen cada parte importante del código, y
dan nombres significativos a variables, debido a que en ocasiones es mucho más sencillo
dejar el comentario dentro del código mismo.

Es bueno utilizar nombres de variables legibles, y en ocasiones es mejor dividir el


código en partes con nombres (por ejemplo en funciones). En algunas situaciones, es una
buena idea escribir los pasos de como se realizaron los cálculos de una forma sencilla y
clara.

Una cosa mas: puede ocurrir que un comentario contenga una pieza de información
incorrecta o errónea, nunca se debe de hacer eso a propósito.
La función input()
Ahora se introducirá una nueva función, la cual pareciese ser un reflejo de la función print() .

¿Por que? Bueno, print() envía datos a la consola.

Esta nueva función obtiene datos de ella.

print() no tiene un resultado utilizable. La importancia de esta nueva función es que regresa un
valor muy utilizable.

La función se llama input() . El nombre de la función lo dice todo.

La función input() es capaz de leer datos que fueron introducidos por el usuario y pasar esos datos al
programa en ejecución.

El programa entonces puede manipular los datos, haciendo que el código sea verdaderamente
interactivo.

Todos los programas leen y procesan datos. Un programa que no obtiene datos de entrada del usuario
es un programa sordo.

Observa el ejemplo:

print("Dime algo...")
algo = input()
print("Mmm...", algo, "...¿en serio?")

Se muestra un ejemplo muy sencillo de como utilizar la función input() .

Nota:

 El programa solicita al usuario que inserte algún dato desde la consola (seguramente
utilizando el teclado, aunque también es posible introducir datos utilizando la voz o alguna
imagen).
 La función input() es invocada sin argumentos (es la manera mas sencilla de utilizar la
función); la función pondrá la consola en modo de entrada; aparecerá un cursor que parpadea,
y podrás introducir datos con el teclado, al terminar presiona la tecla Enter; todos los datos
introducidos serán enviados al programa a través del resultado de la función.
 Nota: el resultado debe ser asignado a una variable; esto es crucial, si no se hace los datos
introducidos se perderán.
 Después se utiliza la función print() para mostrar los datos que se obtuvieron, con algunas
observaciones adicionales.

Intenta ejecutar el código y permite que la función te muestre lo que puede hacer.
La función input() con un argumento
La función input() puede hacer algo más: puede mostrar un mensaje al usuario sin la ayuda de la
función print() .

Se ha modificado el ejemplo un poco, observa el código:

algo = input("Dime algo...")


print("Mmm...", algo, "...¿En serio?")

Nota:

 La función input() al ser invocada con un argumento, contiene una cadena con un mensaje.
 El mensaje será mostrado en consola antes de que el usuario tenga oportunidad de escribir algo.
 Después de esto input() hará su trabajo.

Esta variante de la invocación de la función input() simplifica el código y lo hace más claro.

El resultado de la función input()


Se ha dicho antes, pero hay que decirlo sin ambigüedades una vez más: el resultado de la
función input() es una cadena.
Una cadena que contiene todos los caracteres que el usuario introduce desde el teclado. No es un entero
ni un flotante.

Esto significa que no se debe utilizar como un argumento para operaciones matemáticas, por
ejemplo, no se pueden utilizar estos datos para elevarlos al cuadrado, para dividirlos entre algo o por
algo.

cualquierNumero = input("Inserta un número: ")


algo = cualquierNumero ** 2.0
print(cualquierNumero, "al cuadrado es", algo)

La función input() - operaciones prohibidas


Observa el código en el editor. Ejecútalo, inserta cualquier número, y oprime Enter.

¿Qué es lo que ocurre?

Python debió haberte dado la siguiente salida:

Traceback (most recent call last):

File ".main.py", line 4, in <module>

resultado = algo ** 2.0

TypeError: unsupported operand type(s) for ** or pow(): 'str' and


'float'
La última línea lo explica todo, se intentó aplicar el operador ** a 'str' (una cadena)
acompañado por un 'float' (valor flotante).

Esto está prohibido.

Esto debe de ser obvio – ¿Puedes predecir el valor de "ser o no ser" elevado a
la 2 potencia?

No podemos. Python tampoco puede.

¿Habremos llegado a un punto muerto? ¿Existirá alguna solución? Claro que la hay.

Conversión de datos o casting


Python ofrece dos simples funciones para especificar un tipo de dato y resolver este problema, aquí
están: int() y float() .

Sus nombres indican cual es su función:

 La función int() toma un argumento (por ejemplo, una cadena: int(string) ) e intenta
convertirlo a un valor entero; si llegase a fallar, el programa entero fallará también (existe una
manera de solucionar esto, se explicará mas adelante).
 La función float() toma un argumento (por ejemplo, una cadena: float(string) ) e
intenta convertirlo a flotante (el resto es lo mismo).

Esto es muy simple y muy efectivo. Sin embargo, estas funciones se pueden invocar directamente
pasando el resultado de la función input() directamente. No hay necesidad de emplear variables como
almacenamiento intermedio.

Se ha implementado esta idea en el editor, observa el código.

¿Puedes imaginar como la cadena introducida por el usuario fluye desde la función input() hacía la
función print() ?

Intenta ejecutar el código modificado. No olvides introducir un número valido.

Prueba con diferentes valores, pequeños, grandes, negativos y positivos. El cero también es un buen
valor a introducir.


Sandbox

Code
algo = float(input("Inserta un número: "))
resultado = algo ** 2.0
print(algo, "al cuadrado es", resultado)

1
2
3
algo = float(input("Inserta un número: "))
resultado = algo ** 2.0

print(algo, "al cuadrado es", resultado)

 Console


Prev Next
Más acerca de la función input() y tipos de conversión
El tener un equipo compuesto por input() - int() - float() abre muchas nuevas
posibilidades.

Eventualmente serás capaz de escribir programas completos, los cuales acepten datos en
forma de números, los cuales serán procesados y se mostrarán los resultados.

Por supuesto, estos programas serán muy primitivos y no muy utilizables, debido a que
no pueden tomar decisiones, y consecuentemente no son capaces de reaccionar acorde a
cada situación.

Sin embargo, esto no es un problema; se explicará como solucionarlo pronto.

El siguiente ejemplo hace referencia al programa anterior que calcula la longitud de la


hipotenusa. Vamos a reescribirlo, para que pueda leer las longitudes de los catetos desde
la consola.

Revisa la ventana del editor, así es como se ve ahora.

Este programa le preguntó al usuario los dos catetos, calcula la hipotenusa e imprime el
resultado.

Ejecútalo de nuevo e intenta introducir valores negativos.

El programa desafortunadamente, no reacciona correctamente a este error.

Vamos a ignorar esto por ahora. Regresaremos a ello pronto.

Debido a que la función print() acepta una expresión como argumento, se puede quitar
la variable del código.

Como se muestra en el siguiente código:

cateto_a = float(input("Inserta la longitud del primer cateto: "))

cateto_b = float(input("Inserta la longitud del segundo cateto "))

print("La longitud de la hipotenusa es: ", (cateto_a**2 + cateto_b**2


Operadores de cadenas - introducción
Es tiempo de regresar a estos dos operadores aritméticos: + y * .

Ambos tienen una función secundaría. Son capaces de hacer algo más
que sumar y multiplicar.

Los hemos visto en acción cuando sus argumentos son (flotantes o enteros).

Ahora veremos que son capaces también de manejar o manipular cadenas, aunque, en
una manera muy específica.

Concatenación
El sigo de + (más), al ser aplicado a dos cadenas, se convierte en un operador de
concatenación:

string + string
Simplemente concatena (junta) dos cadenas en una. Además, puede ser utilizado más de
una vez en una misma expresión.

En contraste con el operador aritmético, el operador de concatenación no es conmutativo,


por ejemplo, "ab" + "ba" no es lo mismo que "ba" + "ab" .

No olvides, si se desea que el signo + sea un concatenador, no un sumador, solo se debe


asegurar que ambos argumentos sean cadenas.

No se pueden mezclar los tipos de datos aquí.

Este es un programa sencillo que muestra como funciona el signo + como concatenador:

nom = input("¿Me puedes dar tu nombre por favor? ")

ape = input("¿Me puedes dar tu apellido por favor? ")

print("Gracias.")

print("\nTu nombre es " + nom + " " + ape + ".")

Nota: El utilizar + para concatenar cadenas te permite construir la salida de una manera
más precisa, en comparación de utilizar únicamente la función print() , aún cuando se
enriquezca con los argumentos end= y sep= .

Ejecuta el código y comprueba si la salida es igual a tus predicciones.


Replicación
El signo de * (asterisco), cuando es aplicado a una cadena y a un número (o a un número
y cadena) se convierte en un operador de replicación.

cadena * número
número * cadena

Replica la cadena el numero de veces indicado por el número.

Por ejemplo:

 "James" * 3 nos da "JamesJamesJames" .


 3 * "an" nos da "ananan" .
 5 * "2" (o "2" * 5 ) da como resultado "22222" (no 10 ).

RECUERDA

Un número menor o igual que cero produce una cadena vacía.


Este sencillo programa "dibuja" un rectángulo, haciendo uso del operador ( + ), pero en un
nuevo rol:

print("+" + 10 * "-" + "+")


print(("|" + " " * 10 + "|\n") * 5, end="")
print("+" + 10 * "-" + "+")

Nota como se ha utilizado el paréntesis en la segunda línea de código.

¡Intenta practicar para crear otras figuras o tus propias obras de arte!

Conversión de tipos de datos: str()


A estas alturas ya sabes como emplear las funciones int() y float() para convertir una
cadena a un número.

Este tipo de conversión no es en un solo sentido. También se puede convertir un numero


a una cadena, lo cual es más fácil y rápido, esta operación es posible hacerla siempre.

Una función capaz de hacer esto se llama str() :

str(número)

Sinceramente, puede hacer mucho más que transformar números en cadenas, eso lo
veremos después.

El "triángulo rectángulo" de nuevo


Este es el programa del "triángulo rectángulo" visto anteriormente:

cateto_a = float(input("Ingresa la longitud del primer cateto: "))

cateto_b = float(input("Ingresa la longitud del segundo cateto: "))


print("La longitud de la hipotenusa es: " + str((cateto_a**2 +
cateto_b**2) ** .5))

Se ha modificado un poco para mostrar cómo es que la función str() trabaja. Gracias a
esto, podemos pasar el resultado entero a la función print() como una sola cadena, sin
utilizar las comas.

Has hecho algunos pasos importantes en tu camino hacia la programación de Python.

Ya conoces los tipos de datos básicos y un conjunto de operadores fundamentales. Sabes


cómo organizar la salida y cómo obtener datos del usuario. Estos son fundamentos muy
sólidos para el Módulo 3. Pero antes de pasar al siguiente módulo, hagamos unos cuantos
laboratorios y resumamos todo lo que has aprendido en esta sección.
Este código de aquí lo practique yo según lo que pidió el curso interactivo.

LABORATORIO

Tiempo estimado
20 minutos

Nivel de dificultad
Intermedio

Objetivos
 Familiarizarse con los conceptos de números, operadores y expresiones
aritméticas en Python.
 Comprender la precedencia y asociatividad de los operadores de Python, así como
el correcto uso de los paréntesis.

Escenario
La tarea es completar el código para poder evaluar la siguiente expresión:
El resultado debe de ser asignado a y . Se cauteloso, observa los operadores y priorízalos.
Utiliza cuantos paréntesis sean necesarios.

Puedes utilizar variables adicionales para acortar la expresión (sin embargo, no es muy
necesario). Prueba tu código cuidadosamente.

Datos de Prueba
Entrada de muestra: 1

Salida esperada:

y = 0.6000000000000001

Entrada de muestra: 10

Salida esperada:

y = 0.09901951266867294

Entrada de muestra: 100

Salida esperada:

y = 0.009999000199950014
Entrada de muestra: -5

Salida esperada:

y = -0.19258202567760344

Tiempo estimado
15-20 minutos

Nivel de dificultad
Fácil

Objetivos
 Mejorar la habilidad de implementar números, operadores y operaciones
aritméticas en Python.
 Utilizar la función print() y sus capacidades de formateo.
 Aprender a expresar fenómenos del día a día en términos de un lenguaje de
programación.
Escenario
La tarea es preparar un código simple para evaluar o encontrar el tiempo final de un
periodo de tiempo dado, expresándolo en horas y minutos. Las horas van de 0 a 23 y los
minutes de 0 a 59. El resultado debe ser mostrado en la consola.

Por ejemplo, si el evento comienza a las 12:17 y dura 59 minutos, terminará a las 13:16.

No te preocupes si tu código no es perfecto, está bien si acepta una hora invalida, lo más
importante es que el código produzca una salida correcta acorde a la entrada dada.

Prueba el código cuidadosamente. Pista: utilizar el operador % puede ser clave para el
éxito.

Datos de Prueba
Entrada de muestra:12

17

59

Salida esperada: 13:16

Entrada de muestra:23

58

642

Salida esperada: 10:40

Entrada de muestra:0

2939
Salida esperada: 1:0

Puntos Clave

1. La función print() envía datos a la consola, mientras que la función input() obtiene
datos de la consola.

2. La función input() viene con un parámetro inicial: un mensaje de tipo cadena para el
usuario. Permite escribir un mensaje antes de la entrada del usuario, por ejemplo:

nombre = input("Ingresa tu nombre: ")


print("Hola, " + nombre + ". ¡Un gusto conocerte!")
3. Cuando la función input() es llamada o invocada, el flujo del programa se detiene, el
símbolo del cursor se mantiene parpadeando (le está indicando al usuario que tome
acción ya que la consola está en modo de entrada) hasta que el usuario haya ingresado
un dato y/o haya presionado la tecla Enter.

NOTA

Puedes probar la funcionalidad completa de la función input() localmente en tu


máquina. Por razones de optimización, se ha limitado el máximo número de ejecuciones
en Edube a solo algunos segundos únicamente. Ve a Sandbox, copia y pega el código que
está arriba, ejecuta el programa y espera unos segundos. Tu programa debe detenerse
después de unos segundos. Ahora abre IDLE, y ejecuta el mismo programa ahí -¿Puedes
notar alguna diferencia?

Consejo: La característica mencionada anteriormente de la función input() puede ser


utilizada para pedirle al usuario que termine o finalice el programa. Observa el siguiente
código:

nombre = input("Ingresa tu nombre: ")


print("Hola, " + nombre + ". ¡Un gusto conocerte!")

print("\nPresiona la tecla Enter para finalizar el programa.")


input()
print("FIN.")

3. El resultado de la función input() es una cadena. Se pueden unir cadenas unas con
otras a través del operador de concatenación ( + ). Observa el siguiente código:

num1 = input("Ingresa el primer número: ") # Ingresa 12


num2 = input("Ingresa el segundo número: ") # Ingresa 21

print(num1 + num2) # el programa regresa 1221

4. También se pueden multiplicar ( * - replicación) cadenas, por ejemplo:

miEntrada = ("Ingresa Algo: ") # Ejemplo: hola


print(miEntrada * 3) # Salida esperada: holaholahola

Puntos Clave
1. La función print() envía datos a la consola, mientras que la función input() obtiene datos de
la consola.

2. La función input() viene con un parámetro inicial: un mensaje de tipo cadena para el usuario.
Permite escribir un mensaje antes de la entrada del usuario, por ejemplo:

nombre = input("Ingresa tu nombre: ")


print("Hola, " + nombre + ". ¡Un gusto conocerte!")

3. Cuando la función input() es llamada o invocada, el flujo del programa se detiene, el símbolo del
cursor se mantiene parpadeando (le está indicando al usuario que tome acción ya que la consola está en
modo de entrada) hasta que el usuario haya ingresado un dato y/o haya presionado la tecla Enter.

NOTA

Puedes probar la funcionalidad completa de la función input() localmente en tu máquina. Por razones
de optimización, se ha limitado el máximo número de ejecuciones en Edube a solo algunos segundos
únicamente. Ve a Sandbox, copia y pega el código que está arriba, ejecuta el programa y espera unos
segundos. Tu programa debe detenerse después de unos segundos. Ahora abre IDLE, y ejecuta el mismo
programa ahí -¿Puedes notar alguna diferencia?

Consejo: La característica mencionada anteriormente de la función input() puede ser utilizada para
pedirle al usuario que termine o finalice el programa. Observa el siguiente código:

nombre = input("Ingresa tu nombre: ")


print("Hola, " + nombre + ". ¡Un gusto conocerte!")

print("\nPresiona la tecla Enter para finalizar el programa.")


input()
print("FIN.")

3. El resultado de la función input() es una cadena. Se pueden unir cadenas unas con otras a través
del operador de concatenación ( + ). Observa el siguiente código:

num1 = input("Ingresa el primer número: ") # Ingresa 12


num2 = input("Ingresa el segundo número: ") # Ingresa 21

print(num1 + num2) # el programa regresa 1221

4. También se pueden multiplicar ( * - replicación) cadenas, por ejemplo:

miEntrada = ("Ingresa Algo: ") # Ejemplo: hola


print(miEntrada * 3) # Salida esperada: holaholahola

Ejercicio 1

¿Cuál es la salida del siguiente código?

x = int(input("Ingresa un número: ")) # el usuario ingresa un 2


print(x * "5")
Revisar

55

Ejercicio 2

¿Cuál es la salida esperada del siguiente código?

x = input("Ingresa un número: ") # el usuario ingresa un 2


print(type(x))
Revisar

<class 'str'>

¡Felicidades! Has completado el Módulo 2

¡Bien hecho! Has llegado al final del Módulo 2 y has completado un paso importante en tu educación de
programación en Python. Aquí hay un breve resumen de los objetivos que has cubierto y con los que te
has familiarizado en el Módulo 2:

 Los métodos básicos de formateo y salida de datos ofrecidos por Python, junto con los tipos
principales de datos y operadores numéricos, sus relaciones mutuas y enlaces.
 El concepto de variables y la manera correcta de darles nombre.
 El operador de asignación, las reglas que rigen la construcción de expresiones.
 La entrada y conversión de datos.

Ahora estás listo para tomar el cuestionario del módulo e intentar el desafío final: La Prueba del Módulo
2, que te ayudará a evaluar lo que has aprendido hasta ahora.

También podría gustarte