Python
De programador Java a Python Ninja
Javier Luna Molina
goo.gl/t0iGFR
Python como lenguaje
- Creador: Guido van Rossum
- Código abierto
- Primera versión publicada en 1991
- Fan de los Monty Python
- Versión actual: 3.5.2
Python como lenguaje
- Intérprete más usado: CPython (Escrito en C)
- Tabulación en vez de llaves
- Lenguaje Interpretado
- Hace hincapié en la legibilidad
El Zen
El Zen
>>> import this
- Bello es mejor que feo.
- Explícito es mejor que implícito.
- Simple es mejor que complejo.
- Complejo es mejor que complicado.
- Plano es mejor que anidado.
- Disperso es mejor que denso.
- La legibilidad cuenta.
- Los casos especiales no son tan especiales como para quebrantar las reglas.
- Lo práctico gana a lo puro.
- Los errores nunca deberían dejarse pasar silenciosamente.
- A menos que hayan sido silenciados explícitamente.
- Frente a la ambigüedad, rechaza la tentación de adivinar.
- Debería haber una -y preferiblemente sólo una- manera obvia de hacerlo.
- Aunque esa manera puede no ser obvia al principio a menos que usted sea holandés.
- Ahora es mejor que nunca.
- Aunque nunca es a menudo mejor que ya mismo.
- Si la implementación es difícil de explicar, es una mala idea.
- Si la implementación es fácil de explicar, puede que sea una buena idea.
- Los espacios de nombres (namespaces) son una gran idea ¡Hagamos más de esas cosas!
El Zen
Bello es mejor de feo
public class HelloWorld{
public static void main(String[] args){
System.out.println("Hello World");
}
}
print("Hello world")
El Zen
Simple es mejor que complejo
List<Integer> list = new ArrayList<Integer>();
File file = new File("file.txt");
BufferedReader reader = null;
try {
reader = new BufferedReader(new FileReader(file));
String text = null;
while ((text = reader.readLine()) != null) {
list.add(Integer.parseInt(text));
}
} catch (FileNotFoundException e) {
e.printStackTrace();
} catch (IOException e) {
e.printStackTrace();
} finally {
try {
if (reader != null) {
reader.close();
}
} catch (IOException e) {
}
}
System.out.println(list);
list = []
with open("file.txt") as file:
for line in file:
list.append(int(line))
print(list)
El Zen
La legibilidad cuenta
for(int i=0; i<arraylist.size(); i++){
if(numlist.get(i) > 0 && numlist.get(i) < 5){
System.out.println(numlist.get(i));
}
}
for num in numlist:
if 0 < num < 5:
print(num)
El Zen
Lo práctico gana a lo puro
ExampleObject example = new ExampleObject("green");
System.out.println("My fav color is "+example.getColor());
example.setColor("blue");
System.out.println("Now it is "+example.getColor());
example = ExampleObject("green")
print("My fav color is", example.color)
example.color = "blue"
print("Now it is", example.color)
"Todos somos adultos responsables"
El Zen
Debería haber una -y preferiblemente sólo una- manera obvia de hacerlo.
def is_inside(num, numlist):
return num in numlist
def is_inside(num, numlist):
for n in numlist:
if n == num:
return True
return False
El Zen
Contenido
- Python 101
- Colecciones
- Funciones
- POO
- Ninja Skills
Python 101
Python 101
- Variables
- Condicionales
- Bucles
- I/O Archivos
Python 101
Variables
Python 101
Variables
- Declaración:
nombre = "Ernesto"
nombre_completo = "Ernesto Enrique"
- Tipado dinámico:
variable_cool = "Hola"
variable_cool = 32
- Tipado fuerte:
asco_js = "32"
print(asco_js + 2)
Traceback (most recent call last):
File "<stdin>", line 1, in <module>
TypeError: Cant convert 'int' object to str implicitly
Python 101
Condicionales
Python 101
Condicionales
- Estructura:
if condicion1:
#Si condicion1 es verdadera
elif condicion2:
#Si condicion1 es falsa
#Y condicion2 es verdadera
else:
#Si el resto es falso
Python 101
Condicionales
&&
||
!
and
or
not
Python 101
Condicionales
¡Puedes concatenar comparadores!
if 5 < variable < 9:
print("Wohoo!")
Python 101
Condicionales
Ternarias
print("Verdadero") if True else print("Falso")
if True:
print("Verdadero")
else:
print("Falso")
Igual que:
Python 101
¿Qué se considera verdadero y qué falso?
- Falso:
- False
- 0
- None
- Colecciones vacías
def v_o_f(expresion):
if expresion:
print("Verdadero")
else:
print("Falso")
v_o_f(False)
"Falso"
v_o_f(0)
"Falso"
v_o_f(None)
"Falso"
v_o_f( [] )
"Falso"
- Verdadero:
- True
- El resto
Python 101
Bucles
Python 101
Bucles
Dos tipos de bucles:
For
While
i = 1
while i < 4:
print("Ni", i)
i += 1
print("Sino", i)
"Ni 1"
"Ni 2"
"Ni 3"
"Sino 4"
for letra in "Hola":
print(letra)
"H"
"o"
"l"
"a"
Python 101
Bucles: While
- Estructura:
while condicion:
#Mientras condicion sea verdad
#ejecuta esto
Python 101
Bucles: For
- Estructura:
for item in coleccion:
#Por cada elemento que
#haya en la coleccion
#ejecuta esto.
Python 101
Bucles: For (para gente de Java)
String[] nombres = {"Ángel","Juan","Julian"};
for(int i=0; i < 3; i++){
String nombre = nombres[i];
System.out.println(nombre);
}
nombres = ["Ángel", "Juan", "Julian"]
for nombre in nombres:
print(nombre)
Python 101
Bucles: For (para gente de Java)
for(int i=0; i < 3; i++){
System.out.println(i);
}
for i in range(3):
print(i)
Python 101
I/O Archivos
Python 101
I/O Archivos
- Sintaxis:
with open(RUTA_DEL_ARCHIVO, MODO) as variable_archivo:
#Trabajar con el contenido del archivo
#El archivo se cierra automáticamente
Python 101
Lectura de archivos
- Texto plano:
with open("ejemplo.txt") as ejemplo_cool:
contenido = ejemplo_cool.read()
#Leer linea a linea
with open("ejemplo.txt") as ejemplo_cool:
for linea in ejemplo_cool:
print(linea)
- Archivo binario
with open("ejemplo.txt", 'rb') as binario:
contenido = ejemplo_bin.read()
Python 101
Escritura de archivos
- Texto plano:
with open("ejemplo.txt", 'w') as ejemplo_cool:
contenido = ejemplo_cool.write("Hola")
- Archivo binario
with open("ejemplo.txt", 'wb') as binario:
contenido = ejemplo_bin.write("Hola")
Colecciones
Colecciones
- Listas
- Diccionarios
- Sets
- Tuplas
Colecciones
Listas
Colecciones
- Mantiene el orden en el que se introducen los elementos
Listas
- Puede tener duplicados
- Accedemos al valor mediante índice
Colecciones
Listas
Declaración
lista = [] # Ó lista = list()
Añadir elemento
lista.append('ejemplo')
lista.append(2)
lista.append([])
Acceder elemento
lista[0] 'ejemplo'
lista[1] '2'
lista[-1] '[]'
Colecciones
Listas
Segmentos
lista = [3, 1, 8]
lista[1:] '[1, 8]'
lista[0:2] '[3, 1]
Máximo, mínimo y total
max(lista) '8'
min(lista) '1'
sum(lista) '12'
Ordenar
lista.sort() '[1, 3, 8]'
Colecciones
Diccionarios
Colecciones
Diccionarios
- No mantiene ningún orden
- No puede tener claves duplicadas, valores sí
- Accedemos al valor mediante clave
Colecciones
Diccionarios
Declaración
diccionario = {} # Ó diccionario = dict()
Añadir elemento
diccionario['nombre'] = "Javier"
diccionario['apellido1'] = "Luna"
diccionario['edad'] = 19
Acceder elemento
diccionario['nombre'] 'Javier'
diccionario['apellido1'] 'Luna'
diccionario['edad'] 19
Colecciones
Diccionarios
Acceder elemento [Forma segura]
diccionario['apellido2'] KeyError 'apellido2'
diccionario.get('apellido2', '*') '*'
De diccionario a JSON string
import json
string = json.dumps(diccionario)
"{'nombre': 'Javier', 'apellido1': 'Luna',
'edad':19}"
De JSON string a diccionario
import json
diccionario = json.loads(string)
Colecciones
Sets
Colecciones
- No mantiene ningún orden
Sets
- No tiene duplicados
- No se accede directamente a los elementos (iterar y operaciones con conjuntos)
Colecciones
Sets
Declaración
mi_set = set()
Añadir elemento
mi_set.add('hola') "{'hola'}"
mi_set.add('mundo') "{'hola', 'mundo'}"
mi_set.add('mundo') "{'mundo', 'hola'}"
Lista a set
lista_set = set(['hola', 'mundo', 'mundo'])
"{'mundo', 'hola'}"
Recordad: Los elementos no tienen orden
Colecciones
Sets
Lista sin duplicados
lista = [1, 3, 4, 4, 3]
lista = list(set(lista))
"[3, 1, 4]"
Operaciones de conjuntos
a = set(['a', 'b', 'c'])
b = set(['a', 'm', 'd'])
Elementos de a que no aparecen en b
a - b "{'b', 'c'}"
Elementos de a y elementos en b
a | b "{'m', 'a', 'd', 'c', 'b'}"
Elementos de a y de b
a & b "{'a'}"
Colecciones
Tuplas
Colecciones
- Mantienen el orden de los elementos
Tuplas
- Son inmutables
- Accedemos a los elementos mediante índice
Colecciones
Tuplas
Declaración
tupla = ('hola', 'mundo')
Acceso a elementos
tupla[0] "hola"
tupla[1] "mundo"
Colecciones
Cosas cool
Colecciones
Cosas cool
Ver si una colección contiene un elemento
'hola' in ['hola', 'mundo']
Iterar sobre los elementos de una colección
for elemento in ['hola', 'mundo']:
print(elemento)
String es una especie de colección (de caracteres)
for letra in "Hola mundo"[0:4]:
print(letra)
Funciones
- Declaración
- keyword arguments
- *args y **kwargs
- Pasar funciones por parámetros
Funciones
Funciones
Declaración
def nombre_funcion():
#código de la función
def con_argumentos(nombre, edad):
#código de la función
Funciones
Keyword arguments I
def funcion(nombre="Pedro", edad=2):
print(nombre + " " + edad)
funcion() 'Pedro 2'
funcion(nombre="Manuel") 'Manuel 2'
funcion(edad=3, nombre="Sol") 'Sol 3'
Funciones
Keyword arguments II
def funcion(nombre, edad=2):
print(nombre + " " + edad)
funcion("Pedro") 'Pedro 2'
funcion(edad=34, "Manuel") SyntaxError!!
funcion("Manuel", edad=34) 'Manuel 34'
Funciones
*args y **kwargs
def funcion(*args, **kwargs): #args es una tupla
#y kwargs es un diccionario
for argumento in args:
print(argumento + " " + kwargs.get(argumento, ""))
funcion("Manuel", "Pedro", "Pablo", Manuel="23", Pablo="34")
'Manuel 23'
'Pedro'
'Pablo 34'
Funciones
Pasar funciones como argumento
import time
def medir_tiempo(funcion):
tiempo_inicio = time.time()
funcion()
tiempo_final = time.time()
return tiempo_final - tiempo_inicial
def ejemplo():
time.sleep(3)
print(medir_tiempo(ejemplo), "segundos") '3 segundos'
POO
- Estructura y conceptos básicos
- Encapsulación
- Herencia múltiple
POO
POO
Conceptos Básicos
POO
Declaración de una clase
class Persona:
def __init__(self, nombre, apellido, edad=13):
#Este es el constructor
self.nombre = nombre
self.apellido = apellido
self.edad = edad
def print_datos(self):
print(self.nombre, self.apellido, self.edad, "años")
patron = Persona("Pablo", "Escobar", edad=44)
patron.print_datos() 'Pablo Escobar 44 años'
POO
Varias clases en un mismo archivo
class Persona:
def __init__(self, nombre, apellido, edad=13):
self.nombre = nombre
self.apellido = apellido
self.edad = edad
def print_datos(self):
print(self.nombre, self.apellido, self.edad)
class Animal:
def __init__(self, especie, raza)
self.especie = especie
self.raza = raza
def print_datos(self):
print(self.especie, self.raza)
POO
Herencia simple
class Fruta:
def __init__(self, tipo, color):
self.tipo = tipo
self.color = color
def print_info(self):
print("Tipo:", self.tipo, "Color:", self.color)
class Platano(Fruta):
def __init__(self):
super().__init__("Alargado", "Amarillo")
platano = Platano()
platano.print_info() 'Tipo: Alargado Color: Amarillo'
POO
Encapsulación
POO
- ¡Lo público mola!
Encapsulación
- "Privado" -> No toques eso :(
class Prueba:
def __init__(self):
self.var_publica = "Publica"
self.__var_privada = "Privada"
def hola(self):
return "Publica!"
def __hola(self):
return "Privada :("
POO
Herencia múltiple
POO
Herencia múltiple
class Fruta:
def __init__(self, tipo, color):
self.tipo = tipo
self.color = color
def refrescar(self):
print("Wow qué refrescante!!")
print("Es", self.tipo, "y", self.color)
class Hortaliza:
def __init__(self, peso):
self.peso = peso
def en_ensalada(self):
print("Va bien en una ensalada!")
print("Pesa", self.peso)
POO
Herencia múltiple
class Tomate(Fruta, Hortaliza):
def __init__(self):
Fruta.__init__(self, "Esférico", "Rojo")
Hortaliza.__init__(self, "3gr")
def print_info(self):
self.refrescar()
print("Y")
self.en_ensalada()
tomate = Tomate()
tomate.print_info()
'Wow qué refrescante!'
'Es Esférico y Rojo'
'Y'
'Va bien en una ensalada!'
'Pesa 3gr'
Ninja Skills
Ninja Skills
Unboxing
Ninja Skills
Unboxing
a, b, c = ["Hola", "a", "todos!"]
print(a) 'Hola'
print(b) 'a'
print(c) 'todos!'
Ninja Skills
enumerate
Ninja Skills
enumerate
lista_compra = ["Leche", "Huevos", "Ketchup"]
for i, elemento in enumerate(lista_compra):
print(i, elemento)
'0 Leche'
'1 Huevos'
'2 Ketchup'
Ninja Skills
Asignación condicional
Ninja Skills
Asignación condicional
variable_1 = False or 1
variable_2 = True or 2
print(variable_1) '1'
print(variable_2) 'True'
def llamar_a(numero, nombre=""):
nombre = nombre or "No tiene nombre"
print("LLamando a:", nombre)
llamar_a(679049312) 'Llamando a: No tiene nombre'
Ninja Skills
List comprehensions
Ninja Skills
List comprehensions
lista_pares = [num for num in range(800) if not num % 2]
lista_pares = []
for num in range(800):
if num % 2 == 0:
lista_pares.append(num)
Ninja Skills
Lazy attributes
Ninja Skills
Lazy attributes
class Persona
def __init__(self, edad=30):
self.__edad = edad
@property
def edad(self):
self.__edad += 1
return self.__edad - 1
persona = Persona()
persona.edad '30'
persona.edad '31'
persona.edad '32'
¡Gracias a todos!
Introducción a Python (código sobre blanco)
By Javier Luna Molina
Introducción a Python (código sobre blanco)
Una introducción para programadores, profundizando en algunos de los muchos conceptos interesantes que nos brinda este lenguaje. Para Python 3
- 532