ebook img

Introducción a la programación con Python PDF

399 Pages·2013·4.5 MB·Spanish
by  
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Introducción a la programación con Python

Introducci´on a la programaci´on con Python Andr´es Marzal Isabel Gracia Departamento de Lenguajes y Sistemas Inform´aticos Universitat Jaume I c 2003 de Andr´es Marzal Var´o e Isabel Gracia Luengo. Reservados todos los derechos. ￿ Esta ✭✭Edici´on Internet✮✮ se puede reproducir con fines autodidactas o para su uso en centros pu´blicos de ensen˜anza, exclusivamente. En el segundo caso, u´nicamente se car- gar´analestudianteloscostesdereproducci´on.Lareproducci´ontotaloparcialcon´animo de lucro o con cualquier finalidad comercial est´a estrictamente prohibida sin el permiso escrito de los autores. ´ Indice general 1. Introducci´on 5 1.1. Computadores . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 5 1.2. Codificaci´on de la informaci´on. . . . . . . . . . . . . . . . . . . . . . . . . . . . . 6 1.3. Programas y lenguajes de programaci´on . . . . . . . . . . . . . . . . . . . . . . . 9 1.3.1. C´odigo de m´aquina . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 10 1.3.2. Lenguaje ensamblador . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 12 1.3.3. ¿Un programa diferente para cada ordenador?. . . . . . . . . . . . . . . . 12 1.3.4. Lenguajes de programaci´on de alto nivel . . . . . . . . . . . . . . . . . . . 14 1.3.5. Compiladores e int´erpretes . . . . . . . . . . . . . . . . . . . . . . . . . . 14 1.3.6. Python . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 15 1.3.7. C . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 16 1.4. M´as all´a de los programas: algoritmos . . . . . . . . . . . . . . . . . . . . . . . . 17 2. Una calculadora avanzada 23 2.1. Sesiones interactivas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 23 2.1.1. Los operadores aritm´eticos . . . . . . . . . . . . . . . . . . . . . . . . . . 24 2.1.2. Errores de tecleo y excepciones . . . . . . . . . . . . . . . . . . . . . . . . 30 2.2. Tipos de datos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 2.2.1. Enteros y flotantes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 32 2.2.2. Valores l´ogicos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 34 2.3. Operadores l´ogicos y de comparaci´on . . . . . . . . . . . . . . . . . . . . . . . . . 34 2.4. Variables y asignaciones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 38 2.4.1. Asignaciones con operador. . . . . . . . . . . . . . . . . . . . . . . . . . . 41 2.4.2. Variables no inicializadas . . . . . . . . . . . . . . . . . . . . . . . . . . . 42 2.5. El tipo de datos cadena . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 43 2.6. Funciones predefinidas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 46 2.7. Funciones definidas en m´odulos . . . . . . . . . . . . . . . . . . . . . . . . . . . . 48 2.7.1. El m´odulo math . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 49 2.7.2. Otros m´odulos de inter´es . . . . . . . . . . . . . . . . . . . . . . . . . . . 50 2.8. M´etodos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 51 3. Programas 53 3.1. El entorno PythonG . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 53 3.2. Ejecuci´on de programas desde la l´ınea de ´ordenes Unix . . . . . . . . . . . . . . . 57 3.3. Entrada/salida . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 57 3.3.1. Lectura de datos de teclado . . . . . . . . . . . . . . . . . . . . . . . . . . 57 3.3.2. M´as sobre la sentencia print . . . . . . . . . . . . . . . . . . . . . . . . . 60 3.3.3. Salida con formato . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 62 3.4. Legibilidad de los programas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 64 3.4.1. Algunas claves para aumentar la legibilidad . . . . . . . . . . . . . . . . . 65 3.4.2. Comentarios . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 66 3.5. Gr´aficos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 67 Introducci´on a la Programaci´on con Python i ´INDICE GENERAL 2006/09/25-15:31 4. Estructuras de control 75 4.1. Sentencias condicionales . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 75 4.1.1. Un programa de ejemplo: resoluci´on de ecuaciones de primer grado . . . . 75 4.1.2. La sentencia condicional if . . . . . . . . . . . . . . . . . . . . . . . . . . 77 4.1.3. Trazas con PythonG: el depurador . . . . . . . . . . . . . . . . . . . . . . 79 4.1.4. Sentencias condicionales anidadas. . . . . . . . . . . . . . . . . . . . . . . 81 4.1.5. Otro ejemplo: resoluci´on de ecuaciones de segundo grado. . . . . . . . . . 83 4.1.6. En caso contrario (else) . . . . . . . . . . . . . . . . . . . . . . . . . . . . 84 4.1.7. Una estrategia de disen˜o: refinamientos sucesivos . . . . . . . . . . . . . . 87 4.1.8. Un nuevo refinamiento del programa de ejemplo . . . . . . . . . . . . . . 88 4.1.9. Otro ejemplo: m´aximo de una serie de nu´meros . . . . . . . . . . . . . . . 90 4.1.10. Evaluaci´on con cortocircuitos . . . . . . . . . . . . . . . . . . . . . . . . . 94 4.1.11. Un u´ltimo problema: menu´s de usuario. . . . . . . . . . . . . . . . . . . . 96 4.1.12. Una forma compacta para estructuras condicionales mu´ltiples (elif) . . . 98 4.2. Sentencias iterativas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 4.2.1. La sentencia while . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 99 4.2.2. Un problema de ejemplo: c´alculo de sumatorios . . . . . . . . . . . . . . . 103 4.2.3. Otro programa de ejemplo: requisitos en la entrada . . . . . . . . . . . . . 104 4.2.4. Mejorando el programa de los menu´s . . . . . . . . . . . . . . . . . . . . . 106 4.2.5. El bucle for-in . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 109 4.2.6. for-in como forma compacta de ciertos while . . . . . . . . . . . . . . . 112 4.2.7. Nu´meros primos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 113 4.2.8. Rotura de bucles: break . . . . . . . . . . . . . . . . . . . . . . . . . . . . 118 4.2.9. Anidamiento de estructuras . . . . . . . . . . . . . . . . . . . . . . . . . . 120 4.3. Captura y tratamiento de excepciones . . . . . . . . . . . . . . . . . . . . . . . . 121 4.4. Algunos ejemplos gr´aficos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 124 4.4.1. Un graficador de funciones . . . . . . . . . . . . . . . . . . . . . . . . . . 124 4.4.2. Una animaci´on: simulaci´on gravitacional . . . . . . . . . . . . . . . . . . . 128 4.4.3. Un programa interactivo: un videojuego . . . . . . . . . . . . . . . . . . . 134 4.5. Una reflexi´on final . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 143 5. Tipos estructurados: secuencias 145 5.1. Cadenas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145 5.1.1. Lo que ya sabemos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 145 5.1.2. Escapes . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 146 5.1.3. Longitud de una cadena . . . . . . . . . . . . . . . . . . . . . . . . . . . . 148 5.1.4. Indexaci´on . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 149 5.1.5. Recorrido de cadenas. . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 151 5.1.6. Un ejemplo: un contador de palabras . . . . . . . . . . . . . . . . . . . . . 152 5.1.7. Otro ejemplo: un programa de conversi´on de binario a decimal . . . . . . 157 5.1.8. A vueltas con las cadenas: inversi´on de una cadena . . . . . . . . . . . . . 158 5.1.9. Subcadenas: el operador de corte . . . . . . . . . . . . . . . . . . . . . . . 160 5.1.10. Una aplicaci´on: correo electr´onico personalizado . . . . . . . . . . . . . . 162 5.1.11. Referencias a cadenas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 164 5.2. Listas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 168 5.2.1. Cosas que, sin darnos cuenta, ya sabemos sobre las listas . . . . . . . . . 170 5.2.2. Comparaci´on de listas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 5.2.3. El operador is . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 173 5.2.4. Modificaci´on de elementos de listas . . . . . . . . . . . . . . . . . . . . . . 175 5.2.5. Mutabilidad, inmutabilidad y representaci´on de la informaci´on en memoria176 5.2.6. Adici´on de elementos a una lista . . . . . . . . . . . . . . . . . . . . . . . 178 5.2.7. Lectura de listas por teclado . . . . . . . . . . . . . . . . . . . . . . . . . 180 5.2.8. Borrado de elementos de una lista . . . . . . . . . . . . . . . . . . . . . . 182 5.2.9. Pertenencia de un elemento a una lista . . . . . . . . . . . . . . . . . . . . 185 5.2.10. Ordenaci´on de una lista . . . . . . . . . . . . . . . . . . . . . . . . . . . . 186 5.3. De cadenas a listas y viceversa . . . . . . . . . . . . . . . . . . . . . . . . . . . . 191 5.4. Matrices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 193 5.4.1. Sobre la creaci´on de matrices . . . . . . . . . . . . . . . . . . . . . . . . . 194 5.4.2. Lectura de matrices . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 196 ii Introducci´on a la Programaci´on con Python 0´INDICE GENERAL c 2003Andr´esMarzaleIsabelGracia ￿ 5.4.3. ¿Qu´e dimensi´on tiene una matriz? . . . . . . . . . . . . . . . . . . . . . . 197 5.4.4. Operaciones con matrices . . . . . . . . . . . . . . . . . . . . . . . . . . . 197 5.4.5. El juego de la vida . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 200 5.5. Una reflexi´on final . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 209 6. Funciones 211 6.1. Uso de funciones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 211 6.2. Definici´on de funciones . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 212 6.2.1. Definici´on y uso de funciones con un solo par´ametro . . . . . . . . . . . . 212 6.2.2. Definici´on y uso de funciones con varios par´ametros . . . . . . . . . . . . 221 6.2.3. Definici´on y uso de funciones sin par´ametros . . . . . . . . . . . . . . . . 223 6.2.4. Procedimientos: funciones sin devoluci´on de valor . . . . . . . . . . . . . . 226 6.2.5. Funciones que devuelven varios valores mediante una lista . . . . . . . . . 231 6.3. Un ejemplo: Memori´on . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 232 6.4. Variables locales y variables globales . . . . . . . . . . . . . . . . . . . . . . . . . 241 6.5. El mecanismo de las llamadas a funci´on . . . . . . . . . . . . . . . . . . . . . . . 250 6.5.1. La pila de llamadas a funci´on y el paso de par´ametros . . . . . . . . . . . 250 6.5.2. Paso del resultado de expresiones como argumentos . . . . . . . . . . . . 254 6.5.3. M´as sobre el paso de par´ametros . . . . . . . . . . . . . . . . . . . . . . . 255 6.5.4. Acceso a variables globales desde funciones . . . . . . . . . . . . . . . . . 262 6.6. Ejemplos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 267 6.6.1. Integraci´on num´erica . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 267 6.6.2. Aproximaci´on de la exponencial de un nu´mero real . . . . . . . . . . . . . 270 6.6.3. C´alculo de nu´meros combinatorios . . . . . . . . . . . . . . . . . . . . . . 274 6.6.4. El m´etodo de la bisecci´on . . . . . . . . . . . . . . . . . . . . . . . . . . . 274 6.7. Disen˜o de programas con funciones . . . . . . . . . . . . . . . . . . . . . . . . . . 276 6.7.1. Ahorro de tecleo . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 278 6.7.2. Mejora de la legibilidad . . . . . . . . . . . . . . . . . . . . . . . . . . . . 278 6.7.3. Algunosconsejosparadecidirqu´edeber´ıadefinirsecomofunci´on:an´alisis descendente y ascendente . . . . . . . . . . . . . . . . . . . . . . . . . . . 278 6.8. Recursi´on . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 279 6.8.1. C´alculo recursivo del factorial . . . . . . . . . . . . . . . . . . . . . . . . . 280 6.8.2. C´alculorecursivodelnu´merodebitsnecesariospararepresentarunnu´mero284 6.8.3. Los nu´meros de Fibonacci . . . . . . . . . . . . . . . . . . . . . . . . . . . 284 6.8.4. El algoritmo de Euclides . . . . . . . . . . . . . . . . . . . . . . . . . . . . 287 6.8.5. Las torres de Hanoi . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 289 6.8.6. Recursi´on indirecta . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 292 6.8.7. Gr´aficos fractales: copos de nieve de von Koch . . . . . . . . . . . . . . . 292 6.9. M´odulos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 298 6.9.1. Un m´odulo muy sencillo: m´ınimo y m´aximo . . . . . . . . . . . . . . . . . 298 6.9.2. Un m´odulo m´as interesante: gravedad . . . . . . . . . . . . . . . . . . . . 299 6.9.3. Otro m´odulo: c´alculo vectorial . . . . . . . . . . . . . . . . . . . . . . . . 303 6.9.4. Un m´odulo para trabajar con polinomios . . . . . . . . . . . . . . . . . . 306 6.9.5. Un m´odulo con utilidades estad´ısticas . . . . . . . . . . . . . . . . . . . . 308 6.9.6. Un m´odulo para c´alculo matricial . . . . . . . . . . . . . . . . . . . . . . . 310 7. Tipos estructurados: registros 313 7.1. Asociando datos relacionados . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313 7.1.1. Lo que sabemos hacer . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 313 7.1.2. ... pero sabemos hacerlo mejor . . . . . . . . . . . . . . . . . . . . . . . . 314 7.2. Registros . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 316 7.2.1. Definici´on de nuevos tipos de dato . . . . . . . . . . . . . . . . . . . . . . 316 7.2.2. Referencias a registros . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 318 7.2.3. Copia de registros . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 319 7.3. Algunos ejemplos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 322 7.3.1. Gesti´on de calificaciones de estudiantes . . . . . . . . . . . . . . . . . . . 322 7.3.2. Fechas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 332 7.3.3. Anidamiento de registros . . . . . . . . . . . . . . . . . . . . . . . . . . . 335 7.3.4. Gesti´on de un videoclub . . . . . . . . . . . . . . . . . . . . . . . . . . . . 337 Introducci´on a la Programaci´on con Python iii ´INDICE GENERAL 2006/09/25-15:31 7.3.5. Algunasreflexionessobrec´omodesarrollamoslaaplicaci´ondegesti´ondel videoclub . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 346 8. Ficheros 349 8.1. Generalidades sobre ficheros . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 349 8.1.1. Sistemas de ficheros: directorios y ficheros . . . . . . . . . . . . . . . . . . 349 8.1.2. Rutas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 350 8.1.3. Montaje de unidades . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 351 8.2. Ficheros de texto . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 352 8.2.1. El protocolo de trabajo con ficheros: abrir, leer/escribir, cerrar . . . . . . 352 8.2.2. Lectura de ficheros de texto l´ınea a l´ınea . . . . . . . . . . . . . . . . . . . 352 8.2.3. Lectura car´acter a car´acter . . . . . . . . . . . . . . . . . . . . . . . . . . 357 8.2.4. Otra forma de leer l´ınea a l´ınea . . . . . . . . . . . . . . . . . . . . . . . . 359 8.2.5. Escritura de ficheros de texto . . . . . . . . . . . . . . . . . . . . . . . . . 360 8.2.6. An˜adir texto a un fichero . . . . . . . . . . . . . . . . . . . . . . . . . . . 363 8.2.7. Cosas que no se pueden hacer con ficheros de texto . . . . . . . . . . . . . 364 8.2.8. Un par de ficheros especiales: el teclado y la pantalla . . . . . . . . . . . . 364 8.3. Una aplicaci´on . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 365 8.4. Texto con formato . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 369 A. Tablas ASCII e IsoLatin1 (ISO-8859-1) 375 B. Funciones predefinidas en PythonG y accesibles con modulepythong 377 B.1. Control de la ventana gr´afica . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 377 B.2. Creaci´on de objetos gr´aficos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 377 B.3. Borrado de elementos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 379 B.4. Desplazamiento de elementos . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 379 B.5. Interacci´on con teclado y rat´on . . . . . . . . . . . . . . . . . . . . . . . . . . . . 379 B.6. Etiquetas . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . . 380 C. El m´odulo record 381 iv Introducci´on a la Programaci´on con Python Prefacio Estos libros de texto desarrollan el temario de la asignatura ✭✭Metodolog´ıa y tecnolog´ıa de la programaci´on✮✮delastitulacionesdeIngenier´ıaInform´aticaeIngenier´ıaT´ecnicaenInform´atica de Gesti´on de la Universitat Jaume I. En ella se pretende ensen˜ar a programar y, a diferencia de lo que es usual en cursos introductorios a la programaci´on, se propone el aprendizaje con dos lenguajes de programaci´on: Python y C. ¿Por qu´e dos lenguajes de programaci´on? Python y C son bien diferentes. El primero es un lenguaje de muy alto nivel que permite expresar algoritmos de forma casi directa (ha llegado a considerarse ✭✭pseudoc´odigo ejecutable✮✮) y hemos comprobado que se trata de un lenguaje particularmente adecuado para la ensen˜anza de la programaci´on. El lenguaje C exige una gran atenci´on a multitud de detalles que dificultan la implementaci´on de algoritmos a un estudiante que se enfrenta por primera vez al desarrollo de programas. No obstante, C sigue siendo un lenguajedeprogramaci´ondereferenciaydebeformarpartedelcurr´ıculumdetodoinform´atico; y no s´olo por su extendido uso en el mundo profesional: su proximidad al computador nos permitecontrolarcongranprecisi´onelconsumoderecursoscomputacionales.AprenderPython antes que C permite estudiar las estructuras de control y de datos b´asicas con un alto nivel de abstracci´on y, as´ı, entender mejor qu´e supone, exactamente, la mayor complejidad de la programaci´onenCyhastaqu´epuntoesmayorelgradodecontrolquenosotorga.Porejemplo, una vez se han estudiado listas en Python, su implementaci´on en C permite al estudiante no perderde vistaelobjetivou´ltimo:construirunaentidadconciertoniveldeabstracci´onusando unas herramientas concretas (los punteros). De ese modo se evita una desafortunada confusi´on entre estructuras din´amicas y punteros que es frecuente cuando ´estas se estudian u´nicamente a la luz de un lenguaje como C. En cierto modo, pues, Python y C se complementan en el aprendizaje y ofrecen una visi´on m´as rica y completa de la programacio´n. Las similitudes y diferenciasentreambospermitenalestudianteinferirm´asf´acilmentequ´eesfundamentalyqu´e accesorio o accidental al disen˜ar programas en un lenguaje de programaci´on cualquiera. ¿Y por qu´e otro libro de texto introductorio a la programaci´on? Ciertamente hay muchos libros que ensen˜an a programar desde cero. Este texto se diferencia de ellos tanto en el hecho de estudiar dos lenguajes como en la forma en que se exponen y desarrollan los conocimientos. Hemos procurado adoptar siempre el punto de vista del estudiante y presentar los conceptos y estrategias para disen˜ar programas b´asicos paso a paso, incrementalmente. La experiencia docente nos ha ido mostrando toda una serie l´ıneas de razonamiento inapropiadas, errores y vicios en los que caen muchos estudiantes. El texto trata de exponer, con mayor o menor fortuna,esosrazonamientos,erroresyviciosparaqueelestudiantelostengapresentesyprocure evitarlos.As´ı,eneldesarrollodealgunosprogramasllegamosaofrecerversioneserr´oneaspara, acto seguido, estudiar sus defectos y mostrar una versi´on corregida. Los apuntes est´an repletos de cuadros que pretenden profundizar en aspectos marginales, llamar la atenci´on sobre algu´n extremo, ofrecer algunas pinceladas de historia o, sencillamente, desviarse de lo central al tema con alguna digresi´on que podr´ıa resultar motivadora para el estudiante. Hemosderecalcarqueestelibropretendeensen˜araprogramarynoesunmanualexhaustivo sobre el lenguaje de programaci´on Python. Son particularmente resen˜ables dos omisiones: los diccionarios y las clases. No forman parte de esta edici´on (aunque pensamos incluirlos en la siguiente como material de estudio opcional) porque hemos preferido centrarnos en aquellos aspectos que tanto Python como C presentan en comu´n. Queremosaprovecharparadarunconsejoalosestudiantesquenonoscansamosderepetir: es imposible aprender a programar limit´andose a leer unos apuntes o a seguir pasivamente una explicaci´on en clase, especialmente si el per´ıodo de estudio se concentra en una o dos semanas. Programar al nivel propio de un curso introductorio no es particularmente dif´ıcil, pero consti- tuye una actividad intelectual radicalmente nueva para los estudiantes. Es necesario darse una Introducci´on a la Programaci´on con Python 1 ´INDICE GENERAL 2006/09/25-15:31 oportunidadparairasentandolosconocimientosylasestrategiasdedisen˜odeprogramas(yas´ı, superarelcurso).Esaoportunidadrequieretiempoparamadurar... ytrabajo,muchotrabajo; por eso el texto ofrece m´as de cuatrocientos ochenta ejercicios. S´olo tras haberse enfrentado a buena parte de ellos se estar´a preparado para demostrar que se ha aprendido lo necesario. Hay centenares de diferencias entre la primera edici´on y esta segunda. No s´olo hemos corre- gido erratas (y errores), hemos an˜adido tambi´en nuevos ejemplos, modificado otros, preparado nuevosejercicios,reubicadoejerciciosalugaresdondeparec´ıanm´asoportunos,etc.Losprogra- massepresentanconunatipograf´ıaque,creemos,facilitanotablementelalectura.Eldocumento PDF ofrece, adem´as, la posibilidad de descargar c´omodamente el texto de los programas (que se pueden descargar de http://marmota.act.uji.es/MTP). Esperamos que esta posibilidadse traduzca en un mayor ´animo del estudiante para experimentar con los programas. Convenios tipogr´aficos Hemostratadodeseguirunaseriedeconveniostipogr´aficosalolargodeltexto.Losprogramas, por ejemplo, se muestran con fondo gris, as´ı: 1 print’!Hola,￿mundo!’ Por regla general, las l´ıneas del programa aparecen numeradas a mano izquierda. Esta nu- meraci´on tiene por objeto facilitar la referencia a puntos concretos del programa y no debe reproducirse en el fichero de texto si se copia el texto del programa. Cuando se quiere destacar el nombre del fichero en el que reside un programa, se dispone este en una barra encima del c´odigo: hola mundo.py 1 print’!Hola,￿mundo!’ Si se trabaja con la versi´on electr´onica del libro en formato PDF (disponible en la p´agina web http://marmota.act.uji.es/MTP) es posible acceder c´omodamente al texto de los pro- gramas. Para ello, basta con desempaquetar el fichero programas.tgz (o programas.zip) en el mismo directorio en el que est´e ubicado el documento PDF. Los programas accesibles tienen un icono que representa un documento escrito en la esquina superior izquierda. Junto al icono aparece el nombre real del fichero: como ofrecemos varias versiones de un mismo programa, nos hemos visto obligados a seguir un esquema de numeraci´on que modifica el propio nombre del fichero. La primera versi´on de un fichero llamado hola mundo.py es hola mundo 1.py, la segunda hola mundo 2.py, y as´ı sucesivamente. hola mundo.py holamundo1.py 1 print’!Hola,’,’mundo!’ Si, aunque haya varias versiones, no aparece un nu´mero al final del nombre del fichero descar- gable, se entiende que esa es la versi´on definitiva. hola mundo.py holamundo.py 1 print’!Hola,￿mundo!’ Al pinchar en el icono, se abre un fichero de texto con el navegador web o editor de textos que se indique en las preferencias del visualizador de documentos PDF. Cuando el programa contiene algu´n error grave, aparecen un par de rayos flanqueando al nombre del programa: E hola mundo.py E 1 rint ’!Hola,￿mundo!’ Algunos programas no est´an completos y, por ello, presentan alguna deficiencia. No obstante, hemos optado por no marcarlos como err´oneos cuando ´estos evolucionaban en el curso de la exposici´on. La informaci´on que se muestra por pantalla aparece siempre recuadrada. El resultado de ejecutar hola mundo.py se mostrar´a as´ı: !Hola, mundo! En ocasiones mostraremos las ´ordenes que deben ejecutarse en un int´erprete de ´ordenes Unix. El prompt del int´erprete se representar´a con un s´ımbolo de d´olar: 2 Introducci´on a la Programaci´on con Python 0´INDICE GENERAL c 2003Andr´esMarzaleIsabelGracia ￿ ￿ $ python hola_mundo.py !Hola, mundo! La parte que debe teclear el usuario o el programador se muestra siempre con un fondo gris. El ￿ retorno de carro se representa expl´ıcitamente con el s´ımbolo . Las sesiones interactivas del int´erprete de Python tambi´en se muestran recuadradas. El prompt primario del int´erprete Python se muestra con los caracteres ✭✭>>>✮✮ y el secundario con ✭✭...✮✮. Las expresiones y sentencias que teclea el programador se destacan con fondo gris. ￿ >>> ’Hola,’+’￿’+’mundo!’ ’!Hola, mundo!’ ￿ >>> if ’Hola’==’mundo’: ￿ ... print’si’ ￿ ... else: ￿ ... print’no’ ￿ ... no Agradecimientos Este texto es fruto de la experiencia docente de todo el profesorado de las asignaturas de ✭✭Metodolog´ıa y tecnolog´ıa de la programaci´on✮✮ y se ha enriquecido con las aportaciones, comentarios y correcciones de muchos profesores del departamento de Lenguajes y Sistemas Inform´aticos de la Universitat Jaume I de Castell´o: Juan Pablo Aibar Ausina, Rafael Berlanga Llavor´ı, Antonio Castellanos L´opez, Pedro Garc´ıa Sevilla, Mar´ıa Dolores Llid´o Escriv´a, David Llorens Pin˜ana, Jos´e Luis Llopis Borr´as, Juan Miguel Vilar Torres y V´ıctor Manuel Jim´enez Pelayo. Para todos ellos, nuestro agradecimiento. El agradecimiento a David Llorens Pin˜ana es doble por desarrollar, adem´as, el entorno de programaci´on PythonG. Nos gustar´ıa adelantarnos y agradecer de antemano al colaboraci´on de cuantos nos hagan llegar sugerencias o detecten erratas que nos permitan mejorar el texto en futuras ediciones. Castell´o de la Plana, a 18 de septiembre de 2003. Andr´es Marzal Var´o e Isabel Gracia Luengo. Introducci´on a la Programaci´on con Python 3 ´INDICE GENERAL 2006/09/25-15:31 4 Introducci´on a la Programaci´on con Python

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.