Estructuras y Lazos en Python
Estructuras y Lazos en Python
Ideas clave:
Los bloques de código de Python se inician con el caracter ":" y se limitan con el Tab
(sangría de 4 espacios)
Se pueden anidar bloques, aunque se prefiere utilizar conectores lógicos (and, or,
not) para reducir la lógica a una sola instrucción
El operador "is" evalua si dos objetos son lo mismo. El operador "==" evalua si dos
objetos son equivalentes
El operador "in" verifica si un objeto esta incluido en un contenedor (por ejemplo,
una lista)
Las instruccones for y while gestionan los iteradores
Los contenedores principales de Python (listas, tuplas, diccionarios...) son iterables.
La combinación de un lazo while con un control para romper el lazo con "break"
permite implementar un lazo "do... while"
La instrucción "else" puede incluirse en un lazo for o while para especificar las
instrucciones a realizar luego que el lazo de repetición se haya finalizado
correctamente
Informacion:
https://www.w3schools.com/python/python_conditions.asp
https://www.w3schools.com/python/python_while_loops.asp
https://www.w3schools.com/python/python_for_loops.asp
Pruebe modificando el valor de num y observe los resultados del código en la celda
siguiente. (Recuerde, ejecute una celda de código presionando Ctrl + ENTER)
In [1]: num = 10
# Operador de relación
if num > 5:
print(f"* {num} es mayor que 5")
* 10 es mayor que 5
* 10 es par
In [2]: num = 25
if num % 5 == 0:
if 0 <= num <= 10:
print("{} esta en el rango 0 a 25")
print(f"{num} es multiplo de 5")
print("Fin de programa")
In [5]: num = 10
if num < 5:
print(f"* {num} es menor que 5")
else:
print(f"* {num} es mayor que 5")
* 10 es mayor que 5
* 10 es par
Así también, se puede incluir la instrucción elif para considerar otras posibles
condiciones a evaluar. Considere el código de la siguiente celda. Pruebe con varios
números y siga la lógica del script:
In [9]: num = 7
Una estructura de control anidada consiste en una cascada de operaciones, una dentro
de la otra. En el bloque if externo se considera una decision que, segun la condición,
ingresa a un bloque interno. De ser preferible, esta practica se debe evitar para mantener
el codigo simple, utilizando expresiones lógicas como conectores entre condiciones. Por
ejemplo, considere la evaluación de si un año es bisiesto:
"Año bisiesto es el divisible entre 4, salvo que sea año secular -último de cada siglo,
terminado en «00»-, en cuyo caso también ha de ser divisible entre 400". (Wikipedia)
Palabras reservadas in e is
La palabra reservada in se utiliza en Python para verificar si un elemento es parte de un
conjunto de datos, por ejemplo una tupla o una lista. Considere el siguiente uso de in
con una tupla:
Otra palabra reservada útil es is . Permite evaluar si un objeto es otro. Por ejemplo:
In [ ]: (3 * 6) is 18
Pero debe se utilizado con precaución: is no verifica si un objeto es igual a otro. Por
ejemplo:
Out[11]: False
Out[12]: True
Función range
La función range genera un rango de datos enteros. Formalmente hablando, genera
una construccion conocida como generador, es decir algo que genera valores en línea
que puede ser iterado por un lazo de repetición (al respecto, más adelante). Tiene la
siguiente sintaxis: range(start, end, step) :
Note que se genera un rango de datos hasta el segundo argumento menos 1. Esto se
repite en muchas operaciones de Python donde se generan rangos. Asi, range(1, 20)
genera un rango entre 1 y 20-1, es decir, entre 1 y 19.
if num < 0:
print("El numero ingresado debe ser positivo")
else:
if num in range(0, num+1, 2):
print(f"{num} es par")
else:
print("{num} es impar")
1
2
3
4
5
6
7
8
9
Se puede combinar con la función range() para obtener un código más reducido:
El lazo de control while permite establecer un lazo de control mientras una condición
se mantenga como verdadera. Por ejemplo:
In [ ]: num = 5
In [19]: try:
edad = int(input("Ingrese su edad:"))
except ValueError:
print("Debe de ingresar un valor entero")
En menor de edad
Si se ingresa un valor como 12.5 como edad, al convertír este str en un int se
producirá una excepción del tipo ValueError :
In [ ]: int('12.5')
Este evento detiene la ejecución del bloque de código y se captura el tipo de excepción
para ejecutar las acciones según el tipo de excepción. Si se utiliza la instrucción except
sin especificar el tipo de excepción se esta definiendo un caso de error genérico, lo que
no se recomienda. En lugar de esto se recomienda utilizar la siguiente construcción:
try:
edad = int(edad)
except Exception as e:
print(e)
if two_numbers:
try:
# Intenta ejecutar todo el bloque
# y si algo sale mal, salta a except
n1 = int(n1); n2 = int(n2)
except ValueError:
print("Los numeros ingresados deben ser enteros")
except ZeroDivisionError:
print("No se puede realizar la division: Division por cero!!!")
break y continue
Las instrucciones break y continue permiten alterar la ejecución de un lazo.
In [7]: # Este script imprime los valores numéricos de un rango hasta que alcance a algu
for num in range(1, 20):
if num % 7 == 0:
print(f"{num} es multiplo de 7")
break
else:
print(f"{num} no es multiplo de 7")
1 no es multiplo de 7
2 no es multiplo de 7
3 no es multiplo de 7
4 no es multiplo de 7
5 no es multiplo de 7
6 no es multiplo de 7
7 es multiplo de 7
continue detiene la iteración del ciclo de repetición para continuar con la siguiente
iteración en caso de existír. Considere el siguiente código:
In [11]: # Este script imprime todos los valores numéricos de un rango a excepción de los
for num in range(1, 20):
if num % 7 == 0:
print("---- SIGUIENTE ITERACION ---")
continue
else:
print(f"{num} no es multiplo de 7")
1 no es multiplo de 7
2 no es multiplo de 7
3 no es multiplo de 7
4 no es multiplo de 7
5 no es multiplo de 7
6 no es multiplo de 7
---- SIGUIENTE ITERACION ---
8 no es multiplo de 7
9 no es multiplo de 7
10 no es multiplo de 7
11 no es multiplo de 7
12 no es multiplo de 7
13 no es multiplo de 7
---- SIGUIENTE ITERACION ---
15 no es multiplo de 7
16 no es multiplo de 7
17 no es multiplo de 7
18 no es multiplo de 7
19 no es multiplo de 7
Su uso es restringido para casos en donde su presencia ayuda a hacer un código más
legible o cuando no se tiene una mejor solución.
break
Este tipo de construcciones suele ser confuso pues contiene un while True que indica
que es un lazo infinito cuando no lo se ya que se interrumpirá en algún momento y para
saber bajo que condición es necesario leer el código. Es mejor utilizar una variable tipo
bandera que indique la condición. Esto hace el código más legíble:
In [ ]: num_primos = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 53, 57, 59]
print("Para todos los numeros impares entre 1 y 59, los numeros primos son:")
for num in range(1, 60, 2):
if num in num_primos:
La última línea print("Los demas numeros no son primos") esta fuera del bloque
if y del bloque for , por lo que es una instrucción que se ejecutará al finalizar ambos
bloques. Sin embargo, algun programador puede considerar que esta línea deberia estar
dentro del alguno de los bloques. Para evitar esta falta de claridad, se puede incluír la
instrucción else para un lazo de control:
In [ ]: num_primos = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 53, 57, 59]
print("Para todos los numeros impares entre 1 y 59, los numeros primos son:")
for num in range(1, 60, 2):
if num in num_primos:
print( " *", num)
else:
print("Los demas numeros no son primos")
En el código anterior, la instrucción else es parte del bloque for (NO del bloque
if ). En Python else puede ser parte de un lazo e indica lo que sucederá cuando el
lazo concluya normalmente. Por ejemplo:
In [ ]: i = 6
while i > 0:
print(i)
i -= 1
else:
print("Fin del lazo")
Recuerde: el uso de else permite especificar las instrucciones a ejecutar cuando el lazo
acabe normalmente. Considere el siguente caso:
In [ ]: num = 82
if num < 0:
# TODO: Se colocara un mensaje de error
pass
elif num > 100:
# TODO: Se colocara un mensaje de error
pass
elif num % 2 == 0:
print("{} es par".format(num))
else:
print("{} es impar".format(num))
Si retira las instrucciones pass del codigo anterior este dejará de funcionar. ¿Entiende
por qué? La instrucción pass por lo tanto permite ir construyendo los bloques de
decisión e ir resolviendo cada una de las condiciones poco a poco.
In [17]: dir()
Out[17]: ['In',
'Out',
'_',
'__',
'___',
'__builtin__',
'__builtins__',
'__doc__',
'__loader__',
'__name__',
'__package__',
'__spec__',
'_dh',
'_i',
'_i1',
'_i10',
'_i11',
'_i12',
'_i13',
'_i14',
'_i15',
'_i16',
'_i17',
'_i2',
'_i3',
'_i4',
'_i5',
'_i6',
'_i7',
'_i8',
'_i9',
'_ih',
'_ii',
'_iii',
'_oh',
'exit',
'get_ipython',
'num',
'num_valido',
'open',
'quit',
'random',
'two_numbers']
In [18]: dir(random)
Out[18]: ['BPF',
'LOG4',
'NV_MAGICCONST',
'RECIP_BPF',
'Random',
'SG_MAGICCONST',
'SystemRandom',
'TWOPI',
'_ONE',
'_Sequence',
'_Set',
'__all__',
'__builtins__',
'__cached__',
'__doc__',
'__file__',
'__loader__',
'__name__',
'__package__',
'__spec__',
'_accumulate',
'_acos',
'_bisect',
'_ceil',
'_cos',
'_e',
'_exp',
'_floor',
'_index',
'_inst',
'_isfinite',
'_log',
'_os',
'_pi',
'_random',
'_repeat',
'_sha512',
'_sin',
'_sqrt',
'_test',
'_test_generator',
'_urandom',
'_warn',
'betavariate',
'choice',
'choices',
'expovariate',
'gammavariate',
'gauss',
'getrandbits',
'getstate',
'lognormvariate',
'normalvariate',
'paretovariate',
'randbytes',
'randint',
'random',
'randrange',
'sample',
'seed',
'setstate',
'shuffle',
'triangular',
'uniform',
'vonmisesvariate',
'weibullvariate']
La instrucción anterior muestra una lista de todas las funciones disponibles como parte
de las librería random . Aquellas funciones cuyo nombre inicia con los caracteres __ e
_ no estan disponibles para nosotros (son privadas y protegidas, respectivamente).
¿Encuentra en el listado la función random ? Esta en la función random() incluida en la
librería random . ¿Cómo ejecutar la función radom() de la librería random ?
In [ ]: random.random()
In [19]: help(random)
NAME
random - Random variable generators.
MODULE REFERENCE
https://docs.python.org/3.10/library/random.html
DESCRIPTION
bytes
-----
uniform bytes (values between 0 and 255)
integers
--------
uniform within range
sequences
---------
pick random element
pick random sample
pick weighted random sample
generate random permutation
CLASSES
_random.Random(builtins.object)
Random
SystemRandom
class Random(_random.Random)
| Random(x=None)
|
| Random number generator base class used by bound module functions.
|
| Used to instantiate instances of Random to get generators that don't
| share state.
|
| Class Random can also be subclassed if you want to use a different basic
| generator of your own devising: in that case, override the following
| methods: random(), seed(), getstate(), and setstate().
| Optionally, implement a getrandbits() method so that randrange()
| can cover arbitrarily large ranges.
|
| Method resolution order:
| Random
| _random.Random
| builtins.object
|
| Methods defined here:
|
| __getstate__(self)
| # Issue 17489: Since __reduce__ was defined to fix #759889 this is no
| # longer called; we leave it here because it has been here since rand
om was
| # rewritten back in 2001 and why risk breaking something.
|
| __init__(self, x=None)
| Initialize an instance.
|
| Optional argument x controls seeding, as for Random.seed().
|
| __reduce__(self)
| Helper for pickle.
|
| __setstate__(self, state)
|
| betavariate(self, alpha, beta)
| Beta distribution.
|
| Conditions on the parameters are alpha > 0 and beta > 0.
| Returned values range between 0 and 1.
|
| choice(self, seq)
| Choose a random element from a non-empty sequence.
|
| choices(self, population, weights=None, *, cum_weights=None, k=1)
| Return a k sized list of population elements chosen with replacement.
|
| If the relative weights or cumulative weights are not specified,
| the selections are made with equal probability.
|
| expovariate(self, lambd)
| Exponential distribution.
|
| lambd is 1.0 divided by the desired mean. It should be
| nonzero. (The parameter would be called "lambda", but that is
| a reserved word in Python.) Returned values range from 0 to
| positive infinity if lambd is positive, and from negative
| infinity to 0 if lambd is negative.
|
class SystemRandom(Random)
| SystemRandom(x=None)
|
| Alternate random number generator using sources provided
| by the operating system (such as /dev/urandom on Unix or
| CryptGenRandom on Windows).
|
| Not available on all systems (see os.urandom() for details).
|
| Method resolution order:
| SystemRandom
| Random
| _random.Random
| builtins.object
|
| Methods defined here:
|
| getrandbits(self, k)
| getrandbits(k) -> x. Generates an int with k random bits.
|
| getstate = _notimplemented(self, *args, **kwds)
|
| randbytes(self, n)
| Generate n random bytes.
|
| random(self)
| Get the next random number in the range [0.0, 1.0).
|
| seed(self, *args, **kwds)
| Stub method. Not used for a system random number generator.
|
| setstate = _notimplemented(self, *args, **kwds)
|
| ----------------------------------------------------------------------
| Methods inherited from Random:
|
| __getstate__(self)
| # Issue 17489: Since __reduce__ was defined to fix #759889 this is no
| # longer called; we leave it here because it has been here since rand
om was
| # rewritten back in 2001 and why risk breaking something.
|
| __init__(self, x=None)
| Initialize an instance.
|
| Optional argument x controls seeding, as for Random.seed().
|
| __reduce__(self)
| Helper for pickle.
|
| __setstate__(self, state)
|
| betavariate(self, alpha, beta)
| Beta distribution.
|
| Conditions on the parameters are alpha > 0 and beta > 0.
| Returned values range between 0 and 1.
|
| choice(self, seq)
| Choose a random element from a non-empty sequence.
|
| choices(self, population, weights=None, *, cum_weights=None, k=1)
| Return a k sized list of population elements chosen with replacement.
|
| If the relative weights or cumulative weights are not specified,
| the selections are made with equal probability.
|
| expovariate(self, lambd)
| Exponential distribution.
|
| ----------------------------------------------------------------------
| Data descriptors inherited from Random:
|
| __dict__
| dictionary for instance variables (if defined)
|
| __weakref__
| list of weak references to the object (if defined)
|
| ----------------------------------------------------------------------
| Data and other attributes inherited from Random:
|
| VERSION = 3
|
| ----------------------------------------------------------------------
| Static methods inherited from _random.Random:
|
| __new__(*args, **kwargs) from builtins.type
| Create and return a new object. See help(type) for accurate signatur
e.
FUNCTIONS
betavariate(alpha, beta) method of Random instance
Beta distribution.
is equivalent to:
sample(range(10000000), 60)
For version 2 (the default), all of the bits are used if *a* is a str,
bytes, or bytearray. For version 1 (provided for reproducing random
sequences from older versions of Python), the algorithm for str and
bytes generates a narrower range of seeds.
http://en.wikipedia.org/wiki/Triangular_distribution
DATA
__all__ = ['Random', 'SystemRandom', 'betavariate', 'choice', 'choices...
FILE
c:\users\asus\anaconda3\lib\random.py
In [20]: help(random.random)
0.8309979826763929
0.839864873030073
0.6996786516183964
0.24637615547625913
0.3094165665094325
2
1
2
5
6
3.490770226697019
9.674063315170267
4.527729215990874
6.5165374268575125
1.3644621499051426