Curso Python

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

Curso Python

Eduardo Espinosa Avila


2016

Contents
1 Introducción. 4
1.1 Acerca de Python. . . . . . . . . . . . . . . . . . . . . . . . . . . 4
1.1.1 ¿Qué es Python? . . . . . . . . . . . . . . . . . . . . . . . 4
1.1.2 Ventajas. . . . . . . . . . . . . . . . . . . . . . . . . . . . 5
1.1.3 Desventajas . . . . . . . . . . . . . . . . . . . . . . . . . . 7
1.1.4 ¿Quién lo usa? . . . . . . . . . . . . . . . . . . . . . . . . 8
1.2 Primeros pasos. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 9
1.2.1 Instalación. . . . . . . . . . . . . . . . . . . . . . . . . . . 9
1.2.2 Modo interactivo. . . . . . . . . . . . . . . . . . . . . . . . 9
1.2.3 Hola mundo. . . . . . . . . . . . . . . . . . . . . . . . . . 9
1.2.4 El Zen de Python . . . . . . . . . . . . . . . . . . . . . . . 9
1.2.5 Usando el modo interactivo para explorar Python. . . . . 11
1.2.6 Otros recursos . . . . . . . . . . . . . . . . . . . . . . . . 11

2 Tipos básicos. 12
2.1 None. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
2.2 Booleanos. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
2.3 Números. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12
2.4 Listas. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 13
2.4.1 Creación de una lista. . . . . . . . . . . . . . . . . . . . . 13
2.4.2 Índices. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 14
2.4.3 Particionado de una lista. . . . . . . . . . . . . . . . . . . 14
2.4.4 Modificado de una lista. . . . . . . . . . . . . . . . . . . . 14
2.4.5 Ordenamiento. . . . . . . . . . . . . . . . . . . . . . . . . 15
2.4.6 Otras operaciones comunes . . . . . . . . . . . . . . . . . 16
2.5 Tuplas. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 18
2.5.1 Creación de una tupla. . . . . . . . . . . . . . . . . . . . . 18
2.5.2 Conversiones entre listas y tuplas. . . . . . . . . . . . . . 19
2.6 Conjuntos. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 19
2.6.1 Creación de un conjunto. . . . . . . . . . . . . . . . . . . 19
2.6.2 Operaciones con conjuntos. . . . . . . . . . . . . . . . . . 20
2.7 Cadenas. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 20
2.7.1 Creación de cadenas. . . . . . . . . . . . . . . . . . . . . . 20

1
2.7.2 Métodos asociados a cadenas. . . . . . . . . . . . . . . . . 21
2.7.3 Formateando cadenas. . . . . . . . . . . . . . . . . . . . . 23
2.8 Diccionarios. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 24
2.8.1 Creación de diccionarios. . . . . . . . . . . . . . . . . . . 25
2.8.2 Modificando un diccionario. . . . . . . . . . . . . . . . . . 25
2.8.3 Otras operaciones con diccionarios. . . . . . . . . . . . . . 25
2.8.4 Formateando cadenas con diccionarios. . . . . . . . . . . . 26
2.8.5 Tipos válidos para usarse como claves. . . . . . . . . . . . 26
2.9 Archivos. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 27
2.9.1 Escritura en archivos de texto. . . . . . . . . . . . . . . . 27
2.9.2 Lectura de archivos de texto. . . . . . . . . . . . . . . . . 28
2.9.3 Otras operaciones con archivos de texto. . . . . . . . . . . 28

3 Control de flujo. 29
3.1 Sentencia if-elif-else. . . . . . . . . . . . . . . . . . . . . . . . . . 29
3.2 Ciclo while. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 29
3.3 Ciclo for. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 30
3.3.1 La función range. . . . . . . . . . . . . . . . . . . . . . . . 30
3.4 Sentencias break y continue. . . . . . . . . . . . . . . . . . . . . . 31
3.5 Valores booleanos y expresiones. . . . . . . . . . . . . . . . . . . . 32
3.5.1 La mayoría de los objetos en Python pueden usarse en
pruebas booleanas. . . . . . . . . . . . . . . . . . . . . . . 32
3.6 Listas y diccionarios por “entendimiento/completitud ”. . . . . . . 32

4 Funciones. 34
4.1 Definición de funciones. . . . . . . . . . . . . . . . . . . . . . . . 34
4.2 Opciones para los parámetros de una función. . . . . . . . . . . . 34
4.2.1 Paso de parámetros por posición. . . . . . . . . . . . . . . 34
4.2.2 Valores de parámetros por omisión. . . . . . . . . . . . . . 35
4.2.3 Paso de parámetros por nombre del parámetro. . . . . . . 35
4.2.4 Número variable de parámetros. . . . . . . . . . . . . . . 36
4.2.5 Combinando las técnicas de paso de argumentos. . . . . . 37
4.3 Asignación de funciones a variables. . . . . . . . . . . . . . . . . 37

5 Módulos. 38
5.1 Primer módulo. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38
5.2 Ruta de búsqueda de módulos. . . . . . . . . . . . . . . . . . . . 40
5.2.1 Dónde colocar los módulos propios. . . . . . . . . . . . . . 40
5.3 Nombres privados en módulos. . . . . . . . . . . . . . . . . . . . 41
5.4 Usando el módulo os. . . . . . . . . . . . . . . . . . . . . . . . . 42
5.4.1 Rutas (paths). . . . . . . . . . . . . . . . . . . . . . . . . 42
5.4.2 El directorio de trabajo actual. . . . . . . . . . . . . . . . 42
5.4.3 Manipulación de rutas. . . . . . . . . . . . . . . . . . . . . 43
5.4.4 Constantes y funciones útiles. . . . . . . . . . . . . . . . . 43
5.4.5 Resumen de constantes y funciones del módulo. . . . . . . 44
5.5 Librerías y módulos de terceros. . . . . . . . . . . . . . . . . . . . 45

2
6 Programas. 45
6.1 Primer programa básico. . . . . . . . . . . . . . . . . . . . . . . . 45
6.2 Ejecutando desde línea de comandos. . . . . . . . . . . . . . . . . 45
6.2.1 Argumentos desde línea de comandos. . . . . . . . . . . . 46
6.3 Haciendo ejecutable un programa Python en UNIX. . . . . . . . 46
6.4 Ejecutando un programa Python en Windows. . . . . . . . . . . 47
6.4.1 Ejecutando un programa con un atajo. . . . . . . . . . . . 47
6.4.2 Ejecutando un programa con el cuadro de diálogo ejecutar. 47
6.4.3 Otras opciones. . . . . . . . . . . . . . . . . . . . . . . . . 47
6.5 Programas y módulos. . . . . . . . . . . . . . . . . . . . . . . . . 48
6.6 Distribuyendo aplicaciones de Python. . . . . . . . . . . . . . . . 49
6.6.1 Módulo distutils. . . . . . . . . . . . . . . . . . . . . . . . 49
6.6.2 Usando py2exe, py2app y freeze. . . . . . . . . . . . . . . 49

7 Generación de documentación con pydoc 50

8 Módulo doctest 52

9 Clases y programación orientada a objetos. 53


9.1 Declaración de clases. . . . . . . . . . . . . . . . . . . . . . . . . 53
9.2 Atributos. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 54
9.2.1 Atributos de instancia. . . . . . . . . . . . . . . . . . . . . 54
9.2.2 Atributos de clase. . . . . . . . . . . . . . . . . . . . . . . 55
9.3 Métodos. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57
9.3.1 Métodos estáticos. . . . . . . . . . . . . . . . . . . . . . . 58
9.3.2 Métodos de clase. . . . . . . . . . . . . . . . . . . . . . . . 59
9.4 Herencia. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 60
9.4.1 Herencia múltiple. . . . . . . . . . . . . . . . . . . . . . . 62
9.4.2 Verificar que un objeto sea del tipo deseado . . . . . . . . 64

10 Python Turtle 65

11 ¿Qué sigue? 65

3
1 Introducción.
1.1 Acerca de Python.
1.1.1 ¿Qué es Python?
Python es un lenguaje de programación multiparadigma; esto significa que más
que forzar a los programadores a adoptar un estilo particular de programación,
permite varios estilos: programación orientada a objetos, programación estruc-
turada y programación funcional.
Python fue desarrollado por Guido van Rossum en 1991.

Lenguajes de
Programación

Imperativos Declarativos

Orientados a
Estructurados Funcionales Lógicos
Objetos

C
Pascal Python Prolog
COBOL CLIPS
php ...
... C++ Haskell
Java LISP
C# Dr. Scheme
php5 Dr. Racket
... ...

Figure 1.1: Ubicación de Python en la clasificación de acuerdo al paradigma

Algunas veces se hace referencia a Python como un pseudocódigo ejecutable


(http://www.melbpc.org.au/pcupdate/2108/2108article9.htm), veamos esto con
un ejemplo sencillo.
Supongamos la siguiente definición matemática para obtener el factorial de
n
Q
un número natural: i. Esta misma forma del factorial puede definirse como:
i=1
∀i ∈ (1, n).x ← x ∗ i . Un posible pseudocódigo que realice este cálculo es el
siguiente:
Para cada e l e m e n t o en e l rango ( 1 , n ) : h a c e r x <− x∗ i

4
El código Python que se encarga de realizar lo anterior es el siguiente:

x = 1
f o r i i n r a n g e ( 1 , 5 ) : x∗= i

Que, en realidad es la descripción en idioma inglés del pseudocódigo mostrado


anteriormente.

1.1.2 Ventajas.
Python es bueno para muchas situaciones:

Fácil de Usar
Programadores familiarizados con lenguajes tradicionales encontrarán relativa-
mente fácil aprender Python. Todas las expresiones usuales tales como ciclos,
condicionales, arreglos, etc., están incluídas, pero muchas son más sencillas en
Python. Algunas razones son:
3 Los tipos se asocian a objetos, no a varibles. Una variable puede contener
valores de cualquier tipo, y una lista puede contener objetos de tipos
diferentes. Esto también implica que el casting de tipos no es necesario y
tampoco lo es predeclarar variables.
3 Típicamente Python opera en un muy alto nivel de abstracción. En parte
por la construcción del mismo lenguaje y en parte gracias a la librería
estándar tan extensa que esta incluída con la distribución de Python. Un
programa que descargue una página web se puede escribir con dos o tres
líneas de código.
3 Las reglas sintácticas son muy sencillas. Aún los principiantes pueden
escribir código útil rápidamente.
Python es muy conveniente para desarrollo rápido de aplicaciones.

Expresividad.
Python es un lenguaje muy expresivo, en este contexto, expresivo significa que
una línea puede hacer más que una línea en la casi cualquier otro lenguaje.
Las ventajas son obvias: menos líneas de código requieren menor tiempo para
escribirlas, aún más, menos líneas de código impican mayor facilidad para man-
tener y depurar programas.
Por ejemplo, supóngase que se requiere intercambiar un valor entre dos vari-
ables; el siguiente código lo realizaría en un lenguaje tipo C o Java:

i n t temp = var1 ;
var1 = var2 ;
var2 = temp ;

5
Por el contrario, el mismo intercambio de valores se puede hacer con la
siguiente línea de código Python:

var2 , var1 = var1 , var2

Además de la simplicidad del código, debe notarse que no es necesario hacer


uso (explícito) de una variable auxiliar para realizar el intercambio.

Legibilidad.
Otra ventaja de Python, es su fácilidad de lectura; podría pensarse que un
programa será leído solo por una computadora, pero también será leído por
seres humanos, ya sea al depurar, mantener o modificar el código; en cualquier
caso, entre más legible sea, será más sencillo realizarlo.

“Baterías incluídas”
Otra ventaja de Python es su filosofía de “baterías incuídas” cuando se habla de
librerías. La idea es que al instalar Python se debería tener todo lo necesario
para hacer trabajo real. Por esto la librería estándar de Python incluye mó-
dulos para manejo de email, páginas web, bases de datos, llamadas al sistema
operativo, desarrollo de GUIs y más. Por ejemplo, se puede escribir un servidor
web para compartir archivos de un directorio con solo dos líneas de código:

import h t t p . s e r v e r
h t t p . s e r v e r . t e s t ( H a n d l e r C l a s s=h t t p . s e r v e r . SimpleHTTPRequestHandler )

No hay necesidad de instalar librerías extras para controlar conexiones ni


HTTP; ya están incluídas en Python.

Multiplataforma.
Python también es un excelente lenguaje multiplataforma; corre en Windows,
Mac, Linux, UNIX. Dado que es interpretado, el mismo código puede ejecutarse
en cualquier plataforma que tenga instalado un intérprete de Python. Incluso
existen versiones de Python que corren en Java (Jython) y .NET (IronPython),
incrementando las plataformas de ejecución de Python.

Open Source.
Python está desarrollado con el modelo open source y está disponible libre-
mente, se puede descargar e instalar cualquier versión, además puede usarse
para desarrollar software comercial o aplicaciones personales sin necesidad de
pagar por él.
Greg Stein, ingeniero administrador del grupo Open Source de Google, dijo
en su presentación en la SDForum Python Meeting:

6
En Google, Python es uno de 3 “lenguajes oficiales”, junto con C++ y Java.
Oficial significa que los empleados de Google pueden usar estos lenguajes en
proyectos de producción. Internamente, la gente de Google puede usar muchas
otras tecnologías, incluyendo PHP, C#, Ruby y Perl. Python está bien ade-
cuado a los procesos de ingeniería en Google. El típico proyecto en Google
tiene un equipo pequeño (de 3 personas) y una corta duración (de 3 meses).
Después de que el proyecto se ha terminado, los desarrolladores pueden irse a
otros proyectos. Los proyectos más grandes pueden subdividirse en otros más
pequeños presentables en 3 meses, y los equipos pueden elegir su propio lenguaje
para el proyecto.

1.1.3 Desventajas
Python tiene ventajas, aún así ningún lenguaje puede hacer todo, por tanto
Python no es la solución perfecta para todas las necesidades. Para decidir
si Python es el lenguaje correcto para una situación específica, es necesario
considerar las áreas en las que Python no es tan bueno:

No es el lenguaje más rápido.


Un posible inconveniente de Python es su velocidad de ejecución, es un lenguaje
interpretado, debido a esto, la mayoría de las veces Python resulta en programas
que se ejecutan más lento que un programa realizado en C. Sin embargo, las
computadoras actuales tienen el poder suficiente para que en la gran mayoría
de las aplicaciones la velocidad del programa no sea tan importante como la
rapidez de desarrollo. Además, Python puede extenderse con módulos escritos
en C, que ejecuten porciones de código intensivo para el CPU.

No posee las librerías más extensas.


Python posee una excelente colección de librerías desde la instalación y muchas
otras están disponibles, sin embargo, lenguajes como C, Java o Perl tienen colec-
ciones más extensas disponibles y en algunas ocasiones ofrecen varias soluciones
cuando Python tiene solamente una. Sin embargo, Python puede extenderse
con librerías de otro lenguajes. Para resolver los problemas más comunes de
computación, el soporte de las librerías estándar de Python es excelente.

No tiene revisión de tipos.


Contrario a otros lenguajes, las variables en Python son más etiquetas que hacen
referencia a varios objetos: enteros, cadenas, clases, etc.; esto implica que aún
cuando estos objetos tienen tipos, las variables que hacen referencia a ellos no
están ligados a un tipo en particular. Es posible que alguna variable x refiera a
una cadena en una línea y a un entero en otra.
El hecho de que Python asocia tipos con objetos y no con variables, quiere
decir que el intérprete no ayudará a encontrar “errores” en el tipo de una vari-
able.

7
1.1.4 ¿Quién lo usa?
En general, Python, goza de una gran base de usuarios, y una muy activa
comunidad de desarrolladores. Dado que Python ha existido por casi 20 años y
ha sido ampliamente utilizado, también es muy estable y robusto. Además de
ser utilizado por usuarios individuales, Python también se aplica a productos
reales en empresas reales. Por ejemplo:
3 Google hace un amplio uso de Python en su sistema de búsqueda web, y
emplea al creador de Python.
3 El servicio de video YouTube, es en gran medida escrito en Python.
3 El popular peer-to-peer BitTorrent para compartir archivos es un pro-
grama Python.

3 Intel, Cisco, Hewlett-Packard, Seagate, Qualcomm e IBM utilizan Python


para las pruebas de hardware.
3 Industrial Light & Magic, Pixar, y otros utilizan Python en la producción
de cine de animación.

3 JPMorgan Chase, Getco, y Citadel aplican Python para los mercados fi-
nancieros de previsión.
3 La NASA, Los Alamos, Fermilab, JPL, y otros utilizan Python para tareas
de programación científica.
3 iRobot utiliza Python para desarrollar aspiradoras robóticas comerciales.

3 ESRI utiliza Python como una herramienta de personalización de usuario


final para sus populares productos de cartografía GIS.
3 La NSA utiliza Python para criptografía y análisis de inteligencia.
3 El servidor de correo electrónico de IronPort utiliza más de 1 millón de
líneas de código Python para hacer su trabajo.
3 El proyecto One Laptop Per Child (OLPC) basa su interfaz de usuario y
el modelo de actividad en Python.
3 El servidor web Zope y el CMS Plone están escritos completamente en
Python.
Y la lista continua, para más detalles sobre empresas que utilizan hoy Python,
véase el sitio web de Python para mayor referencia https://www.python.org/about/success/.

8
1.2 Primeros pasos.
1.2.1 Instalación.
Instalar Python es un asunto sencillo, sin importar el sistema operativo que se
utilice. El primer paso es obtener una distribución para el equipo usado, para
esto se debe acceder a la sección de descargas es www.python.org y seguir las
instrucciones referentes al sistema operativo utilizado.

1.2.2 Modo interactivo.


El modo interactivo permite ejecutar diversos comandos de Python; para inicia-
rlo, en una terminal (interfaz de comandos en windows) se debe escribir python
en la línea de comandos. Si existen varias versiones instaladas, puede especifi-
carse la deseada, por ejemplo python3.
La mayoría de las plataformas tienen un mecanismo de historial de coman-
dos, se pueden recuperar instucciones escritas con ayuda de las teclas de direc-
ción.
Para salir del modo interactivo, se debe usar la combinación de teclas CTRL+D
(CTRL+Z en windows).

1.2.3 Hola mundo.


Una vez en el modo interactivo, el prompt está identificado por >‌>‌>. Este es
el prompt de comandos de Python e indica que se puede escribir un comando
para ser ejecutado o una expresión para ser evaluada. Comenzaremos con el
obligatorio “Hola mundo”, el cual consiste de una sola línea en Python:

>>> p r i n t ( " Hola mundo " )


Hola mundo

En Python 2, también puede escribirse como:

>>> p r i n t " Hola mundo"


Hola mundo

1.2.4 El Zen de Python


Los usuarios de Python se refieren a menudo a la Filosofía Python que es
bastante análoga a la Filosofía de Unix.
El código que sigue los principios de Python de legibilidad y transparencia se
dice que es pythonico. Contrariamente, el código opaco u ofuscado es bautizado
como no pythonico (unpythonic en inglés).
Estos principios fueron famosamente descritos por el desarrollador de Python
Tim Peters en el Zen de Python.

9
3 Bello es mejor que feo.
3 Explícito es mejor que implícito.
3 Simple es mejor que complejo.
3 Complejo es mejor que complicado.

3 Plano es mejor que anidado.


3 Disperso es mejor que denso.
3 La legibilidad cuenta.

3 Los casos especiales no son tan especiales como para quebrantar las reglas.
3 Aunque lo práctico gana a la pureza.
3 Los errores nunca deberían dejarse pasar silenciosamente.
3 A menos que hayan sido silenciados explícitamente.

3 Frente a la ambigüedad, rechaza la tentación de adivinar.


3 Debería haber una -y preferiblemente sólo una- manera obvia de hacerlo.
3 Aunque esa manera puede no ser obvia al principio a menos que usted sea
holandés.

3 Ahora es mejor que nunca.


3 Aunque nunca es a menudo mejor que ya mismo.
3 Si la implementación es difícil de explicar, es una mala idea.

3 Si la implementación es fácil de explicar, puede que sea una buena idea.


3 Los espacios de nombres (namespaces) son una gran idea ¡Hagamos más
de esas cosas!

En cualquier momento se puede consultar esta guía desde el modo interactivo


de Python:

>>> import t h i s

También es interesante probar:

>>> import a n t i g r a v i t y

10
1.2.5 Usando el modo interactivo para explorar Python.
Existen algunas herramientas útiles para explorar Python:
La primera es la función help() que tiene dos modos. Escribir solo help() en
el prompt para entrar al sistema de ayuda. Una vez dentro, el prompt cambia
a help>, y se puede ingresar el nombre de algún módulo, por ejemplo math y
explorar la documentación de ese tema.
Usualmente es más conveniente utilizar help() de forma más dirigida; in-
gresando un tipo o una variable como parámetro de help(), se obtiene ayuda
inmediata de la documentación de ese tipo:

>>> x = 5
>>> h e l p ( x )

Usar help() de esta forma es más práctico para revisar la sintaxis de un


método o el comportamiento de un objeto.
Otra función útil es dir(), la cual lista los objetos en un espacio particular.
Si se usa sin parámetros, lista las variables globales, pero también puede listar
los objetos de un módulo o incluso de un tipo:

>>> d i r ( )
>>> d i r ( i n t )

La función type() devuelve el tipo de dato del objeto que recibe como
parámetro:

>>> type ( 5 )
>>> type (1+1 j )
>>> type ( None )

Además se pueden usar otras dos funciones para ver los valores de variables
locales y globales respectivamente: locals() y globals().

1.2.6 Otros recursos


3 Se puede consultar la documentación oficial en cualquier momento en la
URL http://docs.python.org

3 Así mismo, se puede revisar la lista de libros gratuitos en línea:


https://github.com/vhf/free-programming-books/blob/master/free-programming-
books.md#python
3 Esta presentación muestra algunas diferencias entre Python 2 y 3:
https://www.dropbox.com/s/83ppa5iykqmr14z/Py2v3Hackers2013.pptx

11
2 Tipos básicos.
2.1 None.
None es una constante especial de Python, cuyo valor es nulo.
3 None no es lo mismo que False.
3 None no es 0.
3 None no es una cadena vacía.

3 Si comparas None con cualquier otra cosa que no tenga valor None ob-
tendrás siempre False.
3 None es el único valor nulo.
Tiene su propio tipo de dato (NoneType), se puede asignar None a cualquier
variable y todas las variables cuyo valor es None son iguales entre sí.

>>> x = None
>>> type ( x )
>>> type ( None )

2.2 Booleanos.
Los booleanos son verdaderos o falsos. Python tiene dos constantes, de inge-
nioso nombre True y False, que se pueden usar para asignar valores booleanos
de manera directa. Las expresiones también pueden evaluarse como valores
booleanos.
En ciertos lugares (como las sentencias if ), Python espera que la evaluación
de expresiones produzca un booleano. Estos lugares se denominan contextos
booleanos. En uno de estos contextos se puede usar prácticamente cualquier
expresión y Python tratará de determinar su valor de verdad.

2.3 Números.
Python incluye manejo de números para enteros, de punto flotante y comple-
jos. Pueden realizarse operaciones con los operadores aritméticos: + (suma), -
(resta), * (multiplicación), / división, ** (exponenciación) y % (módulo).
Con enteros:

>>> x = 2∗3+1−5
>>> x = 5/2
>>> x = 5%2
>>> x = 5∗∗2

12
Pero todos funcionan también con flotantes:

>>> x = 2.1∗3.2+1.5 −5.3


>>> x = 5.0/2
>>> x = 5/2.0
>>> x = 5.3%2.1
>>> x = 4.5∗∗2.3

Y con complejos (sin necesidad de importar alguna librería):

>>> x = 2.1+3.2 j
>>> y = 1.5+5.3 j
>>> z = x + y
>>> z = x − y
>>> z = x ∗ y
>>> z = x / y
>>> z = x ∗∗ y

En Python 3, NO está disponible la operación módulo entre complejos; en


Python 2 sí:

>>> z = x % y

2.4 Listas.
Cuando se habla de una lista, puede pensarse en “un arreglo cuyo tamaño hay
que declarar con antelación, que sólo puede contener elementos del mismo tipo”.
Pero en realidad una lista de Python es mucho más poderosa.

2.4.1 Creación de una lista.


Crear una lista es sencillo, solo se deben usar corchetes para encerrar una lista
valores separados por comas:

>>> x = [ 1 , 2 , 3 ] # una l i s t a de e n t e r o s
>>> x = [ " uno " , " dos " , " t r e s " ] # una l i s t a de c a d e n a s

Pero una lista puede contener valores de diferentes tipos:

>>> x = [ 5 , " dos " , [ 1 , 2 , 3 ] ] # una l i s t a de t i p o s


d i f e r e n t e s : e n t e r o , cadena , l i s t a

La función len() devuelve el número de elementos que tiene una lista.

>>> x = [ 5 , " dos " , [ 1 , 2 , 3 ] ]


>>> l e n ( x )

13
2.4.2 Índices.
Entender la forma en la que trabajan los índices de listas es muy útil.
Se pueden obtener los elementos de un lista de Python usando notación
similar a C o Java; al igual que en C y otros lenguajes, el índice inicial para
Python es 0 y devuelve el primer elemento de la lista:

>>> x = [ " uno " , " dos " , " t r e s " , " c u a t r o " ]
>>> x [ 0 ]
>>> x [ 3 ]

Pero el indexamiento de Python es más flexible, si se utiliza un índice neg-


ativo, asume que se busca una posición determinada contando desde el final de
la lista, con -1 la última posición:

>>> x = [ " uno " , " dos " , " t r e s " , " c u a t r o " ]
>>> x [ −1]
>>> x [ −3]

2.4.3 Particionado de una lista.


Una vez definida una lista, se puede obtener cualquier parte suya en forma de
una nueva lista. A esto se le denomina particionado (slicing) de la lista.

>>> x = [ " uno " , " dos " , " t r e s " , " c u a t r o " ]
>>> x[0:3]
>>> x [1: −1]
>>> x [1: −3]

2.4.4 Modificado de una lista.


Se puede utilizar el indexamiento para obtener un valor y también para mod-
ificarlo.

>>> x = [ 1 , 2 , 3 , 4 ]
>>> x [ 1 ] = " dos "

Agregar un elemento es una operación común, para esto Python incluye


un método especial:

>>> x = [ 1 , 2 , 3 , 4 ]
>>> x . append ( " c i n c o " )

A veces se necesita concatenar una lista al final de otra:

14
>>> x = [ 1 , 2 , 3 , 4 ]
>>> y = [ 5 , 6 , 7 ]
>>> x . append ( y )

Pero en este caso y es un elemento de x, no es el resultado deseado; para


concatenar se utiliza otro método:

>>> x = [ 1 , 2 , 3 , 4 ]
>>> y = [ 5 , 6 , 7 ]
>>> x . extend ( y )

También es posible insertar un elemento en una posición determinada:

>>> x = [1 , 2 , 3 , 4]
>>> x . i n s e r t (2 , " centro ")
>>> x . i n s e r t (0 , " i n i c i o ")
>>> x . i n s e r t ( −1 , " n e g a t i v o " )

El comando más usado para eliminar elementos de una lista es del :

>>> x = [1 , 2 , 3 , 4 , 5 , 6 , 7 , 8]
>>> del x[1]
>>> del x[:2]
>>> del x[2:]

El método remove elimina la primera incidencia del valor dado:

>>> x = [ 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 ]
>>> x . remove ( 3 )

Para invertir una lista, se tiene un método especializado:

>>> x = [ 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 ]
>>> x . r e v e r s e ( )

2.4.5 Ordenamiento.
Python el método sort para ordenar listas:

>>> x = [ 3 , 8 , 4 , 0 , 2 , 1 ]
>>> x . s o r t ( )

15
Este método modifica la lista original, para evitarlo, se puede trabajar sobre
una copia:

>>> x = [ 3 , 8 , 4 , 0 , 2 , 1 ]
>>> y = x [ : ]
>>> y . s o r t ( )

También sirve para ordenar cadenas y listas:

>>> x = [ " uno " , " dos " , " t r e s " , " c u a t r o " ]
>>> x . sort ()
>>> x = [[3 , 5] , [2 , 9] , [2 , 3] , [4 , 1] , [3 , 2]]
>>> x . sort ()

Nota: en Python 2 sirve para ordenar listas de tipos combinados:

>>> x = [ 1 , 2 , " t r e s " , 4 , [ 2 , 9 ] ]


>>> x . s o r t ( )

En Python 3 esta característica fue eliminada.

>>> x = [1+1 j ,2 −3 j ,−2+2 j ,5+9 j ] # ¿Se pueden o r d e n a r c o m p l e j o s ?


>>> x . s o r t ( ) # NO

¿Por qué? → http://goo.gl/UVYsR

2.4.6 Otras operaciones comunes


Para determinar si un elemento pertenece o no a una lista:

>>> x = [ 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 ]
>>> 3 i n x
>>> 3 not i n x

Otra forma de concatenar listas es hacer uso del operador +:

>>> x = [ 1 , 2 , 3 , 4 ]
>>> y = [ 5 , 6 , 7 ]
>>> z = x + y

Inicialización con el operador *:

16
>>> x = [ None ] ∗ 4
>>> y = [ 1 , 2 ] ∗ 3

También se puede buscar el mínimo y máximo de una lista:

>>> x = [ 3 , 8 , 4 , 0 , 2 , 1 ]
>>> min ( x )
>>> max( x )

Con cadenas:

>>> x = [ " uno " , " dos " , " t r e s " , " c u a t r o " ]
>>> min ( x )
>>> max( x )

En Python 2, también sirve para listas de tipos combinados (en Python 3


no).
Se puede buscar el índice de algún elemento:

>>> x = [ 3 , 8 , 4 , 0 , 2 , 1 ]
>>> x . i n d e x ( 4 )

Y podemos obtener el número de apariciones de un elemento en una


lista:

>>> x = [ 1 , 2 , 2 , 3 , 5 , 2 , 5 ]
>>> x . count ( 2 )
>>> x . count ( 0 )

Finalmente, Python incluye la función pop, que obtiene el último ele-


mento de una lista y lo elimina de la misma:

>>> x = [ 3 , 8 , 4 , 0 , 2 , 1 ]
>>> x . pop ( ) # d e v u e l v e 1

Y tiene una variante que obtiene el valor del índice indicado y también lo
elimina:

>>> x = [ 3 , 8 , 4 , 0 , 2 , 1 ]
>>> x . pop ( 2 ) # d e v u e l v e 4

17
2.5 Tuplas.
Las tuplas son estructuras de datos similares a las listas, pero no pueden mod-
ificarse, solo pueden crearse. Una tupla es una lista inmutable.

2.5.1 Creación de una tupla.


Una tupla se define de la misma manera que una lista, excepto que el conjunto
de elementos se encierra entre paréntesis en lugar de corchetes.
3 Los elementos de una tupla tienen un orden definido, al igual que en las
listas.
3 Los índices de las tuplas empiezan en 0, exactamente como las listas.
3 Los índices negativos empiezan a contar desde el final de la tupla, como
con las listas.
3 También funciona el particionado, igual que en las listas.
Muchas funciones de listas sirven para manipular tuplas:

>>> x = ( ’ a ’ , ’ b ’ , ’ c ’ ) # una t u p l a de t r e s e l e m e n t o s
>>> x[0]
>>> x[1:]
>>> len (x)
>>> min ( x )
>>> max( x )
>>> ’ c ’ in x
>>> ’ d ’ not i n x

La principal diferencia entre tuplas y listas, es que una tupla no puede mod-
ificarse:

>>> x = ( ’ a ’ , ’ b ’ , ’ c ’ )
>>> x [ 2 ] = ’ d ’

Pero se pueden crear tuplas con los operadores + y *:

>>> x = ( ’ a ’ , ’ b ’ , ’ c ’ )
>>> y = x + x
>>> y = x ∗ 4

La copia de una tupla se hace de la misma forma que las listas:

>>> x = ( ’ a ’ , ’ b ’ , ’ c ’ )
>>> y = x [ : ]

18
Una pregunta interesante es por qué Python incluye tuplas si son tan simi-
lares a las listas, y de hecho más limitadas, ya que son estáticas, las razones son
las siguientes:
3 Las tuplas son más rápidas que las listas. Si se requiere un conjunto
constante de valores para iterar sobre él, una tupla es más conveniente
que una lista.
3 El código es más seguro si se “protegen contra escritura” los datos que no
haga falta cambiar.
3 Algunas tuplas se pueden usar como claves para diccionarios, como se verá
más adelante, mientras que las listas no se pueden usar para este fin.

2.5.2 Conversiones entre listas y tuplas.


Las tuplas pueden convertirse en listas con la función list; de manera similar,
las listas pueden convertirse en tuplas con la función tuple:

>>> x = l i s t ( ( 1 , 2 , 3 , 4 ) )
>>> x = t u p l e ( [ 1 , 2 , 3 , 4 ] )

Como nota interesante, una lista es una forma conveniente de separar una
cadena en caracteres:

>>> x = l i s t ( " Hola " )

Esto funciona debido a que list (y tuple) se aplican a cualquier secuencia de


Python, y una cadena es solo una secuencia de caracteres.

2.6 Conjuntos.
Un conjunto es una colección desordenada de objetos, usado en situaciones en
las que la pertenencia y la unicidad de cada objeto es importante.

2.6.1 Creación de un conjunto.


Para crear conjuntos en Python, se utiliza la función set, que recibe una lista o
una tupla como parámetro:

>>> x = s e t ( [ 1 , 2 , 3 , 4 ] )
>>> x = s e t ( ( 1 , 2 , 3 , 4 ) )

19
2.6.2 Operaciones con conjuntos.
Python ofrece varias operaciones específicas de conjuntos:

>>> x = set ([1 , 2 , 3 , 4])


>>> x . add ( 5 )
>>> x . add ( 5 ) # un c o n j u n t o no almacena e l e m e n t o s r e p e t i d o s
>>> x . remove ( 4 ) # e l i m i n a un e l e m e n t o
>>> x . d i s c a r d ( 4 ) # también s i r v e para e l i m i n a r
>>> 2 in x
>>> 4 in x

Además, si se tienen dos conjuntos puede obtenerse la unión, intersección y


diferencia entre ellos:

>>> x = set ([1 , 2 , 3 , 4])


>>> y = set ([3 , 4 , 5 , 6])
>>> z = x | y # unión
>>> z = x & y # intersección
>>> z = x − y # diferencia
>>> z = x ^ y # diferencia simétrica

2.7 Cadenas.
El procesamiento de cadenas (strings) es una de las fortalezas de Python.

2.7.1 Creación de cadenas.


Existen varias formas de delimitar cadenas en Python:

>>> x = "Cadena con c o m i l l a s d o b l e s , puede c o n t e n e r ’ c o m i l l a s s i m p l e s ’ "


>>> x = ’ Cadena con c o m i l l a s s i m p l e s , puede c o n t e n e r " c o m i l l a s d o b l e s " ’
>>> x = ’ ’ ’ \ tCadena que i n i c i a con un t a b u l a d o r y una l í n e a nueva \n ’ ’ ’
>>> x = """ Cadena con t r i p l e c o m i l l a s d o b l e s ,
... puede c o n t e n e r l í n e a s nuevas ’ r e a l e s ’ " " "

Se pueden concatenar cadenas con el operador +:

>>> x = " Hola "


>>> y = ’ mundo ’
>>> z = x + y

Y también existe el operador multiplicación de cadenas *:

>>> x = "x" ∗ 10

20
2.7.2 Métodos asociados a cadenas.
La mayoría de los métodos para cadenas de Python están integrados a la clase
string, por tanto cualquier cadena los tiene asociados; para hacer uso de algún
método se utiliza el operador punto (.).
Cómo las cadenas son inmutables, los métodos devuelven un resultado, pero
no modifican la cadena original.

Los métodos split y join.


Son dos métodos muy útiles cuando se trabaja con cadenas, la función split
devuelve una lista de subcadenas de la cadena original:

>>> x = " Hola mundo"


>>> y = x . s p l i t ( )

Se puede especificar una cadena usada como separador:

>>> x = " Hola&&buen&&d í a "


>>> y = x . s p l i t ( ’&& ’)

Si se especifican n particiones, split generará n+1 subcadenas:

>>> x = "a b c d e"


>>> y = x . s p l i t ( ’ ’ , 1)
>>> y = x . s p l i t ( ’ ’ , 3)
>>> y = x . s p l i t ( ’ ’ , 9)

La función join permite concatenar cadenas, pero de una mejor forma que
el operador +:

>>> x = " " . j o i n ( [ ’ j o i n ’ , ’ concatena ’ , ’ e s p a c i o s ’ ] )


>>> x = " : " . j o i n ( [ ’ j o i n ’ , ’ concatena ’ , ’ l o ’ , ’ que ’ , ’ sea ’ ] )
>>> x = " " . j o i n ( [ ’ i n c l u s o ’ , ’ cadena ’ , ’ v a c í a ’ ] )

Convirtiendo cadenas a números.


Las funciones int y float se utilizan para conviertir cadenas en números enteros
o de punto flotante, respectivamente:

>>> x = int ( ’253 ’)


>>> x = float ( ’128.345 ’)
>>> x = i n t ( ’ 1 2 . 5 ’ ) # e r r o r , un e n t e r o no t i e n e punto d e c i m a l
>>> x = f l o a t ( ’ xx . yy ’ ) # e r r o r , no puede r e p r e s e n t a r s e como número

21
Además int puede recibir un segundo argumento:

>>> x = int ( ’1000 ’ ,8)


>>> x = int ( ’101 ’ ,2)
>>> x = int ( ’ ff ’ ,16)
>>> x = int ( ’12345 ’ ,5)

Python cuenta con métodos para cambiar mayúsculas a minúsculas y vicev-


ersa upper, lower, title; y otras para revisar algunas características de una ca-
dena: isdigit, isalpha, isupper, islower.

Búsquedas.
Las cadenas proveen varios métodos para realizar búsquedas simples en cadenas.
Existen cuatro métodos principales para hacer búsquedas en cadenas Python:
find, rfind, index y rindex, muy similares entre ellas. Además el método count
obtiene el número de apariciones de una cadena dentro de otra.
La función find requiere un argumento, la cadena a buscar y devuelve la
posición del primer caracter en la primera aparición, si no se encuentra, devuelve
-1:

>>> x = " F e r r o c a r r i l "


>>> x . f i n d ( ’ r r ’ )
>>> x . f i n d ( ’ y ’ )

Además, find tiene dos argumentos opcionaes, ambos enteros, si se especifica


el primero, la búsqueda se realiza a partir de esa posición en la cadena, si se
utiliza el segundo argumento, la búsqueda se hace en la subcadena limitada por
ambos argumentos:

>>> x = " F e r r o c a r r i l "


>>> x . f i n d ( ’ r r ’ , 4 )
>>> x . f i n d ( ’ r r ’ , 4 , 6 )

Otro par de funciones de búsqueda útiles son startswith y endswith, realizan


una búsqueda al inicio y al final de la cadena, respectivamente, y devuelven un
valor booleano:

>>> x = " F e r r o c a r r i l "


>>> x . s t a r t s w i t h ( ’ f e r ’ )
>>> x . e n d s w i t h ( ’ r r i l ’ )

Pero en Python 3 tiene una ventaja, se pueden buscar varias cadenas, si se


especifican como una tupla:

>>> x = " F e r r o c a r r i l "


>>> x . e n d s w i t h ( ( ’ r r i l ’ , " i l " , " l " ) )

22
Conviertiendo objetos a cadenas.
Prácticamente cualquier cosa en Python puede representarse como cadena, us-
ando la función repr :

>>> x = [1 , 2 , 3 , 4]
>>> "La l i s t a x es : " + repr (x)
>>> x = (1 , 2 , 3 , 4)
>>> "La tupla x es : " + repr (x)
>>> x = set ([1 , 2 , 3 , 4])
>>> " El conjunto x es : " + repr (x)

La función repr puede utilizarse para obtener la representación de cadena


de casi cualquier objeto Python:

>>> r e p r ( l e n )

2.7.3 Formateando cadenas.


Recordemos que se pueden concatenar cadenas con el operador + y el método
join, sin embargo con estas opciones no es posible dar formato alguno a las
cadenas.
Para dar formato a cadenas, Python posee el operador % (string modulus),
se utiliza para combinar valores con cadenas:

>>> " El %s e s l a %s de l o s %s " % ( " t e q u i l a " , " b e b i d a " , " d i o s e s " )

El operador % (al centro, no las %s de la cadena izquierda), requiere dos


partes: del lado izquierdo una cadena y del lado derecho una tupla. El operador
% revisa la cadena buscando secuencias de formato y produce una nueva cadena
sustituyendo las secuencias de formato con los valores de la tupla en el mismo
orden.
La tupla puede contener valores que no son cadenas:

>>> "La %s c o n t i e n e %s " % ( " l i s t a " , [ 5 , " dos " , [ 1 , 2 , 3 ] ] )

Secuencias de formato.
Existen diferentes secuencias de formato:

>>> " Entero : %d" % ( 2 )


>>> " F l o t a n t e : %f " % ( 5 . 2 4 8 1 )
>>> " F l o t a n t e : %6.2 f " % ( 5 . 2 4 8 1 ) # 6 p o s i c i o n e s 2 de
e l l a s para l a parte decimal
>>> " F l o t a n t e : %.3 e " % ( 0 . 0 0 0 0 0 1 9 2 ) # n o t a c i ó n
científica con 3 c i f r a s d e c i m a l e s

23
Nota: Python 3 provee además de % el método format para dar formato a
cadenas.

>>> " El {0} e s l a {1} de l o s { 2 } " . format ( " t e q u i l a " , " b e b i d a " , " d i o s e s " )

En este caso, se tienen tres campos reemplazables {0}, {1} y {2}, los cuales
se rellenan con el primero, segundo y tercer parámetro respectivamente, la difer-
encia y ventaja respecto a %, es que se puede colocar el campo {0} en cualquier
posición y será reemplazado siempre por el primer parámetro.
El método format también reconoce parámetros con nombres para reem-
plazar campos:

>>> " El { b e b i d a } e s l a b e b i d a de l o s { u s u a r i o s } " . format (


b e b i d a=" t e q u i l a " , u s u a r i o s =" d i o s e s " )

También es posible utilizar ambas formas de reemplazo de parámetros, e


incluso se puede acceder a atributos y elementos de esos parámetros:

>>> " El {0} e s l a b e b i d a de l o s { u s u a r i o s [ 1 ] } " . format ( "


t e q u i l a " , u s u a r i o s =[" hombres " , " d i o s e s " , " o t r o s " ] )

Lectura de valores por teclado.


Python proporciona varias formas de leer valores por teclado, la más sencilla es
la función input:

>>> x = i n p u t ( " I n g r e s a a l g o : " )


>>> p r i n t ( x )

La función lee lo que se escribe como cadena, y se debe procesar para uti-
lizarla como algún otro tipo.

2.8 Diccionarios.
Un diccionario es un conjunto desordenado de pares clave-valor (keys-values),
similares a los hashtables, o los arreglos asociativos de otros lenguajes. Cuando
se añade una clave a un diccionario, también se debe añadir su valor asociado
(que puede cambiarse después). Los diccionarios de Python están optimizados
para recuperar un valor a partir de la clave, pero no al contrario.

24
2.8.1 Creación de diccionarios.
Crear un diccionario es sencillo, existen dos formas para hacerlo, la primera es
crear un diccionario vacío solamente con llaves de apertura y cierre:

>>> x = {}

Y después añadir parejas clave-valor:

>>> x [ ’ red ’ ] = ’ r o j o ’
>>> x [ ’ green ’ ] = ’ verde ’
>>> x [ ’ blue ’ ] = ’ a z u l ’

Aunque tambien se puede crear especificand pares clave : valor separados


por comas:

>>> x = { ’ red ’ : ’ r o j o ’ , ’ green ’ : ’ verde ’ , ’ blue ’ : ’ a z u l ’ }

Las claves y los valores pueden ser de tipos distintos:

>>> x = {" uno " : 1 , 2 : " dos " , 2 . 5 : " f l o t a n t e " , 1+1 j : " c o m p l e j o
" , " l i s t a " : [ 1 , 2 , 3 ] , ( 0 , 1 ) : " t u p l a "}

Nota: Las claves del diccionario son únicas.

2.8.2 Modificando un diccionario.


Los diccionarios no tienen ningún límite de tamaño predefinido. Se pueden
añadir pares clave-valor en cualquier momento, o modificar el valor de una clave
ya asignada.

>>> x = { ’ red ’ : ’ r o j o ’ , ’ green ’ : ’ verde ’ , ’ blue ’ : ’ a z u l ’ }


>>> x [ " w h i t e "]=" n e g r o "
>>> x [ " w h i t e "]=" b l a n c o "

2.8.3 Otras operaciones con diccionarios.


Se puede obtener el número de elementos de un diccionario, así como preguntar
si una clave está en el mismo (pero no se puede preguntar por el valor):

>>> x = { ’ red ’ : ’ r o j o ’ , ’ green ’ : ’ verde ’ , ’ blue ’ : ’ a z u l ’ }


>>> len (x)
>>> " red " in x
>>> " rojo " in x

25
Pero se pueden obtener las claves o los valores como una lista:

>>> x = { ’ red ’ : ’ r o j o ’ , ’ green ’ : ’ verde ’ , ’ blue ’ : ’ a z u l ’ }


>>> y = x . k e y s ( )
>>> y = x . v a l u e s ( )

Y ahora podemos preguntar por claves y valores:

>>> x = { ’ red ’ : ’ r o j o ’ , ’ green ’ : ’ verde ’ , ’ blue ’ : ’ a z u l ’ }


>>> y = x . keys ( )
>>> " red " in y
>>> y = x . values ()
>>> " rojo " in y

También se pueden obtener los pares clave-valor del diccionario como una
lista de tuplas:

>>> x = { ’ red ’ : ’ r o j o ’ , ’ green ’ : ’ verde ’ , ’ blue ’ : ’ a z u l ’ }


>>> x . i t e m s ( )

Otros métodos útiles son get, setdefault y copy:

>>> x = { ’ red ’ : ’ r o j o ’ , ’ green ’ : ’ verde ’ , ’ blue ’ : ’ a z u l ’ }


>>> x . g e t ( " g r e e n " , " no d i s p o n i b l e " )
>>> x . g e t ( " b l a c k " , " no d i s p o n i b l e " )
>>> x . s e t d e f a u l t ( " g r e e n " , " no d i s p o n i b l e " )
>>> x . s e t d e f a u l t ( " b l a c k " , " no d i s p o n i b l e " )
>>> y = x . copy ( )

2.8.4 Formateando cadenas con diccionarios.


Se puede combinar el uso del operador % para formatear cadenas con los valores
de un diccionario, utilizando las claves del diccionario como nombres en una
secuencia de formato:

>>> x = { ’ e ’ : 2 . 7 1 8 , ’ pi ’ : 3 . 1 4 1 5 9 }
>>> p r i n t ("%( p i ) . 2 f \n %( p i ) . 4 f \n %(e ) . 2 f " % x )

2.8.5 Tipos válidos para usarse como claves.


Como se mostró anteriormente se pueden utilizar diferentes tipos de Python
como claves de un diccionario, pero no todos: cualquier tipo Python que sea
inmutable puede usarse como clave de un diccionario, lo anterior excluye las
listas, conjuntos y los mismos diccionarios como posibles claves.

26
Ejemplo de uso de tuplas como claves.
Una matriz es una tabla de dos dimensiones como la siguiente:
 
3 0 4 0
 0 0 1 7 
 
 0 2 0 3 
6 0 1 0

Una forma de representar esta matriz en Python es la siguiente:

>>> m = [ [ 3 , 0 , 4 , 0 ] , [ 0 , 0 , 1 , 7 ] , [ 0 , 2 , 0 , 3 ] , [ 6 , 0 , 1 , 0 ] ]

Y se puede tener acceso a los elementos de la matriz usando índices:

>>> m[ 2 ] [ 3 ] # d e v u e l v e 3

Sin embargo, en algunas aplicaciones es común tener matrices de miles de el-


ementos, muchos de los cuales tienen valor 0; una forma de economizar memoria
es hacer uso de matrices dispersas (sparse matrices).
En Python es simple implementar matrices dispersas, utilizando diccionarios
con tuplas como claves, por ejemplo, la matriz anterior se puede representar
como:

>>> m = { ( 0 , 0 ) : 3 , ( 0 , 2 ) : 4 , ( 1 , 2 ) : 1 , ( 1 , 3 ) : 7 , ( 2 , 1 ) : 2 ,
(2 ,3) :3 , (3 ,0) :6 , (3 ,2) :1}

Y se puede utilizar el método get para acceder a los elementos:

>>> m. g e t ( ( 2 , 3 ) , 0 ) # d e v u e l v e 3
>>> m. g e t ( ( 0 , 1 ) , 0 ) # d e v u e l v e 0

2.9 Archivos.
En Python un archivo es un objeto.

2.9.1 Escritura en archivos de texto.


Antes de poder usar un archivo, es necesario abrirlo:

>>> x = open ( " m i a r c h i v o " , "w" ) # modo "w" para c r e a c i ó n /


escritura

Y se puede escribir texto con el método write:

27
>>> x . w r i t e ( " Primera cadena guardada en a r c h i v o de t e x t o \
n")

También texto con formato:

>>> x . w r i t e ( " El v a l o r de PI : <%6.2 f >\n " % ( 3 . 1 4 1 6 ) )

Al terminar de usar un archivo, siempre debe cerrarse:

>>> x . c l o s e ( )

Si se abre nuevamente el archivo con modo w, se elimina el archivo original


y se crea uno nuevo. Para abrir un archivo y añadir texto al final del mismo se
utiliza:

>>> x = open ( " m i a r c h i v o " , " a " ) # modo "a " para e s c r i t u r a
al final
>>> x . w r i t e ( " Texto añadido a l f i n a l \n " )
>>> x . c l o s e ( )

2.9.2 Lectura de archivos de texto.


Python posee un modo específico para leer texto de un archivo de texto:

>>> x = open ( " m i a r c h i v o " , " r " ) # modo " r " para l e c t u r a

Y tenemos varias formas de leer datos del archivo:

>>> x . r e a d l i n e ( ) # l e e una l í n e a d e l a r c h i v o
>>> x . r e a d ( ) # l e e todo e l c o n t e n i d o d e l a r c h i v o a p a r t i r
de l a p o s i c i ó n a c t u a l
>>> x . c l o s e ( )

2.9.3 Otras operaciones con archivos de texto.


Existen otros métodos útiles al trabajar con archivos de texto:

>>> x . s e e k ( 0 ) # r e g r e s a e l apuntador d e l a r c h i v o a l
i n i c i o del archivo
>>> x . s e e k ( 1 6 ) # mueve e l apuntador a l c a r a c t e r 16
>>> x . r e a d ( 1 ) # l e e un c a r a c t e r a p a r t i r de l a p o s i c i ó n
actual
>>> x . r e a d ( 5 ) # l e e c i n c o c a r a c t e r e s a p a r t i r de l a
posición actual
>>> x . t e l l ( ) # d e v u e l v e l a p o s i c i ó n a c t u a l d e l apuntador

28
3 Control de flujo.
Python tiene un conjunto completo de estructuras para controlar el flujo de
la ejecución del programa. Un punto importante para el uso de sentencias
de control de flujo, es que a diferencia de otros lenguajes, la indentación es
obligatoria, con esto se evita el uso de marcadores de bloque.

3.1 Sentencia if-elif-else.


En esta sentencia, se ejecuta el bloque de código que se encuentra después
de la primera condición verdadera (del if o algún elif ), si ninguna condición
es verdadera, se ejecuta el bloque de código después de la sentencia else. La
estructura más general es:

i f cond1 :
bloque1
e l i f cond2 :
bloque2
. . .
e l i f condN :
bloqueN
else :
bloqueElse

Un ejemplo sencillo es el siguiente:

>>> x = i n p u t ( " I n g r e s a un número : " )


>>> y = i n p u t ( " I n g r e s a o t r o número : " )
>>> i f x<y :
... p r i n t ( " y e s mayor " )
... e l i f x>y :
... p r i n t ( " x e s mayor " )
... else :
... p r i n t ( " son i g u a l e s " )

Nota: al trabajar en la línea de comandos, si se da enter en una línea de


código incompleta aparecen de forma automática los puntos suspensivos (. . .),
esperando el resto de la instrucción y para terminarla, se debe dar enter en una
línea vacía.

3.2 Ciclo while.


El ciclo while ejecuta un bloque de código mientras la condición se evalua a
True, una vez que se evalua a False, se ejecuta el bloque de código que sigue al
cierre de indentación:

29
w h i l e cond :
bloqueWhile
bloqueSiguiente

Por ejemplo:

>>> x , y , z =0 ,5 ,0
>>> w h i l e x < y :
... z += x
... x += 1

3.3 Ciclo for.


En Python el ciclo for es diferente a la mayoría de los otros lenguajes de pro-
gramación, este ciclo itera sobre cualquier objeto iterable (cualquier objeto que
contenga secuencias de valores); por ejemplo listas, tuplas, cadenas ó diccionar-
ios. La sintaxis es la siguiente:

for x in secuencia :
bl oq ue For
bloqueSiguiente

Por ejemplo:

>>> l 1 , l 2 =[1 ,2 ,3 ,1+1 j ] , [ ]


>>> f o r x i n l 1 :
... l 2 . append ( x / 1 . 1 )

3.3.1 La función range.


Algunas veces es necesario iterar con índices explícitos (posiciones en una lista).
La función range junto con la función len generan una secuencia de índices que
pueden usarse en el ciclo; como se ve en el siguiente ejemplo:

>>> l =[1 ,2 −3 j ,3 ,1+1 j , 4 ]


>>> f o r i i n r a n g e ( l e n ( l ) ) :
... i f l [ i ] . imag i s not 0 :
... p r i n t ( " Hay un c o m p l e j o en l a p o s i c i ó n %d"
% i)

Si la función range recibe un sólo argumento n, regresa una secuencia de 0 a


n-1; además, range puede utilizarse para generar una secuencias de valores en
un rango:

30
>>> l i s t ( r a n g e ( 3 , 1 2 ) ) # l i s t s e u t i l i z a para que s e vea
>>> l i s t ( r a n g e ( 6 , 2 ) ) # e l r e s u l t a d o p e r o no e s n e c e s a r i a

Y también puede recibir otro argumento, que indica el valor del incremento
a aplicar (puede ser negativo):

>>> l i s t ( r a n g e ( 3 , 1 2 , 2 ) )
>>> l i s t ( r a n g e (6 ,2 , −1) )

Las secuencias generadas por range siempre incluyen el valor inicial y nunca
el valor final.

3.4 Sentencias break y continue.


Tanto el ciclo while como el for tienen una sintaxis más general a la presentada
anteriormente:

w h i l e cond :
bloqueWhile
else :
bloqueElse

for x in secuencia :
bl oq ue For
else :
bloqueElse

En ambos casos, una vez que el ciclo termina, se ejecuta el bloque de la


sentencia else; la diferencia es que si dentro del bloque correspondiente al ciclo
se encuentra una sentencia break, el ciclo termina y no se ejecuta el código
de else. Por otro lado, si el ciclo tiene una sentencia continue, se termina la
iteración actual y se continua con la siguiente iteración.
Ejemplo:

>>> import random


>>> x=random . r a n d i n t ( 1 , 1 0 )
>>> f o r i i n r a n g e ( 3 ) :
... y=i n t ( i n p u t ( ’ a d i v i n a e l número : ’) )
... i f x>y :
... p r i n t ( ’ para a r r i b a ’ )
... e l i f x<y :
... p r i n t ( ’ para abajo ’ )
... else :
... print ( ’ adivinaste ! ’)

31
... break
... continue
... p r i n t ( ’ No l l e g a a e s t a l í n e a ’ )
... else :
... p r i n t ( ’ No a d i v i n a s t e , e l número e s : ’+ r e p r ( x ) )

3.5 Valores booleanos y expresiones.


Los ejemplos anteriores de control de flujo, verifican el valor condicional con
comparaciones, pero no muestran de manera explícita que es un valor True o
False en Python, o que expresiones se pueden utilizar como condición.

3.5.1 La mayoría de los objetos en Python pueden usarse en pruebas


booleanas.
Python incluye el tipo Boolean que puede almacenar los valores True ó False.
Toda expresión booleana devuelve True ó False; las expresiones booleanas se
forman con operadores de comparación (<, >, ==, !=, <=, >=, <>) y con
operadores lógicos (and, or, not, is, is not).
Adicionalmente, Python utiliza las siguientes reglas cuando un objeto se
utiliza como condición:
3 Cualquiera de los siguientes valores son False:

– Los números 0, 0.0 y 0 + 0j


– La cadena vacía “”
– La lista vacía []
– El conjunto vacío set()
– El diccionario vacío {}
– El valor None

3 Y cualquier valor diferente a los anteriores, es True.


Existen otras estructuras que no se han revisado, pero se aplica la misma regla
general. Algunos objetos como no tienen una definición de 0, vacío ó nulo (como
es el caso de los archivos) y no deben usarse en un contexto booleano.

3.6 Listas y diccionarios por “entendimiento/completitud ”.


Utilizar un ciclo for para iterar sobre una lista para modificar ó seleccionar
elementos indivuales y, a partir de ellos crear una nueva lista o diccionario es
muy común; un ciclo como tal se vería de la siguiente forma:

32
>>> l = [1 , 2 , 3 , 4]
>>> l_2 = []
>>> f o r x in l :
... l_2 . append ( x ∗∗ 2 )

Esto es tan común que Python posee una forma especial para estas opera-
ciones, llamado “entendimiento” (comprehension). Una lista o diccionario por
entendimiento es un ciclo de una sola línea que crea una nueva lista o diccionario
a partir de otra lista.
La sintaxis general es la siguiente:

l i s t a N u e v a = [ expr1 f o r var i n l i s t a i f expr2 ]


d i c c i o n a r i o N u e v o = { expr1 : expr2 f o r var i n l i s t a i f expr3 }

Por ejemplo, el código siguiente hace exactamente lo mismo que el ejemplo


inicial, pero usando entendimiento:

>>> l = [ 1 , 2 , 3 , 4 ]
>>> l_2 = [ x ∗∗ 2 f o r x i n l ]

Incluso puede usarse una expresión if para elegir ciertos elementos de la


lista:

>>> l = r a n g e ( 2 0 )
>>> l_2 = [ x ∗∗2 f o r x i n l i f x%2 i s 0 ]

Además en Python 3 se pueden generar diccionarios por entendimiento. Un


diccionario por entendimiento es similar, pero es necesario proporcionar pares
clave-valor; por ejemplo, si se desea un diccionario con clave un número y valor
el cuadrado de cada número, se puede obtener por entendimiento, de la siguiente
manera:

>>> l = r a n g e ( 2 0 )
>>> d i c = {x : x ∗∗ 2 f o r x i n l i f x%2 i s 0}

La creación de listas y diccionarios por entendimiento es un mecanismo muy


útil y poderoso que puede hacer más sencillo el procesamiento de listas.

33
4 Funciones.
4.1 Definición de funciones.
La definición de funciones en Python tiene la siguiente sintaxis:

d e f nombre_funcion ( param1 , param2 , . . . ) :


cuerpo

Como en las estructuras de control, Python utiliza indentación para delimitar


el cuerpo de la función, por ejemplo:

>>> d e f suma ( n ) :
... """ R e a l i z a l a suma de n a 0"""
... s = 0
... while n > 0:
... s += n
... n −= 1
... return s

La línea 2 es opcional y es una cadena de documentación (docstring) y se


puede recuperar su valor con suma.__doc__. Usualmente la cadena de docu-
mentación se utiliza para dar una sinopsis de la función en varias líneas.
Ahora está disponible en el ambiente el uso de la función suma:

>>> suma ( 5 )
>>> x = suma ( 5 )

4.2 Opciones para los parámetros de una función.


La mayoría de las funciones necesitan parámetro, cada lenguaje tiene reglas es-
pecíficas para el manejo de parámetros. Python es flexible y provee tres opciones
para definir parámetros de funciones.

4.2.1 Paso de parámetros por posición.


La forma más sencilla de pasar parámetros a un función en Python es por posi-
ción. En la primer línea de la función se especifican los nombres de las variables
para cada parámetro; cuando se llama la función, los parámetros usados en el
llamado se asocian con los parámetros, basados en el orden.
El siguiente ejemplo calcula x elevado a la potencia y:

34
>>> d e f pow ( x , y ) :
... """ C a l c u l a x ^ y """
... p = 1
... while y > 0:
... p ∗= x
... y −= 1
... return p

Esta función requiere que el número de parámetros sea exactamente el mismo


al número de parámetros de la definición de la función, o generará una excepción
de TypeError :

>>> pow ( 5 , 2 ) # d e v u e l v e 25
>>> pow ( 5 ) # g e n e r a una e x c e p c i ó n TypeError

4.2.2 Valores de parámetros por omisión.


Los parámetros de una función pueden tener valores por omisión (default), que
se declaran asignando una valor en la primera línea de la definición de la función,
la sintaxis es:

d e f f u n c i o n ( param1=val1 , param2=val2 , param3=val3 , . . . )


:
cuerpo

El siguiente ejemplo también realiza el cálculo de x a la potencia y, pero si


no se especifica un valor para y, se utiliza el valor por omisión 2 y la función
obtiene el cuadrado del primer parámetro:

>>> d e f pow ( x , y=2) :


... """ C a l c u l a x ^ y """
... p = 1
... while y > 0:
... p ∗= x
... y −= 1
... return p

4.2.3 Paso de parámetros por nombre del parámetro.


Se pueden pasar argumentos a una función usando el nombre del parámetro
correspondiente, en lugar de su posición. Usando la función anterior, la función
puede llamarse como:

35
>>> pow ( 5 , 3 ) # d e v u e l v e 125
>>> pow ( 5 ) # d e v u e l v e 25
>>> pow ( y=3, x=5) # d e v u e l v e 125

Dado que en el útimo llamado los argumentos tienen el nombre de los


parámetros, la posición es irrelevante. Este mecanismo se conoce como paso
por palabra clave (keyword passing).
Combinar el paso de parámetros por palabra clave junton con los valores por
omisión puede resultar muy útil cuande se desea definir funciones con un gran
número de argumentos posibles.

4.2.4 Número variable de parámetros.


Las funciones en Python pueden tener un número variable de argumentos, esto
puede hacerse de dos formas diferentes. La primera sirve para el caso en que
no se conoce el número de argumentos, y se desea capturar estos argumentos
en una lista. El segundo método puede capturar un número arbitrario de argu-
mentos pasados por palabra clave, que no tienen un nombre de parámetro que
corresponda con la definición de la función, en un diccionario.

Manipulación de un número indefinido de argumentos por posición.


Colcar un * antes del nombre del último parámetrode una función provoca que
los argumentos “extras” que no usen palabra clave en la llamada a la función,
sean captados como una tupla en el parámetro dado.
El siguiente ejemplo obtiene el máximo elemento de una lista de elementos:

>>> d e f maximo ( ∗ numeros ) :


... i f not numeros :
... r e t u r n None
... else :
... numMax = numeros [ 0 ]
... f o r n i n numeros [ 1 : ] :
... i f n > numMax :
... numMax = n
... r e t u r n numMax

Y se puede llamar de la siguiente manera:

>>> maximo ( ) # d e v u e l v e None


>>> maximo ( 1 , 5 , 2 , 6 , 9 , 7 , 4 , 8 , 3 )

36
Manipulación de un número indefinido de argumentos por palabra
clave.
Un número arbitrario de argumentos por palabra clave también puede ser ma-
nipulado, si se antepone ** al último parámetro de la función, esté colectará los
argumentos “extras” que sean pasados por palabra clave en un diccionario. La
clave de cada entrada será la palabra clave (nombre del parámetro) y el valor
será el mismo que se pasa como argumento.
Por ejemplo:

>>> d e f ejemDic ( x , y , ∗∗ d i c ) :
... p r i n t ( " x = %s y = %s d i c t = %s " % ( x , y , d i c ) )

Y el llamado es de la siguiente manera:

>>> ejemDic ( y = 1 , x = 2 )
>>> ejemDic ( y = 1 , x = 2 , z = 4 , w = 6 )

4.2.5 Combinando las técnicas de paso de argumentos.


Es posible utilizar todas las formas de paso de argumentos mostradas en fun-
ciones de Python al mismo tiempo; sin embargo, puede resultar confuso si no
se realiza con cuidado.

>>> d e f ejem ( x = 0 , y = None , ∗ t u p l a , ∗∗ d i c ) :


... p r i n t ( " x = %s y = %s t u p l a = %s d i c t = %s " % ( x ,
y , tupla , dic ) )

Y la función se puede invocar de la siguiente manera:

>>> ejem ( )
>>> ejem ( y=10)
>>> ejem ( z =15)
>>> ejem ( 1 , 2 , 3 , 4 , 5 , 6 , z =7, w=8)
>>> ejem ( 1 , 2 , 3 , 4 , u=5, v=6, z =7, w=8)

4.3 Asignación de funciones a variables.


Al igual que otros objetos de Python, las funciones pueden asignarse a variables:

37
>>> d e f pow ( x , y=2) :
... """ Devuelve x ^ y , s i s ó l o r e c i b e
... un argumento , d e v u e l v e x ^ 2"""
... r e t u r n x ∗∗ y
...
>>> def doble (x) :
... """ C a l c u l a 2 ∗ x """
... return 2 ∗ x
...
>>> f 1 = pow
>>> f2 = doble

Y se pueden ejecutar las funciones de la siguiente manera:

>>> f 1 ( 2 , 3 )
>>> f 1 ( 3 )
>>> f 2 ( 6 )

Incluso pueden colocarse en listas, tuplas o diccionarios, en este ejemplo se


muestra como se hace el llamado:

>>> d i c = { ’ f1 ’ : pow , ’ f2 ’ : d o b l e }
>>> d i c [ ’ f1 ’ ] ( 2 , 8 )
>>> d i c [ ’ f2 ’ ] ( 6 )

5 Módulos.
Los módulos se utilizan para organizar proyectos grandes de Python, por ejem-
plos, la librería estándar está dividida en módulos para que su manejo sea más
sencillo. No es necesario organizar todos los códigos de Python en módulos, pero
si un programa ocupa muchas líneas de código, o si se desea reutilizar código,
es buena idea hacerlo de esta forma.
Un módulo es un archivo que contiene código en el que se definen un conjunto
de funciones de Python y otros objetos. El nombre del módulo se deriva del
nombre del archivo y se puede importar con la sentencia:

>>> import NombreModulo

5.1 Primer módulo.


Para crear un módulo, se usa un editor de textos básico (block de notas, vi,
notepad++, etc.), se escribe el código Python y se guarda con extensión .py (en
windows, si se utiliza IDLE, se puede utilizar Nuevo del menú Archivo).
Por ejemplo, el siguiente código está en un archivo llamado Modulo1.py:

38
""" Módulo 1 − c a l c u l o de á r e a s """ # d o c s t r i n g d e l módulo
pi = 3.14159
def areaCirculo ( r ) :
""" a r e a C i r c u l o ( r ) − o b t i e n e e l á r e a de un c í r c u l o
de r a d i o r """
r e t u r n ( p i ∗ r ∗∗ 2 )

d e f areaCuadrado ( l ) :
""" areaCuadrado ( l ) − o b t i e n e e l á r e a de un
cuadrado de l a d o l """
r e t u r n ( l ∗∗ 2 )

Se pueden utilizar las constantes y funciones definidas importando el módulo:

>>> import Modulo1 # no s e pone l a e x t e n s i ó n . py


>>> Modulo1 . p i # e s n e c e s a r i o h a c e r r e f e r e n c i a a l modulo
>>> Modulo1 . a r e a C i r c u l o ( 2 )
>>> Modulo1 . areaCuadrado ( 4 )

También se puede consultar la documentación del módulo y las funciones:

>>> Modulo1 . __doc__


>>> Modulo1 . a r e a C i r c u l o . __doc__
>>> Modulo1 . areaCuadrado . __doc__

Además es posible importar objetos específicos, la sintaxis es:

>>> from NombreModulo import nombreObjeto1 , nombreObjeto2


, nombreObjeto3 , . . .

De esta forma se puede hacer referencia a un objeto sin necesidad de an-


teponer el nombre del módulo, por ejemplo:

>>> from Modulo1 import p i


>>> p i

Por otro lado, es deseable utilizar el modo interactivo para probar de forma
incremental un código que se está desarrollando; sin embargo, reescribir import
NombreModulo, no carga nuevamente algún archivo que se haya modificado.
Para poder hacer esto, es necesario utilizar la función reload :

>>> r e l o a d ( Modulo1 )

39
En Python 3, el método reload se encuentra dentro del módulo imp (mecan-
ismos para importar módulos). Por ejemplo:

>>> import imp # En Python3


>>> imp . r e l o a d ( Modulo1 )

Cuando un módulo es importado por primera vez, o recargado, se revisa


todo el código; si se encuentra algún error, se levanta una excepción. Si, por el
contrario, es correcto, se crea un archivo .pyc (por ejemplo Modulo1.pyc).
Por supuesto es posible importar módulos en otros módulos, para esto se
deben escribir las sentencias import al principio del archivo.
Finalmente, existe una forma más general para importar nombres de objetos:

>>> from NombreModulo import ∗

El * reemplaza los nombres declarados en el módulo; esto importa todos los


nombres públicos del módulo (aquellos que no inician con guión bajo) y los hace
disponibles sin necesidad de escribir el nombre del módulo antes del nombre del
objeto.
Se debe tener cuidado al utilizar esta forma de importar objetos: si dos
módulos definen un mismo nombre de objeto y se importan ambos módulos
usando esta forma de importación, se presenta un choque de nombres, y el
del segundo módulo reemplazará al del primero; además esto hará más difícil
determinar donde se originan los nombres que se están utilizando en el código.

5.2 Ruta de búsqueda de módulos.


Python posee una varible especial que indica donde buscará módulos, está vari-
able se llama path y se accede a su valor a través del módulo sys:

>>> import s y s
>>> s y s . path

Lo anterior devuelve una lista de directorios en los que Python busca (en
orden) cuando se ejecuta una sentencia import. El primer módulo que satisface
la petición de import es utilizada; si no existe módulo que satisfaga en la ruta
de búqueda, se levanta una Excepción ImportError.

5.2.1 Dónde colocar los módulos propios.


En el ejemplo mostrado, el archivo Modulo1.py estaba accesible en el modo
interactivo por que el primer elemento de sys.path es “”, que le indica a Python
que busque módulos en el directorio actual y Python fue iniciado en el directorio
donde se encuantra el archivo. Sin embargo, usualmente no es posible que estas
condiciones sean satisfechas siempre.
Para garantizar que el códigos de un módulo pueda ser usado, es necesario:

40
3 Colocar los modulos en alguno de los directorios en los que Python busca
normalmente.
3 Colocar todos los módulos en el mismo directorio del ejecutable de Python.
3 Crear un directorio (o varios) en los que se almacenen los módulos pro-
pios, y modificar la variable sys.path de tal forma que incluya el nuevo
directorio.
De estas tres opciones, las primeras dos parecen ser las más sencillas; sin em-
bargo, su uso debe evitarse al máximo.
La mejor elección es la tercera, es posible modificar sys.path de varias formas:
se puede asignar vía código, y también puede modificarse la variable de ambiente
PYTHONPATH, lo cual es relativamente sencillo.

5.3 Nombres privados en módulos.


Anteriormente se mencionó que la sentencia from NombreModulo import * im-
porta casi todos los nombre de un módulo, la excepción es que aquellos nombres
que inicien con un guión bajo no pueden ser importados de esta manera.
Para ver esto, se tiene el siguiente código en el archivo PruebaOcultos.py:

""" PruebaOcultos : Módulo para p r o b a r nombres o c u l t o s """


a = 1
_b = 2
def f (x) :
return x ∗ 2
d e f _g( x ) :
r e t u r n x ∗∗ 2

Ahora en el modo interactivo:

>>> from PruebaOcultos import ∗


>>> a
>>> f ( 2 )

Hasta aquí todo funciona bien, pero si intentamos usar:

>>> _b
>>> _g ( 2 )

Python indica un error; para solucionarlo, tenemos dos opciones, la primera


es:

41
>>> import PruebaOcultos
>>> PruebaOcultos . _b
>>> PruebaOcultos . _g ( 2 )

La segunda es importar cada nombre de forma particular:

>>> from PruebaOcultos import _b, _g


>>> _b
>>> _g ( 2 )

5.4 Usando el módulo os.


Trabajar con archivos incluye dos cosas básicas, lectura y escritura de archivos
(revisadas previamente) y manipular el sistema de archivos (nombrar, crear,
mover, etc.), lo cual es diferente dependiendo del sistema operativo utilizado.
Resulta bastante sencillo crear códigos que son dependientes de determinado
sistema operativo si no se conocen algunas caractarísticas que Python provee
para evitarlo, esta sección tiene por objetivo mostrar estas características.

5.4.1 Rutas (paths).


Todos los sitemas operativos hacen referencia a archivos y directorios con cade-
nas que dan nombre a un archivo ó directorio, cadenas usadas de esta manera
usualmente se conocen como rutas (paths). Python provee funciones que fa-
cilitan las posibles complicaciones al trabajar con rutas en diferentes sistemas
operativos.
La semántica de las rutas en diferentes sistemas operativos es muy similar
gracias a que casi en todos los sistemas operativos el sistema de archivos se
modela como una estructura de árbol, con una raíz y ramas que representan las
carpetas.
Sin embargo cada sistema operativo tiene diferentes convenciones en la sin-
taxis de sus rutas. Por ejemplo, el caracter utilizado para separar diectorios
en sistemas tipo UNIX es ’/’, mientras que en windows es ’\’. Además, en
un sistema tipo UNIX, la raíz se identifica solamente con ’/’, mientras que en
windows cada unidad tiene una raíz separada etiquetada ’a:\’, ’c:\’, etc.

5.4.2 El directorio de trabajo actual.


Para obtener el directorio de trabajo actual (current working directory) en
Python, se utiliza la función getcwd del módulo os:

>>> import o s
>>> o s . getcwd ( )

42
Lo anterior devuelve la ruta absoluta del directorio de trabajo actual, que es
dependiente del sistema operativo.
Ahora, si se escribe:

>>> o s . l i s t d i r ( o s . c u r d i r )

Se obtiene una lista con los nombres de los archivos y directorios del di-
rectorio actual; la constante os.curdir, es el indicador del directorio actual en
el sistema operativo, tanto en sistemas tipo UNIX como en windows, se repre-
senta con un ’.’; sin embargo, es recomendable utilizar os.curdir, en lugar de el
caracter ’.’.

5.4.3 Manipulación de rutas.


Ahora que se conoce lo básico del sistema de archivos, directorios y rutas, es
posible revisar las facilidades que ofrece Python para manipular rutas.
Primero se verá el uso de la función os.path.join; nótese que importar el
módulo os es suficiente para acceder al submódulo os.path:

>>> import o s
>>> p r i n t ( o s . path . j o i n ( ’ bin ’ , ’ u t i l s ’ , ’ t o o l s ’ ) )

Al ejecutar la línea anterior en un ambiente windows, se obtiene la siguiente


cadena: bin\utils\disktools; si se ejecuta en un sistema operativo tipo UNIX,
la misma instrucción genera la cadena bin/utils/disktools; es decir, la función
os.path.join, “sabe” que separador debe utilizar.

5.4.4 Constantes y funciones útiles.


Pueden usarse constantes relacionadas con rutas, así como funciones que harán
el código Pyhton más independiente del sistema operativo; entre ellos, se en-
cuentran las constantes os.curdir y os.pardir, que definen los símbolos para el
directorio actual y el directorio padre, ’.’ y ’..’ repectivamente. Por ejemplo:

>>> import o s
>>> o s . l i s t d i r ( o s . c u r d i r )
>>> o s . l i s t d i r ( o s . p a r d i r )

La constante os.name, devuelve el nombre de módulo Python importado


para manipular detalles específicos del sistema operativo:

>>> o s . name

43
Si la línea anterior se ejecuta en un sistema operativo tipo UNIX, se ob-
tiene ’posix ’ como respuesta; si se ejecuta en windows se obtendrá ’nt’. Con
esto, pueden realizarse operaciones especiales, dependiendo de la respuesta de
os.name, por ejemplo:

>>> import o s
>>> i f o s . name i s ’ p o s i x ’ :
>>> r o o t _ d i r = "/"
>>> e l i f o s . name i s ’ nt ’ :
>>> r o o t _ d i r = "C: \ \ "
>>> else :
>>> p r i n t ( " s i s t e m a o p e r a t i v o no c o n o c i d o " )

Nota: también es posible utilizar sys.platform, que devuelve información


exacta del sistema operativo; en windows XP, devuelve ’win32 ’; en Linux, puede
ser ’linux2 ’ y en Mac OSX, ’darwin’.

5.4.5 Resumen de constantes y funciones del módulo.


Manipular el sistema de archivos de forma independiente del sistema operativo
no es simple; afortunadamente, Python proporciona varias funciones y cons-
tantes que facilitan esta tarea. La siguiente tabla muestra las principales:

Nombre Funcionalidad
os.getcwd () Devuelve el directorio actual
os.name Identificación genérica de la plataforma
sys.platform Identificación específica de la plataforma
os.listdir (ruta) Devuelve los archivos de ruta
os.chdir (ruta) Cambia de directorio a ruta
os.path.join(elementos) Crea una ruta con los elementos
os.path.split(ruta) Divide ruta en encabezado y cola (el último elemento)
os.path.splitext(ruta) Divide ruta en base y una extensión
os.path.exists(ruta) Prueba si existe una ruta
os.path.isdir (ruta) Prueba si ruta es un directorio
os.path.islist(ruta) Prueba si ruta es un archivo
os.path.isabs(ruta) Prueba si ruta es una ruta absoluta
os.path.getsize(ruta) Obtiene el tamaño de un archivo
os.path.getmtime(ruta) Obtiene la hora de modificación
os.path.getatime(ruta) Obtiene la hora de último acceso
os.rename(nombre, nomNvo) Cambia el nombre de un archivo
os.remove(ruta) Elimina un archivo
os.mkdir (ruta) Crea un directorio
os.rmdir (ruta) Elimina un directorio

44
Se puede consultar la ayuda del módulo desde el modo interactivo (con help).

5.5 Librerías y módulos de terceros.


Al inicio de la sección se indica que la librería estándar de Python se encuentra
dividida en módulos para que sea más manejable; una vez instalado, toda esta
funcionalidad está disponible, lo único que debe hacerse es importar los módulos
ó nombres explícitamente para poder usarlos. La librería estándar incluye mu-
chos módulos, éstos pueden consultarse en la referencia de librerías de Python
(Python Library Reference) en http://docs.python.org/library/.
Además, en el sitio web de Python (www.python.org), existen módulos desar-
rollados por terceros y ligas a ellos. Lo único que hay que hacer para utilizarlos,
es descargarlos, colocarlos es un directorio y añadir este directorio a la ruta de
búsqueda de módulos de Python.

6 Programas.
Hasta el momento, se ha utilizado el intérprete de Python en modo interactivo
solamente, pero siempre es deseable poder ejecutar programas o scripts. En esta
sección se presentan varias formas de hacer esto, la mayoría basadas en línea de
comandos.

6.1 Primer programa básico.


Cualquier grupo de sentencias Python en un archivo puede usarse como pro-
grama o script. Sin embargo es mejor (y más útil) utilizar estructura estándar
adicional. El siguiente es un ejemplo sencillo, almacenado en un archivo llamado
Programa1.py:

d e f main ( ) : # d e c l a r a n d o main
p r i n t ( " Hola mundo , p r i m e r programa " )
main ( ) # llamada de main

En este script, main es la función de control ; primero es definida y después


llamada. Aunque no existe gran diferencia en programas pequeños, utilizar esta
estructura puede proporcionar mayor control en aplicaciones grandes, por tanto
es buena idea tener una función main definida.

6.2 Ejecutando desde línea de comandos.


Para ejecutar un programa Python, es necesario abrir una terminal (LINUX ó
Mac OSX), ó un intérprete de comandos (windows), cambiarse al directorio en
el cual se encuentra el archivo .py que se desea ejecutar (con ayuda del comando
cd ); Una vez ubicado en el directorio, se ejecuta:

45
$ python NombrePrograma . py

Nota: Si se desea utilizar alguna versión particular del intérprete, deberá


especificarse, por ejemplo, python3. $ indica el prompt del sistema operativo.
Para ejecutar el ejemplo anterior:

$ python Programa1 . py

Lo anterior ejecuta el código escrito en Programa1.py y regresa al prompt


del sistema.

6.2.1 Argumentos desde línea de comandos.


Python provee un mecanismo sencillo para pasar argumentos a un programa
Python, el siguiente ejemplo almacenado en el archivo Programa2.py lo muestra:

import s y s
d e f main ( ) :
p r i n t ( " Segundo programa " )
p r i n t ( s y s . argv )
main ( )

Ahora se puede ejecutar como:

$ python Programa2 . py Hola mundo 123

Y se obtiene la siguiente salida:

Segundo programa
[ ’ Programa2 . py ’ , ’ hola ’ , ’ mundo ’ , ’123 ’]

Los argumentos pasados por línea de comandos se almacenan en sys.argv


como una lista de cadenas.

6.3 Haciendo ejecutable un programa Python en UNIX.


Si el sistema operativo utilizado es tipo UNIX (Linux, Mac OSX), es muy sencillo
hacer ejecutable un programa, sólo es necesario cambiar el modo apropiado al
archivo con el comando chmod del sistema operativo y agregar la siguiente línea
al inicio del archivo de programa:

#! / u s r / b i n / env python

Es posible especificar la versión que se desea utilizar para ejecutar el pro-


grama, por ejemplo, python3.
Con esto se puede ejecutar directamente el archivo con la siguiente llamada:

$ . / Programa1 . py

46
6.4 Ejecutando un programa Python en Windows.
Existen varias formas de ejecutar un programa Python en windows, desafortu-
nadamente ninguna es tan flexible ni poderosa como en sistemas tipo UNIX.

6.4.1 Ejecutando un programa con un atajo.


La forma más simple de ejecutar un script Pyhton en windows, es utilizar la
técnica estándar de asociar extensiones. Al instalar Pyhton, deberían asociarse
de forma automática, esto puede verificarse revisando si los archivos .py tienen
un ícono de Python. Al hacer doble clic en alguno, Python es llamado de forma
automática con el nombre del archivo pasado como argumento. Sin embargo,
esta técnica no permite pasar otros argumentos desde línea de comandos y
la ventana de ejecución se cerrará tan pronto como termine la ejecución del
programa.
Si se desea detener el cierre de la ventana, se puede agregar la siguiente línea
al final de la función de control:

i n p u t ( " P r e s i o n a <e n t e r > para t e r m i n a r " )

6.4.2 Ejecutando un programa con el cuadro de diálogo ejecutar.


Una forma más flexible para ejecutar un programa Python, es utilizar el cuadro
de diálogo ejecutar, y escribir:

python " r u t a _ a l _ a r c h i v o / Programa . py" a r g 1 a r g 2 . . .

Sin embargo presenta el mismo problema de cierre al fin de la ejecución, se


puede utilizar la técnica de la sección anterior para detener este cierre.

6.4.3 Otras opciones.


Existen otras opciones disponibles:

3 Crear un archivo de proceso por lotes (.bat).


3 Instalar Cygwin (www.cygwin.com), que provee capacidades tipo UNIX a
windows.
3 Editar las variables de entorno y agregar la extensión .py a las extensiones
ejecutables:
PATHEXT=.COM;.EXE;.BAT;.CMD;.VBS;.JS;.PY

47
6.5 Programas y módulos.
Para scripts pequeños de unas cuantas líneas de código, una sola función es
suficiente, pero si el programa crece, es recomendable separar la función de
control del resto del código.

#! / u s r / b i n / env python3
""" Módulo 1 − c a l c u l o de á r e a s """
pi = 3.14159
def areaCirculo ( r ) :
""" a r e a C i r c u l o ( r ) − o b t i e n e e l á r e a de un c í r c u l o
de r a d i o r """
r e t u r n ( p i ∗ r ∗∗ 2 )

d e f main ( ) :
x = f l o a t ( input ( ’ radio ? : ’) )
print ( areaCirculo (x) )
main ( )

Aquí, la función de control llama a la función areaCirculo con el argumento


apropiado e imprime el resultado.
Resulta útil poder combinar programas con módulos para hacer que las
funciones creadas estén disponibles a otros módulos ó scripts.
Combinar un programa y un módulo es una tarea simple, sólo se necesita
colocar el siguiente condicional en la función de control:

i f __name__ i s ’__main__ ’ :
main ( )
else :
# c ó d i g o e s p e c í f i c o de i n i c i a l i z a c i ó n d e l módulo
( si existe )

Si el programa es llamado como script, se ejecutará con el nombre __main__


y se ejecutará la función de control main(); en cambio, si se importa en una
sesión interactiva o en otro módulo, su nombre sera el nombre del archivo. Por
ejemplo:

#! / u s r / b i n / env python3
""" Módulo 1 − c a l c u l o de á r e a s """
pi = 3.14159
def areaCirculo ( r ) :
""" a r e a C i r c u l o ( r ) − o b t i e n e e l á r e a de un c í r c u l o
de r a d i o r """
r e t u r n ( p i ∗ r ∗∗ 2 )

48
d e f main ( ) :
x = f l o a t ( input ( ’ radio ? : ’) )
print ( areaCirculo (x) )
i f __name__ i s ’__main__ ’ :
main ( )
else :
p r i n t ( " importando Módulo 1 " )

6.6 Distribuyendo aplicaciones de Python.


Una aplicación Python puede distribuirse con el código fuente (archivos .py); o
solamente los archivos compilados (archivos .pyc o .pyo), un archivo compilado
funcionará bajo cualquier plataforma si se escribió de forma portable (usando
correctamente el módulo os).

6.6.1 Módulo distutils.


La forma estándar de empacar y distribuir módulos de Python y aplicaciones
es hacer uso del módulo distutils. Los detalles están fuera del alcance de este
curso, sin embargo se puede consultar la documentación para hacer uso de este
módulo (http://docs.python.org/3/distutils/).
El núcleo de un paquete creado con distutils, es un archivo con nombre
setup.py, que básicamente es un programa Python que controla la instalación.
El módulo tiene gran diversidad de opciones y permite crear distribuciones para
windows y sistemas operativos tipo UNIX.

6.6.2 Usando py2exe, py2app y freeze.


Además, existen aplicaciones que crean distribuciones stand-alone para sistemas
operativos específicos:
3 py2exe, para windows (http://www.py2exe.org).
3 py2app, para Mac OSX (http://wiki.python.org/moin/MacPython/py2app).

El término stand-alone, indica que son archivos ejecutables que pueden funcionar
en máquinas que no tienen Python instalado; no son la forma ideal de distribuir
programas, debido a que tienden a ser muy grandes y poco flexibles, pero en
algunas ocasiones son la única forma de hacerlo.
Otra opción es utilizar la herramienta freeze, incluida en la distribución
de Python en Tools/freeze (es necesario descargar el código fuente); funciona
convirtiendo código Python compilado a código C y después compila este código,
obviamente freeze requiere un compilador de C.

49
7 Generación de documentación con pydoc
El módulo pydoc genera automáticamente documentación de códigos de Python
que contienen cadenas de documentación (docstring). La documentación puede
presentarse directamente en la consola como páginas de texto, guardarlas como
archivos html o directamente mostradas en un servidor web.
La función help() invoca la ayuda en línea dentro del intérprete interactivo,
internamente utiliza pydoc para generar la documentación como texto en la
consola. La misma documentación puede consultarse desde fuera del intérprete
utilizando el comando pydoc desde la línea de comandos del sistema operativo.
Por ejemplo, si ejecutamos:

% pydoc s y s

desde el prompt, desplegará la documentación correspondiente al módulo sys


de forma similar al comando man de Unix.

Figure 7.1: Vista de comando pydoc en ejecución.

La sintaxis general del comando es:

% pydoc nombre1 [ nombre2 . . . ]

Y muestra la documentación del tema, módulo, clase, paquete, función o


palabra clave indicada de forma similar a la función help. Si el nombre es
keywords, topics o modules se listarán las distintas palabras claves, temas y
módulos respectivamente.

50
Para obtener la documentación de un módulo propio que se encuentra en el
directorio actual, se utiliza la sintaxis:

% pydoc . / modulo . py

Por ejemplo:

% pydoc . / Modulo1 . py

Figure 7.2: Vista del comando pydoc con un módulo propio.

Además, el comando puede recibir algunas banderas. Con la bandera -w,


guardará la documentación en uno o varios archivos html en lugar de mostrarla
por pantalla. La bandera -k sirve para buscar una determinada palabra en la
sinopsis de los módulos disponibles; la sinopsis es la primera línea de la cadena
de documentación.
Con -p se inicia el servidor http en el puerto indicado: pydoc -p puerto. Una
vez hecho esto se puede acceder a la documentación de los módulos disponibles
abriendo la url http://localhost:puerto en algún navegador. Finalmente, la ban-
dera -b lanza una interfaz gráfica para buscar documentación que utiliza el
servidor http para mostrar los resultados.

51
8 Módulo doctest
Este módulo busca texto igual a una sesión interactiva dentro de cadenas de doc-
umentación (docstring) y las ejecuta para verificar que funcionan exactamente
como se muestran. Es muy útil de varias formas:
3 Verificar que los códigos funcionan correctamente al tener pruebas de los
mismos (TDD).
3 Verificar que las docstring del módulo están actualizadas.

3 “Documentación ejecutable”.
Ejemplo:

""" Módulo 1 − c a l c u l o de á r e a s # d o c s t r i n g d e l módulo


>>> p i
3.14159
"""
pi = 3.14159
def areaCirculo ( r ) :
""" a r e a C i r c u l o ( r ) − o b t i e n e e l á r e a de un c í r c u l o de
radio r
>>> a r e a C i r c u l o ( 1 )
3.14159
>>> a r e a C i r c u l o ( 5 )
78.53975
"""
r e t u r n ( p i ∗ r ∗∗ 2 )
d e f areaCuadrado ( l ) :
""" areaCuadrado ( l ) − o b t i e n e e l á r e a de un cuadrado
de l a d o l
>>> areaCuadrado ( 1 )
1
>>> areaCuadrado ( 5 )
25
"""
r e t u r n ( l ∗∗ 2 )
i f __name__ i s "__main__" :
import d o c t e s t #Importa e l módulo
d o c t e s t . testmod ( ) #E j e c u t a r l a s p r u e b a s

Se prueba como:

% python Modulo1 . py

52
Si no hay errores, no se produce salida, pero se puede solicitar que se ejecute
en modo verboso:

% python Modulo1 . py −v

9 Clases y programación orientada a objetos.


Está sección presenta una breve introducción a las características de Progra-
mación Orientada a Objetos (POO) que se incluyen en Python.

9.1 Declaración de clases.


Una clase de Python es un tipo de dato efectivo; todos los tipos de datos nativos
en Python son clases, y Python ofrece herramientas para manipular todos los
aspectos del comportamiento de clases.
Una clase se declara utilizando la palabra reservada class:

c l a s s MiClase ( o b j e c t ) :
# t o d a s l a s c l a s e s heredan de o b j e c t
cuerpo

El cuerpo es una serie de sentencias Python, usualmente asignaciones de


variables y definiciones de funciones, pero no son necesarias, el cuerpo puede ser
sola una sentencia pass.
Por convención, los identificadores de clases llevan mayúscula la primer letra
y cada cambio de palabra. Una vez definida una clase, se puede crear un objeto
(instancia) del tipo de esa clase, llamando al nombre de la clase como función:

o b j e t o = MiClase ( )

Ejemplo:

""" Ejemplo de POO con Python """


c l a s s MiClase ( o b j e c t ) :
""" MiClase : Ejemplo 1"""
pass

Prueba en la interfaz interactiva de Python:

>>> import e j 1
>>> e j 1 . __doc__
>>> o b j = e j 1 . MiClase ( )
>>> o b j . __doc__

53
Por otro lado, la forma en la que se modelan sistemas basados en la ideología
OO, utiliza diagramas del Lenguaje Unificado de Modelado, UML por sus siglas
en inglés (Unified Modeling Language). El primer diagrama definido en este
lenguaje es el diagrama de clases, su esquema general se muestra en la siguiente
figura.

NombreDeClase
atributo1
atributo2
metodo1(par1,...)
metodo2(par1,...)

Figure 9.1: Esquema general del Diagrama de Clases.

Esta figura muestra la aplicación de algunas convenciones para diagramas


de clases:
3 El nombre de la clase inicia con mayúscula y las demás letras en minús-
culas, salvo que haya cambio de palabra, en cuyo caso la primer letra será
mayúscula.
3 Los nombres de atributos y métodos son en minúsculas, salvo que haya
cambio de palabra, en cuyo caso la primer letra será mayúscula.

9.2 Atributos.
En POO, se tiene el concepto de atributos (variables, fields), Python provee
capacidad de tener atributos de instancia y atributos de clase.

9.2.1 Atributos de instancia.


Las variables de instancia son la característica más básica de la POO, un atributo
de instancia es aquella que pertenece a cada objeto creado, y cuyo valor puede
ser diferente a ese atributo en otras instancias.
Se pueden inicializar incluyendo la función inicializadora __init__ en el
cuerpo de la clase, esta función se ejecuta siempre que se crea una nueva instancia
de la clase:

c l a s s MiClase ( o b j e c t ) : # h e r e d a de o b j e c t
d e f __init__ ( s e l f , arg1 , . . . , argN ) :
s e l f . atr1 = arg1
...
s e l f . atrN = argN

54
Por convención, self siempre es el nombre del primer argumento de la función
__init__; self siempre hace referencia al objeto que llama al método, en este
caso, al objeto que se acaba de crear.
Además, en Python se pueden crear atributos de instancia asignando un
valor a atributo nuevo:

ob jet o . nuevoAtributo = v a l o r

Siempre que se utiliza un atributo de instancia (tanto para asignación como


para recuperar valor), requieren mención explícita el objeto que lo contiene:
objeto.atributo.
Por ejemplo, el siguiente código se encuentra en un módulo llamado Cir-
culo.py:

c l a s s C i r c u l o ( o b j e c t ) : # h e r e d a de o b j e c t
d e f __init__ ( s e l f ) :
s e l f . radio = 1

En una sesión interactiva, se puede probar con:

>>> import C i r c u l o 1
>>> circ1 = Circulo1 . Circulo ()
>>> print ( circ1 . radio )
>>> circ2 = Circulo1 . Circulo ()
>>> print ( circ2 . radio )
>>> circ1 . radio = 5
>>> c i r c 1 . atNvo = ’ hola ’ # c r e a n d o un nuevo a t r i b u t o
>>> print ( circ1 . radio )
>>> p r i n t ( c i r c 1 . atNvo )

9.2.2 Atributos de clase.


Una variable de clase está asociada a la clase, no a un objeto particular, y todos
los objetos de esa clase pueden acceder al valor
Para crear un atributo de clase, se asigna un valor en el cuerpo de la clase, no
en la función __init__, una vez creada, puede ser vista por todas las instancias
de la clase, por ejemplo:

c l a s s C i r c u l o ( o b j e c t ) : # h e r e d a de o b j e c t
pi = 3.14159
d e f __init__ ( s e l f ) :
s e l f . radio = 1

55
El diagrama de clases correspondiente es el de la siguiente figura, es impor-
tante notar que no se hace diferencia entre el atributo de instancia y el de clase
(no es parte del lenguaje).

Circulo
pi
radio
__init__(self)

Figure 9.2: Diagrama de clases del ejemplo.

En el modo interactivo, se puede probar:

>>> import C i r c u l o 1
>>> Circulo1 . Circulo . pi
>>> Circulo1 . Circulo . pi = 5
>>> Circulo1 . Circulo . pi

Así es como se espera que funcione un atributo de clase, no hay necesidad


de crear objetos del tipo de la clase para acceder al valor.
Sin embargo también es deseable poder obtener este valor a través de instan-
cias creadas a partir de determinada clase, esto puede realizarse utilizando en
atributo especial __class__, este atributo devuelve la clase a la cual pertenece
determinada instancia:

>>> Circulo1 . Circulo


>>> c i r c 1 . __class__
>>> c i r c 1 . __class__ . p i
>>> c i r c 2 . __class__ . p i
>>> c i r c 1 . __class__ . p i = 5
>>> c i r c 2 . __class__ . p i

Una rareza en los atributos.


En Python sucede algo raro (en el sentido de que no sucede en otros lenguajes)
si no se tiene cuidado al utilizar atributos de instancia y de clase; si se solicita un
nombre de variable a un objeto, primero busca en los atributos inicializados en
el método __init__, si no lo encuentra sube un nivel y busca en los atributos
de clase, si no existe en este nivel, envía un error:

>>> c i r c 1 . p i

56
Ahora, si por error se asigna un valor a este atributo, lo que hace es crear
un nuevo atributo de instancia, no modifica el atributo de clase:

>>> c i r c 1 . p i = 5 # c r e a un a t r i b u t o de i n s t a n c i a
>>> c i r c 1 . p i # imprime 5
>>> c i r c 1 . __class__ . p i # imprime 3 . 1 4 1 5

9.3 Métodos.
Un método es una función asociada a una clase particular; por ejemplo, el
método __init__, este método es llamado cuando se crea un nuevo objeto, en
el siguiente ejemplo se declara otro método que devuelve el área del círculo:

c l a s s C i r c u l o ( o b j e c t ) : # h e r e d a de o b j e c t
pi = 3.14159
d e f __init__ ( s e l f ) :
s e l f . radio = 1
def area ( s e l f ) :
r e t u r n s e l f . __class__ . p i ∗ s e l f . r a d i o ∗∗
2

Al igual que el método __init__, los métodos definidos llevan self como
primer argumento, para probar este método, se hace lo siguiente:

>>> import C i r c u l o 1
>>> circ1 = Circulo1 . Circulo ()
>>> circ1 . radio = 5
>>> c i r c 1 . area ()

Es deseable poder inicializar el valor de argumentos en la creación de un


objeto, esto se puede hacer agregando argumentos al método __init__, el
siguiente ejemplo recibe como argumento el radio del círculo y lo asigna en la
creación, también es posible utilizar todas las técnicas de paso de argumentos
vistas anteriormente:

c l a s s C i r c u l o ( o b j e c t ) : # h e r e d a de o b j e c t
pi = 3.14159
d e f __init__ ( s e l f , r a d i o =1) :
s e l f . radio = radio
def area ( s e l f ) :
r e t u r n s e l f . __class__ . p i ∗ s e l f . r a d i o ∗∗
2

Ahora en la creación del objeto se puede indicar el radio del círculo:

57
>>> import C i r c u l o 1
>>> c i r c 1 = C i r c u l o 1 . C i r c u l o ( 5 )

Las clases en Python, tienen métodos que corresponden con tales métodos
en lenguajes como java; adicionalmente, Python tiene métodos de clase que son
más avanzados.

9.3.1 Métodos estáticos.


Al igual que en java, se pueden invocar métodos estáticos sin necesidad de crear
instancias de la clase, aunque pueden llamarse utilizando un objeto. Para crear
un método estático, es necesario utilizar la sentencia @staticmethod antes del
método:

""" Módulo C i r c u l o : c o n t i e n e l a c l a s e C i r c u l o
y s u s a t r i b u t o s y métodos """
c l a s s C i r c u l o ( o b j e c t ) : # h e r e d a de o b j e c t
t o d o s L o s C i r c u l o s = [ ] # l i s t a que almacenará
todos l o s objetos
pi = 3.14159
d e f __init__ ( s e l f , r a d i o =1) :
""" I n i c i a l i z a un C i r c u l o con e l r a d i o
dado """
s e l f . radio = radio
s e l f . __class__ . t o d o s L o s C i r c u l o s . append (
s e l f ) # agrega e l objeto actual a la
lista
def area ( s e l f ) :
""" Obtiene e l á r e a d e l C i r c u l o """
r e t u r n s e l f . __class__ . p i ∗ s e l f . r a d i o ∗∗
2
@staticmethod
def areaTotal () :
""" Obtiene e l á r e a de t o d o s l o s C i r c u l o s
"""
total = 0
for c in Circulo . todosLosCirculos :
t o t a l = t o t a l + c . area ()
return total

Se puede probar interactivamente:

>>> import C i r c u l o 2
>>> c1=C i r c u l o 2 . C i r c u l o ( )
>>> c2=C i r c u l o 2 . C i r c u l o ( 3 )

58
>>> C i r c u l o 2 . C i r c u l o . a r e a T o t a l ( )
>>> c3=C i r c u l o 2 . C i r c u l o ( 5 )
>>> c2 . a r e a T o t a l ( )

También se incluyen docstrings para el módulo y los métodos y pueden verse


con __doc__.

9.3.2 Métodos de clase.


Los métodos de clase son similares a los métodos estáticos, ambos pueden in-
vocarse sin necesidad de crear objetos; pero los métodos de clase reciben im-
plícitamente la clase a la que pertenecen como primer parámetro, con esto se
puede codificar de forma más sencilla. Para crear un método de clase, se utiliza
la sentencia @classmethod antes del método::

""" Módulo C i r c u l o : c o n t i e n e l a c l a s e C i r c u l o
y sus atributos y
métodos """
c l a s s C i r c u l o ( o b j e c t ) : # h e r e d a de o b j e c t
t o d o s L o s C i r c u l o s = [ ] # l i s t a que almacenará
todos l o s objetos
pi = 3.14159
d e f __init__ ( s e l f , r a d i o =1) :
""" I n i c i a l i z a un C i r c u l o con e l r a d i o
dado """
s e l f . radio = radio
s e l f . __class__ . t o d o s L o s C i r c u l o s . append (
s e l f ) # agrega e l objeto actual a la
lista
def area ( s e l f ) :
""" Obtiene e l á r e a d e l C i r c u l o """
r e t u r n s e l f . __class__ . p i ∗ s e l f . r a d i o ∗∗
2
@classmethod
def areaTotal ( c l s ) :
""" Obtiene e l á r e a de t o d o s l o s C i r c u l o s
"""
total = 0
for c in c l s . todosLosCirculos :
t o t a l = t o t a l + c . area ()
return total

El parámetro de métodos de clase, tradicionalmente es cls, con esto, se puede


utilizar cls en lugar de self.__class__, o dejar “código duro” con referencia
explícita a Circulo.

59
El diagrama de clases completo del ejemplo se muestra a continuación, tam-
poco se hace distinción entre métdos estáticos y de clase.

Circulo
todosLosCirculos
pi
radio
__init__(self)
area(self)
areaTotal(cls)

Figure 9.3: Diagrama de clases del ejemplo.

9.4 Herencia.
La herencia en Python es más flexible y sencilla que en lenguajes como C++ ó
java, dado que la naturaleza dinámica de Python no tiene tantas restricciones.
Para ver su uso en Python, retomaremos algunas líneas de Circulo, proba-
blemente sería deseable tener una clase adicional para cuadrados:

c l a s s Cuadro ( o b j e c t ) : # h e r e d a de o b j e c t
d e f __init__ ( s e l f , l a d o =1) :
s e l f . lado = lado
c l a s s C i r c u l o ( o b j e c t ) : # h e r e d a de o b j e c t
d e f __init__ ( s e l f , r a d i o =1) :
s e l f . radio = radio

Ahora, si estás clases son la base de un programa que dibujará formas, se


debe definir la posición en la cual se comenzará cada instancia; es posible hacerlo
definiendo coordenas x, y en cada instancia:

c l a s s Cuadro ( o b j e c t ) : # h e r e d a de o b j e c t
d e f __init__ ( s e l f , l a d o =1, x=0, y=0) :
s e l f . lado = lado
self .x = x
self .y = y
c l a s s C i r c u l o ( o b j e c t ) : # h e r e d a de o b j e c t
d e f __init__ ( s e l f , r a d i o =1, x=0, y=0) :
s e l f . radio = radio
self .x = x
self .y = y

Lo anterior funciona, pero no es buena idea hacerlo; si se desean agregar


más formas al programa, al final se tendrá mucho código repetido (cada forma
podría requerir una posición).

60
Usando conceptos de POO, en lugar de definir las coordenadas x, y en la
clase de cada forma, es mejor abstraerlas en una clase genérica Forma, y que
cada forma herede de esa clase genérica; en Python, lo anterior queda de la
siguiente manera:

c l a s s Forma ( o b j e c t ) : # h e r e d a de o b j e c t
d e f __init__ ( s e l f , x , y ) :
self .x = x
self .y = y
c l a s s Cuadro ( Forma ) : # i n d i c a que Cuadro h e r e d a de Forma
d e f __init__ ( s e l f , l a d o =1, x=0, y=0) :
s u p e r ( ) . __init__ ( x , y ) # l l a m a a l método
__init__ de Forma
s e l f . lado = lado
c l a s s C i r c u l o ( Forma ) : # i n d i c a que C i r c u l o h e r e d a de
Forma
d e f __init__ ( s e l f , r a d i o =1, x=0, y=0) :
s u p e r ( ) . __init__ ( x , y )
s e l f . radio = radio

Existen (generalmente) dos requerimientos cuando se utiliza herencia en


Python:

1. Definir la jerarquía en la herencia, esto se realiza escribiendo entre parén-


tesis la clase de la cual se hereda (superclass, superclase, clase padre),
inmediatamente después del nombre de la clase que se está definiendo
(base class, clase base, clase hija).
2. Llamar al método __init__, heredado de la clase padre; Python no hace
esto de forma automática (ya que podría no usarse), pero para poder
realizarlo, provee la función super, que devuelve la clase de la cual se está
heredando.
Los efectos de la herencia son notables cuando se intenta utilizar algún método
que no está definido en la clase base, pero sí en la superclase; para mostrar
esto, se añadirá un método a la clase Forma, llamado mover y modificará las
coordenadas en las que se encuentra el objeto, en la cantidad de unidades dadas
por los argumentos, el código queda de la siguiente manera:

c l a s s Forma ( o b j e c t ) : # h e r e d a de o b j e c t
d e f __init__ ( s e l f , x , y ) :
self .x = x
self .y = y
d e f mover ( s e l f , incX =0, incY =0) :
s e l f . x += incX
s e l f . y += incY

61
c l a s s Cuadro ( Forma ) : # i n d i c a que Cuadro h e r e d a de Forma
d e f __init__ ( s e l f , l a d o =1, x=0, y=0) :
s u p e r ( ) . __init__ ( x , y ) # l l a m a a l método
__init__ de Forma
s e l f . lado = lado
c l a s s C i r c u l o ( Forma ) : # i n d i c a que C i r c u l o h e r e d a de
Forma
d e f __init__ ( s e l f , r a d i o =1, x=0, y=0) :
s u p e r ( ) . __init__ ( x , y )
s e l f . radio = radio

En el diagrama de clases, la herencia se indica con una flecha que va de la


clase hija hacia la superclase, para este ejemplo, se tiene la figura siguiente.

Forma
x
y
__init__(self,x,y)
mover(self,x,y)

Cuadro Circulo
lado radio
__init__(self,lado,x,y) __init__(self,radio,x,y)

Figure 9.4: Diagrama de clases con herencia.

En el modo interactivo, se puede probar:

>>> import Forma


>>> c i 1=Forma . C i r c u l o ( )
>>> c i 1 . mover (1 , −2)
>>> cu1=Forma . Cuadro ( )
>>> cu1 . mover ( −1 ,1)
>>> print ( ci1 . x , ci1 . y)
>>> p r i n t ( cu1 . x , cu1 . y )

9.4.1 Herencia múltiple.


Python no tiene restricciones respecto a la herencia mútiple, como sucede en
java y su uso es más sencillo que la forma en la que se utiliza en C++. Una
clase puede heredar de muchas superclases, de la misma forma en que hereda
de una sola clase padre.
En el caso más sencillo, ninguno de los nombres utilizados (atributos ó méto-
dos) se repite en ninguna de las clases utilizadas, en este caso, la clase hija se

62
comporta como una síntesis de sus propios nombres y de los nombres definidos
por sus ancestros.
La situación se vuelve más compleja cuando las clases comparten algún nom-
bre, por que Python debe decidir que nombre es el que debe utilizar en dicha
situación, y lo hace de la siguiente manera:

3 Si el nombre está definido en la clase hija, utiliza este nombre.


3 Si no está en la clase hija, busca el nombre en las clases padre de izquierda
a derecha y utiliza el primero que encuentra.
El siguiente ejemplo muestra lo anterior:

c l a s s Padre1 ( o b j e c t ) :
d e f __init__ ( s e l f ) :
p r i n t ( " Padre1 i n i c i a l i z a d o " )
s e l f . x = 10
c l a s s Padre2 ( o b j e c t ) :
d e f __init__ ( s e l f ) :
p r i n t ( " Padre2 i n i c i a l i z a d o " )
s e l f . y = 20
c l a s s H i j a ( Padre1 , Padre2 ) :
d e f __init__ ( s e l f ) :
s u p e r ( ) . __init__ ( )
s e l f . x = 25
s e l f . y = 25

La herencia múltiple se ve de la siguiente forma.

Padre1 Padre2
x y
__init__(self) __init__(self)

Hija
x
y
__init__(self)

Figure 9.5: Diagrama de clases con herencia múltiple.

Un problema fundamental de la herencia múltiple es que no existe solución


elegante para el choque de nombres (name clash). Este problema se presenta
cuando una clase C que hereda A y B, ambas con métodos con la misma firma.
Para solucionar este problema Python:

63
3 Favorece la primera clase nombrada en la herencia.
3 Solicita que el programador lo resuelva explícitamente.
Por ejemplo:
c l a s s A:
d e f __init__ ( s e l f , x=’x ’ ) :
s e l f .__x = x
def f ( s e l f ) :
r e t u r n s e l f .__x
c l a s s B:
d e f __init__ ( s e l f , x=’y ’ ) :
s e l f .__x = x
def f ( s e l f ) :
r e t u r n s e l f .__x
c l a s s C(A, B ) :
def h( s e l f ) :
return s e l f . f () # devuelve ’x ’
c l a s s D(B,A ) :
def h( s e l f ) :
return s e l f . f () # devuelve ’y ’
c l a s s E(A, B ) :
d e f __init__ ( s e l f ) :
A. __init__ ( s e l f ) # i n i c i a l i z a c i ó n de c l a s e A : ’ x ’
B . __init__ ( s e l f ) # i n i c i a l i z a c i ó n de c l a s e B : ’ y ’
def g( s e l f ) :
r e t u r n A. f ( s e l f ) # d e v u e l v e ’ x ’
def h( s e l f ) :
return B. f ( s e l f ) # devuelve ’y ’
Prueba en la sesión interactiva:
>>> c=C( )
>>> print ( c . h ())
>>> d=D( )
>>> print (d . h ())
>>> e=E ( )
>>> print ( e . g ())
>>> print ( e . h ())

9.4.2 Verificar que un objeto sea del tipo deseado


La función type devuelve la clase a la cuál pertenece un objeto determinado;
sin embargo, este valor no puede usarse para comprobar si es de algún tipo
específica. Para realizar esto último, se suele utilzar el atributo “__name__”,
por ejemplo:

64
>>> d e f checkType ( v a l o r , t i p o ) :
... r e t u r n type ( v a l o r ) .__name__ == t i p o
...
>>> checkType ( 5 , ’ i n t ’ )
>>> checkType ( 5 , ’ f l o a t ’ )
>>> checkType ( 5 . , ’ f l o a t ’ )

Esta sección es una introducción a la POO en Python con el objetivo de


poder revisar y entender códigos que utilicen este paradigma.
Las clases y objetos son muy útiles en proyectos grandes como una buena
forma de reutilizar código; además son muy útiles cuando se desea desarrollar
un proyecto GUI (Interfaz Gráfica de Usuario):

>>> import t k i n t e r
>>> import s y s
>>> win = t k i n t e r . Tk ( )
>>> boton = t k i n t e r . Button ( win , t e x t ="C e r r a r " , command=
sys . exit )
>>> boton . pack ( )

10 Python Turtle
https://docs.python.org/3/library/turtle.html
https://code.google.com/p/python-turtle-demo/

11 ¿Qué sigue?
Python es muy útil para desarrollar aplicaciones de forma rápida, además de
lo mostrado en este documento se pueden realizar muchas otras cosas como
las nombradas a continuación. Un buen manual para introducción a algunas de
ellas se encuentra en http://diveintopython.org/; además, como se mencionó an-
teriormente en http://docs.python.org/library/ se encuentra la documentación
oficial de la Python Library Reference, en la cual se incluyen ejemplos de su uso.

Interfaces Gráficas de Usuario (GUI).


Python incluye un módulo muy completo llamado Tkinter, un framework que
permite desarrollo rápido de aplicaciones gráficas interactivas, así como control
de los aspectos de la interfaz.

Paquetes.
Los paquetes permiten crear librerías de código que puede estar esparcido en
múltiples archivos y directorios, lo que permite tener mejor organización de
grandes colecciones de código que usando un módulo.

65
Conceptos avanzados de POO.
Python posee muchas opciones relacionadas con orientación a objetos; añadi-
endo atributos especiales a los métodos, se pueden simular otras clases, in-
cluso los tipos básicos; también es posible modificar su comportamiento según
las necesidades propias; también es posible controlar la creación y el compor-
tamiento de las clases, por medio de meta-clases.

Acceso a bases de datos


El acceso a bases de datos es una parte muy importante de muchas aplicaciones,
incluyendo aplicaciones web dinámicas; utilizando módulos externos, Python
puede comunicarse con las bases de datos comunes, la interfaz de todas ellas
utilizan el estándar DB-API 2.0, lo cual facilita todas las operaciones sobre
bases de datos.

Programación en red.
La librería estándar de Python posee todo lo necesario para controlar los pro-
tocolos estándares de Internet, así como crear clientes y servidores; en muchos
casos, puede crearse un servidor con unas pocas líneas de código.

Aplicaciones web.
Aunque el módulo http.server tiene todo lo básico para servicios web, se necesita
más que sólo lo básico para crear aplicaciones completas; es necesario manejo de
usuarios, autentificación, sesiones, etc.; y se necesita un mecanismo para generar
páginas html. La solución es utilizar el web framework, con este se han creado
varios frameworks en Python, llegando a proyectos de última generación, como
Zope y Plone, Django, TurboGears, web2py y muchos otros.

66

También podría gustarte