Para poder programar con Python vamos a usars el siguiente software:
Mas información:
Pasemos ahora a indicar todo lo que hay que instalar para poder trabajar en Python y los Jupyter notebooks.
Ejecutar los siguiente comandos en las consola de Linux para instalar VS Code
sudo rpm --import https://packages.microsoft.com/keys/microsoft.asc cd /etc/yum.repos.d/ sudo sh -c 'echo -e "[code]\nname=Visual Studio Code\nbaseurl=https://packages.microsoft.com/yumrepos/vscode\nenabled=1\ngpgcheck=1\ngpgkey=https://packages.microsoft.com/keys/microsoft.asc" > vscode.repo' sudo dnf check-update sudo dnf install code
Descargar Miniconda desde https://docs.conda.io/en/latest/miniconda.html.
Ejecutar los siguiente comandos en las consola de Linux para instalar Anaconda
cd Descargas chmod +x Miniconda3-latest-Linux-x86_64.sh ./Miniconda3-latest-Linux-x86_64.sh
Instalar las siguientes extensiones en VS Code
Instalar antes que nada el paquete de Linux de Graphviz
sudo dnf install graphviz
Ahora vamos a instalar una serie de paquetes de Python en Anaconda. Se usa el comando conda
conda install numpy conda install pandas conda install matplotlib conda install seaborn conda install scikit-learn conda install tensorflow conda install keras conda install tabulate conda install pymysql conda install sqlalchemy conda install pydotplus conda install ipympl conda install opencv --channel conda-forge conda install pillow --channel anaconda conda install pandas_profiling --channel conda-forge
pandas_profiling
no se encuentra en el canal (como un repositorio) oficial de Anaconda sino en el canal conda-forge
. Por eso lo hemos indicado con --channel
Para crear un nuevo Jupyter Notebook en VS Code deberemos pulsar las teclas CTRL+SHIFT+P
y escribir "Jupyter: Create New Blank Notebook".
Dentro de un Jupyter Notebook podemos:
Mas información:
Un libro sobre Python lo puedes descargar aqui:Python para todos.Explorando la información con Python 3 y un sitio web sobre python es Python 3 para impacientes
numpy
con nombre np
import numpy as np
load_iris
de sklearn.datasets
from sklearn.datasets import load_iris
True
y False
int()
float()
str()
round(valor,decimales)
a=5 b="Hola" c=True d=6.7 print(a,b,c) print(d)
5 Hola True 6.7
end=""
a=5 b="Hola" c=True d=6.7 print(a,b,c,end="") print(d)
5 Hola True6.7
sep=""
a=5 b="Hola" c=True d=6.7 print(a,b,c,sep="") print(d)
5HolaTrue 6.7
sep=","
a=5 b="Hola" c=True d=6.7 print(a,b,c,sep=",") print(d)
5,Hola,True 6.7
abs?
Signature: abs(x, /) Docstring: Return the absolute value of the argument. Type: builtin_function_or_method
help
help(abs)
Help on built-in function abs in module builtins: abs(x, /) Return the absolute value of the argument.
help
otras veces de ?
from sklearn.preprocessing import StandardScaler standard_scaler = StandardScaler() dir(standard_scaler)
['__annotations__', '__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', '__format__', ...... 'set_output', 'set_params', 'transform', 'with_mean', 'with_std']
//
%
**
a=[1,2,3] a[1]
2
a=[1,2,3,3,1,2] len(a)
6
a=[1,2,3,3,1,2] sum(a)
12
a=[8,9,10] a.append(77) a
[8, 9, 10, 77]
+
. Crea un nuevo array y sirve también para listas.
a=[1,2,3] b=[10,20,30] a+b
[1, 2, 3, 10, 20, 30]
append
con un array
a=[1,2,3] b=[10,20,30] a.append(b)
[1, 2, 3, [10, 20, 30]]
$$ \begin{pmatrix} 1 & 11\\ 2 & 22\\ 3 & 33 \end{pmatrix} $$
a=[ [1,11], [2,22], [3,33] ] a[2][1]
33
a=(1,2,3) a[1]
2
a= { "nombre":"Juan", "edad": 37 } a['edad']
37
keys()
a= { "nombre":"Juan", "edad": 37 } for key in a.keys(): print(key)
nombre edad
Para imprimir datos en forma tabular, es necesario tenerlas en una matriz. Y para imprimir usaremos la librería tabulate
from tabulate import tabulate datos=[ [5,0.7,0.765], [10,1.45,0.84], [20,2.678,0.978], [60,11.396,0.9973] ] print(tabulate(datos, headers=["Épocas", "Tiempo (s)", "Resultado"]))
Épocas Tiempo (s) Resultado -------- ------------ ----------- 5 0.7 0.765 10 1.45 0.84 20 2.678 0.978 60 11.396 0.9973
También podemos añadir una primera columna que sean también como "cabeceras". El siguiente anterior ejemplo se podría modificar de forma que en el array a
solo estén los datos de tiempo y resultado y no las épocas ya que son como "cabeceras".
from tabulate import tabulate datos=[ [0.7,0.765], [1.45,0.84], [2.678,0.978], [11.396,0.9973] ] epocas=[5,10,20,60] print(tabulate(datos, headers=["Épocas", "Tiempo (s)", "Resultado"],showindex=epocas))
Épocas Tiempo (s) Resultado -------- ------------ ----------- 5 0.7 0.765 10 1.45 0.84 20 2.678 0.978 60 11.396 0.9973
a=1 if a==1: b=4 else: b=5 print(b)
4
a=2 if a==1: b=4 elif a==2: b=-1 else: b=5 print(b)
-1
a=[0,1,2,3] for i in a: print(i)
0 1 2 3
for i in range(0,4): print(i)
0 1 2 3
precios=[45,234,6.99,7] for index_precio,precio in enumerate(precios): print(index_precio,precio)
0 45 1 234 2 6.99 3 7
def sumar(a,b): return a+b resultado=sumar(3,4) print(resultado)
7
def sumar_y_multiplicar(a,b): return a+b,a*b a,b=sumar_y_multiplicar(3,4) print(a) print(b)
7 12
def sumar_y_multiplicar(a,b): return a+b,a*b resultado=sumar_y_multiplicar(3,4) print(resultado) print(resultado[0]) print(resultado[1])
(7, 12) 7 12
def dividir(dividendo,divisor): return dividendo/divisor print(dividir(10,2)) print(dividir(dividendo=10,divisor=2)) print(dividir(divisor=2,dividendo=10)) print(dividir(10,divisor=2))
5.0 5.0 5.0 5.0
def dividir(dividendo,divisor=2): return dividendo/divisor print(dividir(10,2)) print(dividir(10)) print(dividir(10,4)) print(dividir(dividendo=10))
5.0 5.0 2.5 5.0
Para crear clases en python:
class
: Se crear la claseself
: Para referirse a propiedades y métodos del propio objeto, se pasa siempre como primer argumento en todos los métodos.__init__
: El nombre del constructor
class Rectangulo: def __init__(self, longitud, ancho): self.longitud = longitud self.ancho = ancho def calcular_area(self): return self.longitud * self.ancho def calcular_perimetro(self): return 2 * (self.longitud + self.ancho)
mi_rectangulo = Rectangulo(5, 10) print("Longitud:", mi_rectangulo.longitud) print("Ancho:", mi_rectangulo.ancho) print("Área:", mi_rectangulo.calcular_area()) print("Perímetro:", mi_rectangulo.calcular_perimetro())
Longitud: 5 Ancho: 10 Área: 50 Perímetro: 30
IPython es como la forma genérica de los Jupyter Notebooks. Y tiene una serie de órdenes que podemos usar directamente. La orden %timeit
permite saber el tiempo que ha tardado una orden en ejecutarse.
time = %timeit -n1 -r1 -o sum(range(10000000))Lo que hace es calcula el tiempo de ejecutar la orden
sum(range(1000000000))
y almacena cuanto ha tardado en time
Y para imprimirlo, se usa:
print(round(time.average,2),"seg")
0.21 seg
Sin embargo el problema de usar %timeit
es que lo que ejecutas no puede devolver un resultado. Es decir que no podríamos saber el resultado de la suma.
Para solucionar el problema anterior podemos simplemente medir nosotros el tiempo que tarda un método en ejecutarse con la función perf_counter
.
from time import perf_counter t = perf_counter() resultado=sum(range(10000000)) t=perf_counter()-t print(resultado) print(round(t,2),"seg")
49999995000000 0.21 seg
El resultado se muestra en segundos
Mas información:
A veces no quieremos usar conda sino tener una carpeta con todo lo que necesita el proyecto, al estilo de NodeJS. En ese caso podemos usar una herramienta llamada Poetry
pip install --user poetry
poetry --version
poetry config virtualenvs.in-project true
poetry init poetry add libclang = "<12.0.0" numpy pandas matplotlib seaborn scikit-learn tensorflow tabulate PyMySQL SQLAlchemy ipympl keras-tuner tensorflow-addons statsmodels poetry install
poetry add
se produce el error:
[org.freedesktop.DBus.Error.UnknownObject] ("No such object path '/org/freedesktop/secrets/aliases/default'",)
deberemos crear la siguiente variable de entorno:
export PYTHON_KEYRING_BACKEND=keyring.backends.null.Keyring
Para ejecutar el código hay 2 formas:
poetry run python my_script.py
.venv
del propio proyecto:$HOME/.config/Code/User/settings.json
{ "python.defaultInterpreterPath": "/home/logongas/python_default_env/.venv/bin/python", }
Instala todo lo indicado en el apartado "Instalación" de este tema
numpy
con el nombre de np
pandas
con el nombre de pd
matplotlib.pyplot
con el nombre de plt
seaborn
con el nombre de sns
load_breast_cancer
desde sklearn.datasets
Una vez importadas esas librerías ejecuta el siguiente código, el cual mostrará una gráfica.
df=pd.DataFrame({ 'Perímetro medio':load_breast_cancer().data[:,2], '¿Benigno?':load_breast_cancer().target, }) figure=plt.figure() axes = figure.add_subplot() sns.scatterplot(data=df,x="Perímetro medio",y="¿Benigno?")
String
con un número y la transformas en un int
.String
con un número y la transformas en un float
.int
y la transformas en un float
.int
y la transformas en un String
.float
y la transformas en un String
.float
y la transformas en un int
. ¿La función redondea o trunca?load_breast_cancer
mediante ?
load_breast_cancer
mediante help
datos
, sabien que el objeto datos se obtiene así:
datos=load_breast_cancer()
1,2,3,4
y 10,20,30,40
. Deberás usar un bucle for
.1,2,3,4
el siguiente array 10,20,30,40
, pero como si fuera un único elemento usando una sola vez append
. ¿Ves la diferencia con el ejercicio anterior?Dado el array:
a=[2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97]
$$ \begin{pmatrix} 1 & 0 & 0 & 0\\ 0 & 1 & 7 & 0\\ 0 & 0 & 1 & 0\\ 0 & 0 & 0 & 1\\ \end{pmatrix} $$
cliente
que sea un diccionario con la información de este cliente
nombre: Juan apellidos: Pérez García teléfono movil: 654789658 fijo: 963789654 dirección: tipo via: calle numero: 45 puerta: 7 numero facturas: compras: 234/2020, 345/2021, 675/2021, 561/2022 ventas: 456/2020, 564/2021, 768/2021, 345/2022
Usando la variable cliente
del ejercicio anterior, haz lo siguiente:
2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37, 41, 43, 47, 53, 59, 61, 67, 71, 73, 79, 83, 89, 97
4º -> 7
, 6º -> 13
Primero -> 2
y si es el último número primo del array , se muestre Ultimo -> 97
Vamos a volver al ejercicio de redes neuronales del tema 1 del tipo de flor .
Modifica el siguiente programa:
model=Sequential() model.add(Dense(6, activation='relu',input_dim=2)) model.add(Dense(12, activation='relu')) model.add(Dense(6, activation='relu')) model.add(Dense(1, activation='sigmoid')) model.compile(loss='mean_squared_error') model.fit(x, y,epochs=40)
Para que en vez de poner tantas líneas como capas hay , se haga con un array. Es decir que dado el array capas=[6,12,6,1]
se cree la red anterior pero si cambiamos los datos del array que se cree la red correspondiente.
Modifica el ejercicio anterior de forma que el código esté en una función llamada compile_fit
que haga lo mismo y retorne el objeto model
.
Prueba a llamar a la función con los siguientes datos
capas_red1=[6,12,6,1] model1=compile_fit(capas_red1,x,y) capas_red2=[8,16,8,1] model2=compile_fit(capas_red2,x,y)
Además, encapsula la obtención de los datos en la función get_datos
x,y=get_datos()
Siguiendo con el ejercicio anterior, haz un programa que muestre lo siguiente
Red Result 1 Result 2 ------ ---------- ---------- 1 0.06094426 0.9634158 2 0.06094426 0.9634158 ... 5 0.06094426 0.9634158
Pero los números con decimales que se muestran son el resultado de llamar a la red neuronal con los valores (4.9, 1.4) y (6.3, 4.9). Y cada red va a tener las siguientes capas con las neuronas:
Red | Nº Neuronas en cada capa |
---|---|
1º | 2, 4, 1 |
2º | 4, 8, 8, 2, 1 |
3º | 8, 12, ,24, 12, 1 |
4º | 8, 16, 8, 1 |
5º | 16, 32, 1 |
Para hacer eso deberás crear un array en la que cada elemento será otro array con las neuronas de cada capa. Ejemplo:
redes=[ [2, 4 , 1] , [4, 8, 8, 2, 1] ]
compile_fit
Modifica el ejercicio anterior para que el método compile_fit
retorna además del objeto model
, el tiempo en segundos (con 2 decimales) que ha tardado en ejecutarse el método fit
Y que en la tabla se muestre también el tiempo
Red Result 1 Result 2 Tiempo (s) ------ ---------- ---------- ------------ 1 0.06094426 0.9634158 0.4 2 0.06094426 0.9634158 1.56 ... 5 0.06094426 0.9634158 12.71
Modifica el ejercicio anterior pero ahora modifica en el array de cada red para que la columna Red sea el nombre de la red para que podamos saber cual es cada una. El nombre será las neuronas de cada capa
Red Result 1 Result 2 Tiempo (s) ---------- ---------- ---------- ------------ 2,4,1 0.06094426 0.9634158 0.4 4,8,8,2,1 0.06094426 0.9634158 1.56 ... 16,32,1 0.06094426 0.9634158 12.71
Modifica el ejercicio anterior pero ahora incluye en el array de cada red un nuevo campo con el número de épocas con las que se ha entrenado.
Por ello , deberás incluir un nuevo valor para cada red que será el número de épocas a entrenar.
Ejemplo:
redes=[ [[2, 4 , 1], 30] , [[4, 8, 8, 2, 1], 34] ]
El último elemento de cada array en el número de épocas que se va a entrenar la red.
Red Épocas Result 1 Result 2 Tiempo (s) ---------- -------- ---------- ------------ 2,4,1 30 0.06094426 0.9634158 0.4 4,8,8,2,1 34 0.06094426 0.9634158 1.56 ... 16,32,1 20 0.06094426 0.9634158 12.71
Modifica la función compile_fit
añadiendo un nuevo parámetro que se a el número de neuronas de entrada. Es decir, el número de valores de la "x".
Repite el ejercicio anterior pero ahora con la red neuronal del cáncer de mama y las siguientes capas de la red:
Nº Neuronas en cada capa | Épocas |
---|---|
4, 8, 4, 2, 1 | 20 |
4, 8, 4, 2, 1 | 40 |
8, 16, 8, 4, 1 | 20 |
8, 16, 8, 4, 1 | 40 |
16, 32, 16, 8, 1 | 20 |
16, 32, 16, 8, 1 | 40 |
32, 64, 32, 8, 1 | 20 |
32, 64, 32, 8, 1 | 40 |
64, 128, 64, 8, 1 | 20 |
64, 128, 64, 8, 1 | 40 |
Crea una clase llamada CuentaBancaria
.
La clase debe tener los siguientes atributos:
titular
: el titular de la cuenta.saldo
: el saldo actual de la cuenta.La clase debe tener los siguientes métodos:
__init__
: el método de inicialización que toma el titular como parámetro e inicializa el saldo en 0.depositar
: un método que toma una cantidad como parámetro y la suma al saldo actual.retirar
: un método que toma una cantidad como parámetro y la resta del saldo actual, pero verifica que haya suficiente saldo antes de realizar la operación.obtener_saldo
: un método que devuelve el saldo actual de la cuenta.Usa la clase de forma que