From 342d84b7c40d021ad2cf7aa95643ed145e135b8a Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sun, 22 Jan 2023 02:01:29 -0300 Subject: [PATCH 01/16] Creado con Colaboratory --- ...B\303\241sico_Interactivo_de_Python.ipynb" | 982 ++++++++++++++++++ 1 file changed, 982 insertions(+) create mode 100644 "Copia_de_Tutorial_B\303\241sico_Interactivo_de_Python.ipynb" diff --git "a/Copia_de_Tutorial_B\303\241sico_Interactivo_de_Python.ipynb" "b/Copia_de_Tutorial_B\303\241sico_Interactivo_de_Python.ipynb" new file mode 100644 index 000000000..8a4ee6328 --- /dev/null +++ "b/Copia_de_Tutorial_B\303\241sico_Interactivo_de_Python.ipynb" @@ -0,0 +1,982 @@ +{ + "nbformat": 4, + "nbformat_minor": 0, + "metadata": { + "colab": { + "provenance": [], + "private_outputs": true, + "include_colab_link": true + }, + "kernelspec": { + "name": "python3", + "display_name": "Python 3" + }, + "language_info": { + "name": "python" + }, + "gpuClass": "standard" + }, + "cells": [ + { + "cell_type": "markdown", + "metadata": { + "id": "view-in-github", + "colab_type": "text" + }, + "source": [ + "\"Open" + ] + }, + { + "cell_type": "markdown", + "source": [ + "# Tutorial Básico Interactivo de Python de Código Pitón\n", + "\n", + "![cp.png]()\n", + "\n", + "¡Hola! **Bienvenido al Tutorial Básico Interactivo de Python de [Código Pitón](https://www.codigopiton.com/)**.\n", + "\n", + "Este tutorial recoge una guía básica de los fundamentos de Python en forma de cuaderno de Jupyter alojado en Google Colab (Colaboratory).\n", + "\n", + "Está estrechamente ligado a la [Hoja de Referencia de Python de Código Pitón](https://www.codigopiton.com/la-hoja-de-referencia-de-python/) que recibiste cuando te suscribiste a la lista de correo de Código Pitón.\n", + "\n", + "Si no tienes la Hoja de Referencia (por ejemplo, porque alguien te compartió este tutorial) puedes [conseguirla de manera gratuita al susbscribirte a Código Pitón](https://www.codigopiton.com/la-hoja-de-referencia-de-python/) y te llegará inmediatamente por correo electrónico.\n", + "\n", + "La **idea principal de este tutorial** es que tengas una guía interactiva para complementar perfectamente a la Hoja de Referencia y a la que puedas recurrir durante tu aprendizaje si te surge alguna duda. Espero que te sea de mucha utilidad.\n", + "\n", + "El tutorial tiene 15 apartados, exactamente igual que la Hoja de Referencia, y en el mismo orden, para que no te pierdas en ningún momento. Además, les he puesto el mismo nombre para que no quede lugar a ningún tipo de duda.\n", + "\n", + "¡Vamos allá!\n", + "\n", + "## Antes de empezar\n", + "\n", + "Si no estás muy familiarizado con los cuadernos de Jupyter, ¡no te preocupes! Aquí es todo muy fácil. Todo se organiza en celdas. Podrás ver celdas de texto explicativo (como este) y celdas con fragmentos de código Python ejecutable, como el siguiente:\n" + ], + "metadata": { + "id": "EZslL1PpIsde" + } + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": { + "id": "9NrJqYoyINXn" + }, + "outputs": [], + "source": [ + "print('¡Hola desde el Tutorial Básico Interactivo de Código Pitón! 😊') " + ] + }, + { + "cell_type": "markdown", + "source": [ + "Siéntete libre de ejecutar los fragmentos de código que quieras y de modificarlos a tu gusto para experimentar y aprender, ¡ese es el objetivo de este tutorial interactivo!\n", + "\n", + "Para ejecutar un fragmento de código basta con que hagas click en el icono de ejecutar a la izquierda de cada celda. También puedes ejecutarlos con la combinación de teclas Ctrl + Enter y verás el resultado justo debajo.\n", + "\n", + "Y ahora sí, vamos con el tutorial.\n", + "\n", + "\n", + "\n", + "\n", + "\n", + "Los contenidos son los siguientes:\n", + "\n", + "\n", + "1. Asignación de variables\n", + "2. Acceso a valor de variables\n", + "3. Aritmética básica\n", + "4. Importación de módulos\n", + "5. Gestión de excepciones\n", + "6. Salida y formato de texto\n", + "7. Listas\n", + "8. Condicionales\n", + "9. Booleanos y comparaciones\n", + "10. Comprensión de listas\n", + "11. Comentarios\n", + "12. Funciones\n", + "13. Bucles\n", + "14. Notación de porciones\n", + "15. Entrada por teclado\n", + "\n", + "\n", + "\n" + ], + "metadata": { + "id": "IAHwNotEQtNy" + } + }, + { + "cell_type": "markdown", + "source": [ + "# 1. Asignación de variables\n", + "\n", + "Los principales tipos de datos son números enteros (int), números decimales (float), cadenas de texto (str) y valores booleanos (verdadero o falso, te cuento más sobre esto más adelante).\n", + "\n", + "Para realizar asignaciones utiliza nombres de variables identificativos, el símbolo = y el valor que quieras asociar a la variable." + ], + "metadata": { + "id": "qhinAwWbPwsG" + } + }, + { + "cell_type": "code", + "source": [ + "x = 10 # enteros\n", + "y = 0.5 # decimales\n", + "z = 'hola' # texto\n", + "b = True # booleanos\n", + "print(x)\n", + "print(y)\n", + "print(z)\n", + "print(b)" + ], + "metadata": { + "id": "bl-PHta-TM7D" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "Las principales colecciones de datos son las listas (modificables), las tuplas (no modificables), los conjuntos (que no admiten repetidos) y los diccionarios (que guardan pares clave-valor)." + ], + "metadata": { + "id": "ltpQ4vgOTgx6" + } + }, + { + "cell_type": "code", + "source": [ + "tupla = (1, 2, 3)\n", + "lista = [4, 5.5, 'a6']\n", + "conjunto = ('a', 'b', 'c')\n", + "\n", + "print(tupla)\n", + "print(lista)\n", + "print(conjunto)\n", + "\n", + "diccionario = {10: 1.1, 20: 1.0, 30: 1.3}\n", + "diccionario[40] = 1.5 # asignando un valor (1.5) a una nueva clave (40)\n", + "print(diccionario)\n", + "\n", + "x, y, z = 1, 2, 3 # asignación múltiple\n", + "print('Tras la asignación múltiple: ')\n", + "print(x)\n", + "print(y)\n", + "print(z)\n", + "\n", + "print('Tras intercambiar valores: ')\n", + "x, y = y, x # intercambio de valores\n", + "print(x)\n", + "print(y)\n", + "\n", + "print('Tras desempaquetar una tupla en variables: ')\n", + "x, y, z = (10, 20, 30)\n", + "print(x)\n", + "print(y)\n", + "print(z)\n" + ], + "metadata": { + "id": "mBTQ6WUbTmSX" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 2. Acceso a valor de variables\n", + "\n", + "Cuando ya hemos hecho asignaciones y tenemos variables con valores, podemos acceder a esos valores utilizando el nombre de las variables en otras expresiones.\n", + "\n", + "Además, podemos acceder a los elementos de una lista o una tupla a través de su índice (número de posición, comenzando en 0) indicándolo entre corchetes \\[ y \\].\n", + "\n", + "Para acceder a los valores de un diccionario utilizaremos la clave asociada a cada valor, de nuevo entre corchetes.\n", + "\n", + "También podemos acceder a los atributos de una clase utilizando el nombre de la clase, un punto y a continuación el nombre del atributo. De igual manera, podemos acceder a los atributos de un objeto o instancia utilizando el nombre del objeto, un punto y a continuación el nombre del atributo.\n" + ], + "metadata": { + "id": "xUu-z6MPQTn8" + } + }, + { + "cell_type": "code", + "source": [ + "lista = [10, 20, 30, 40, 50]\n", + "valor = lista[2]\n", + "print(valor)\n", + "\n", + "diccionario = {10: 5, 20: 7, 30: 9}\n", + "valor = diccionario[20]\n", + "print(valor)\n", + "valor = diccionario.get(40, '0') # valor por defecto 0 si clave (40) no existe\n", + "\n", + "class Clase:\n", + "\n", + " atributo_de_clase = 10\n", + "\n", + " def __init__(self):\n", + " self.atributo_de_instancia = 20\n", + "\n", + "\n", + "print(Clase.atributo_de_clase)\n", + "\n", + "instancia = Clase()\n", + "print(instancia.atributo_de_instancia)" + ], + "metadata": { + "id": "Dv3EgoExVqhr" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "Más información sobre variables: https://www.codigopiton.com/variables-locales-y-globales-en-python/" + ], + "metadata": { + "id": "hllJO5IAMPS1" + } + }, + { + "cell_type": "markdown", + "source": [ + "# 3. Aritmética básica\n", + "\n", + "Podemos realizar operaciones matemáticas aritméticas básicas utilizando los símbolos +, -, * (multiplicación), / (división), // (división entera), % (resto de la división entera o módulo) y \\*\\* (potencia).\n" + ], + "metadata": { + "id": "GXjjRcl4QzB8" + } + }, + { + "cell_type": "code", + "source": [ + "print(3 + 5)\n", + "print(5 - 3)\n", + "print(5 * 3)\n", + "print(5 / 3)\n", + "print(5 // 3)\n", + "print(5 % 3)\n", + "print(5 ** 3)" + ], + "metadata": { + "id": "SSDZqkv8XRer" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 4. Importación de módulos\n", + "\n", + "Si necesitas utilizar una librería (tanto de Python como externa) tendrás que importar el módulo correspondiente con import. \n", + "\n", + "Podrás darle un alias al módulo si utilizas as.\n", + "\n", + "También puedes importar un componente concreto de un módulo a través de from." + ], + "metadata": { + "id": "WItnb6q8Q-fp" + } + }, + { + "cell_type": "code", + "source": [ + "import datetime\n", + "\n", + "print(datetime.datetime.now())" + ], + "metadata": { + "id": "aVd-5GYuYY8f" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "source": [ + "import datetime as dt\n", + "\n", + "print(dt.datetime.now())" + ], + "metadata": { + "id": "pmez2i-FYx0G" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "source": [ + "from datetime import datetime as dt\n", + "\n", + "print(dt.now())" + ], + "metadata": { + "id": "u52AMnEFY3Cf" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 5. Gestión de excepciones\n", + "\n", + "Para manejar errores y excepciones tienes que usar la construcción try - except - finally. De no hacerlo, el código interrumpe su ejecución en caso de surgir algún error.\n", + "\n", + "Algunos de los errores más comunes son los siguientes:\n", + "* SyntaxError: sintaxis incorrecta\n", + "* ValueError: valor argumento no válido\n", + "* ZeroDivisionError: división por cero\n", + "* NameError: variable no definida\n", + "* ModuleNotFoundError: modulo no existe\n", + "* FileNotFoundError: fichero no existe\n", + "* IndexError: índice no existe\n", + "* KeyError: clave no existe\n", + "\n", + "\n", + "\n" + ], + "metadata": { + "id": "j_bTR38XRB1Y" + } + }, + { + "cell_type": "code", + "source": [ + "# El siguiente código genera un error\n", + "\n", + "a = 10\n", + "b = 0\n", + "\n", + "print(a/b) # no se puede dividir por cero" + ], + "metadata": { + "id": "-XPkB0XRbR88" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "code", + "source": [ + "# Vamos a controlar el error para que no se interrumpa la ejecución\n", + "\n", + "a = 10\n", + "b = 0\n", + "\n", + "try:\n", + " print(a/b)\n", + "except ZeroDivisionError:\n", + " print('Lo siento, no puedo dividir por cero.')\n", + "finally:\n", + " print('Bloque try-except finalizado') # esto, que es opcional, se ejecuta siempre, haya error o no\n", + " " + ], + "metadata": { + "id": "fp6wj4dybZI4" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 6. Salida y formato de texto\n", + "\n", + "Ya has visto que la función *print* se utiliza para mostrar información por pantalla.\n", + "\n", + "Podemos personalizar la manera en que se muestra esa información de múltiples maneras. Algunas formas sencillas y básicas son la siguientes:" + ], + "metadata": { + "id": "e-4K3kjIRIee" + } + }, + { + "cell_type": "code", + "source": [ + "a = 10\n", + "b = 20\n", + "c = 30.158\n", + "print(a)\n", + "print('b=' + str(b)) # convertimos un numero a string con str\n", + "\n", + "print('a=%i' % a) # usamos una máscara de número entero (%i) dentro de la cadena de texto\n", + "print('a=%i, b=%i' % (a, b))\n", + "\n", + "print('a={}, b={}'.format(a, b))\n", + "print('c={:.2f}'.format(c)) # puedes indicar se se usen solo dos decimales para un float\n", + "\n", + "print(f'a={a}, b={b}') # usamos f-strings, la forma preferida\n" + ], + "metadata": { + "id": "soEeTeTKcHDu" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 7. Listas\n", + "\n", + "Podemos hacer muchas cosas con las listas, pues son secuencias muy potentes. Veamos algunas:" + ], + "metadata": { + "id": "OowBr9SiOINH" + } + }, + { + "cell_type": "code", + "source": [ + "lista = [5, 6, 7]\n", + "\n", + "lista.append(8) # añadimos un elemento al final\n", + "print(lista)\n", + "\n", + "lista.insert(1, 10) # insertamos un elemento en la posición que queramos\n", + "print(lista)\n", + "\n", + "lista.remove(6) # eliminamos un elemento\n", + "del lista[0] # eliminamos una posición\n", + "print(lista)\n", + "\n", + "lista.clear() # vacíamos la lista\n", + "print(lista)\n", + "\n", + "lista = [5, 6, 7]\n", + "elementos = [8, 9]\n", + "\n", + "lista.extend(elementos) # añadimos al final los elementos de otra lista\n", + "print(lista)\n", + "\n", + "lista.reverse() # invertimos la lista (le damos la vuelta)\n", + "print(lista)\n", + "\n", + "print(len(lista)) # obtenemos el número de elementos (o longitud) de una lista\n", + "\n", + "print(lista.index(7)) # obtenemos el índice de un elemento\n", + "\n" + ], + "metadata": { + "id": "ahagt7kyeE5J" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "Aquí tienes más información sobre cómo obtener la posición o índice de un elemento en una lista: https://www.codigopiton.com/encontrar-indice-de-elemento-en-lista-en-python/" + ], + "metadata": { + "id": "nyQRye6VfOcC" + } + }, + { + "cell_type": "markdown", + "source": [ + "# 8. Condicionales\n", + "\n", + "Las condicionales nos permiten ejecutar un determinado fragmento de código si se cumple una determinada condición (rama if).\n", + "\n", + "Además, podemos indicar que, si no se cumple dicha condición, se ejecute otro código (rama else).\n", + "\n", + "Finalmente, se permite encadenar varias ramas ifs con distintas condiciones (elif) y una rama else si no se cumple ninguna de las condiciones indicadas. Las ramas aquí son excluyentes." + ], + "metadata": { + "id": "ju3H-DAjOId7" + } + }, + { + "cell_type": "code", + "source": [ + "a = 10\n", + "b = 20\n", + "\n", + "if a < 15:\n", + " print('a es menor que 15') # esto se ejecutará ya que se cumple la condición\n", + "\n", + "\n", + "if a > 15:\n", + " print('a es mayor que 15') # esto no se ejecutará ya que no se cumple la condición\n", + "\n", + "if a > 30:\n", + " print('a es mayor que 30') # esto no se ejecutará ya que no se cumple la condición\n", + "else:\n", + " print('a no es mayor que 30') # esto sí se ejecutará ya que no se cumple la condición\n", + "\n", + "\n", + "if b > 10:\n", + " print('b es mayor que 10') # esto se ejecutará ya que se cumple la condición\n", + "else:\n", + " print('b no es mayor que 10') # esto no se ejecutará ya que se cumple la condición\n", + "\n", + "\n", + "# a continuación se comprobaran las condiciones secuencialmente y se ejecutara \n", + "# solo el fragmento de código de la condición que se cumpla (condiciones excluyentes)\n", + "\n", + "if a < 10:\n", + " print('a es menor que 10')\n", + "elif a > 12:\n", + " print('a es mayor que 12')\n", + "elif b > 15:\n", + " print('b es mayor que 15') # esta es la rama que se ejecuta\n", + "elif b == 20:\n", + " print('b es igual a 20') # aunque la condición de esta rama es cierta no se ejcuta\n", + " # pues ya se ejecutó otra rama antes\n", + "else:\n", + " print('no se ha cumplido ninguna de las condiciones anteriores')" + ], + "metadata": { + "id": "JV2mITN3a2TG" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "Más información sobre condicionales: https://www.codigopiton.com/condicionales-en-python-mucho-mas-que-if-else/\n", + "\n", + "La estrucutura de control switch no existe en Python. Más información sobre cómo hacer switch en Python: https://www.codigopiton.com/como-hacer-switch-case-en-python/\n", + "\n", + "En Python existe, además, un operador ternario condicional: https://www.codigopiton.com/el-operador-ternario-condicional-en-python/\n", + "\n", + "Aunque desde la versión 3.10 de Python existe un mecanismo de \"pattern matching\" que se puede utilizar para emular un switch. Más información: https://peps.python.org/pep-0636/" + ], + "metadata": { + "id": "EPh-Axa2cc1L" + } + }, + { + "cell_type": "markdown", + "source": [ + "# 9. Booleanos y comparaciones\n", + "\n", + "Ahora que ya sabes cómo hacer condicionales, vamos a revisar los valores booleanos y las principales posibles comparaciones y comprobaciones que se pueden hacer en Python que devuelven valores booleanos.\n", + "\n", + "Los valores booleanos, son True y False (escritos con inicial mayúscula) y cuyo significado es \"cierto\" y \"falso\" respectivamente.\n", + "\n", + "Comparaciones y comprobaciones principales:\n", + "* Mayor: >\n", + "* Mayor o igual: >=\n", + "* Menor: <\n", + "* Menor o igual: <=\n", + "* Igual: ==\n", + "* Diferente: !=\n", + "* Pertenencia: in\n", + "\n", + "Puedes negar un valor booleano o condición para obtener el valor contrario con la palabra reservada \"not\"." + ], + "metadata": { + "id": "rQKB2F9AOIr2" + } + }, + { + "cell_type": "code", + "source": [ + "a = 2\n", + "b = 3\n", + "\n", + "print('Comparaciones simples:')\n", + "print(a > b)\n", + "print(a >= b)\n", + "print(a < b)\n", + "print(a <= b)\n", + "print(a == b)\n", + "print(a != b)\n", + "\n", + "print('Comprobación de pertenencia:')\n", + "lista = [1, 3, 5]\n", + "print(a in lista)\n", + "print(b in lista)\n", + "\n", + "print('Negación con not')\n", + "print(not True)\n", + "print(not False)\n", + "print(not a > b)\n", + "print(not a == b)\n" + ], + "metadata": { + "id": "aBjkpZRyd8V9" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "Más información sobre booleanos, comparaciones, condicionales, etc.: https://www.codigopiton.com/condicionales-en-python-mucho-mas-que-if-else/" + ], + "metadata": { + "id": "ZZKF7GPaeoZO" + } + }, + { + "cell_type": "markdown", + "source": [ + "Puedes combinar distintas comparaciones para crear una más compleja con las palabras reservadas \"and\" y \"or\".\n", + "\n", + "Cuando usas and entre dos comparaciones o condiciones, ambas deben ser True para que la condición combinada sea True.\n", + "\n", + "Cuando usas or entre dos comparaciones o condiciones, al menos una de ellas tiene que ser True para que la condición combinada sea True." + ], + "metadata": { + "id": "2tzz0ZRjwqHo" + } + }, + { + "cell_type": "code", + "source": [ + "a = 2\n", + "b = 3\n", + "print(b >= 3 and a == 2)\n", + "print(a < 10 and b < 2)\n", + "print(a == 2 or b == 0)\n", + "print(a < 0 or b < 0)" + ], + "metadata": { + "id": "Mu96IFV6xECQ" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 10. Comprensión de listas\n", + "\n", + "En Python podemos generar listas \"al vuelo\" utilizando un bucle for que devuelva un elemento e en cada iteración, aplicando un cálculo o expresión sobre e y encerrándolo todo entre [corchetes](https://www.codigopiton.com/parentesis-corchetes-llaves-en-python/). \n", + "\n", + "De esta manera se genera una lista con todos los elementos generados a partir de e.\n", + "\n", + "Ejemplos:" + ], + "metadata": { + "id": "MVkNPcwDOI6A" + } + }, + { + "cell_type": "code", + "source": [ + "lista = [10, 20, 30]\n", + "\n", + "lista_negada = [ -e for e in lista ]\n", + "lista_doble = [ e*2 for e in lista]\n", + "\n", + "print(lista_negada)\n", + "print(lista_doble)" + ], + "metadata": { + "id": "gEhGP1_bfcp2" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 11. Comentarios\n", + "\n", + "En el código que escribas puedes (y debes) incluir comentarios explicativos.\n", + "\n", + "Los comentarios no son interpretados por el interprete de Python y no afectan al código ni a su ejecución.\n", + "\n", + "Puedes usar el símbolo \\# para añadir un comentario al principio o al final de una línea (como ya has visto en este tutorial).\n", + "\n", + "Además, si necesitas hacer un comentario de varias líneas basta con que lo encierres en triples comillas ' ' ' o \" \" \".\n", + "\n", + "Ejemplos:\n" + ], + "metadata": { + "id": "NZjQEM3MOJGX" + } + }, + { + "cell_type": "code", + "source": [ + "# inicialización de variables (este es un comentario de una línea)\n", + "a = 10\n", + "b = 20\n", + "\n", + "''' En este comentario de varias líneas\n", + "voy a explicar lo que hago a continuación:\n", + "sumaré los valores de a y b y si suman más de 25\n", + "mostraré un mensaje de éxito por pantalla '''\n", + "\n", + "if a + b > 25:\n", + " print('¡Éxito!') # este será mi mensaje de éxito" + ], + "metadata": { + "id": "HtJvtFjbgbMA" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 12. Funciones\n", + "\n", + "Tanto para estructurar nuestro código así como para favorecer la reutilización del mismo se utilizan funciones.\n", + "\n", + "Las funciones nos permiten encapsular un fragmento de código y darle un nombre.\n", + "\n", + "Para definir una función usamos la palabra reservada \"def\" a continuación el nombre de la función y los parámetros que necesitemos entre paréntesis. La función puede devolver uno o varios valores si lo necesita (o ninguno).\n", + "\n", + "Después se puede invocar una función creada a través de su nombre." + ], + "metadata": { + "id": "QWnzNyKROJSs" + } + }, + { + "cell_type": "code", + "source": [ + "def suma(a, b):\n", + " return a + b\n", + "\n", + "\n", + "# min y max son funciones integradas en Python que nos devuelven\n", + "# los valores mínimo y máximo de un iterable (como las listas o las tuplas)\n", + "def min_y_max(lista):\n", + " return min(lista), max(lista)\n", + "\n", + "\n", + "# ahora vamos a usar estas funciones\n", + "valor = suma(10, 15)\n", + "print(valor)\n", + "\n", + "minimo, maximo = min_y_max([30, 10, 50, 40, 20])\n", + "print(f'min y max son {minimo} y {maximo}')\n" + ], + "metadata": { + "id": "DD5-_oeLsiNX" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 13. Bucles\n", + "\n", + "Los bucles son un mecanismo de control de flujo que nos permite repetir un fragmento de código un número determinado de veces.\n", + "\n", + "Hay dos tipos:\n", + "\n", + "\n", + "1. while, que nos permite controlar mediante una condición el número de repeticiones.\n", + "2. for, que nos permite iterar por los elementos de una colección de manera sencilla y cómoda.\n", + "\n", + "El código que queremos repetir, también llamado \"cuerpo del bucle\" debe indentarse tras el for o el while.\n", + "\n" + ], + "metadata": { + "id": "yJaf1DpiOJeh" + } + }, + { + "cell_type": "code", + "source": [ + "# ejemplo de while\n", + "a = 0\n", + "\n", + "while (a < 10): # mientras a sea < 10 el cuerpo del bucle se repetirá\n", + " print(a)\n", + " a = a + 1 # sumamos 1 a la variable a para asegurarnos de que la condición del bucle será False en algún momento\n", + "\n", + "# ejemplo de for\n", + "lista = [10, 20, 30, 40]\n", + "\n", + "for elemento in lista:\n", + " print(elemento)\n", + "\n" + ], + "metadata": { + "id": "lIfvC-pN_QhY" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "Dentro de los bucles puedes utilizar las sentencias de control break y continue:\n", + "* break termina anticipadamente el bucle\n", + "* continue interrumpe la vuelta actual del bucle y continúa con la siguiente." + ], + "metadata": { + "id": "6_U1A3i9AEdq" + } + }, + { + "cell_type": "markdown", + "source": [ + "# 14. Notación de porciones\n", + "\n", + "Cuando tenemos una colección de elementos indexados por posición (como una lista o una tupla), podemos acceder a una porción concreta utilizando la notación de porciones.\n", + "\n", + "Se utilizan los corchetes entre los que indicamos tres números separados por el carácter ':'. De esta manera\n", + "\n", + "lista\\[ini:fin:paso\\]\n", + "\n", + "Donde:\n", + "* ini es la posición del elemento primero en nuestra porción.\n", + "* fin es la posición del elemeto último (no incluido) de nuestra porción (el último incluido será el correspondiente a la posición fin -1).\n", + "* paso (optativo) indica la manera en la que tomaremos la porción: si es un número positivo tomaremos los elementos en el orden en el que aparecen, si es negativo los tomaremos en orden inverso (fin tiene que ser anterior a ini). Si la magnitud es 1, tomaremos todos los elementos, si es 2, tomaremos uno y saltaremos otro, si es 3, tomaremos uno y saltaremos 2, etc.\n", + "\n", + "Si dejamos ini o fin sin indicar se interpreta que la porción se toma desde el comienzo o el final respectivamente.\n", + "\n", + "Veamos algunos ejemplos:\n" + ], + "metadata": { + "id": "WQw19GRlOJrp" + } + }, + { + "cell_type": "code", + "source": [ + "lista = [10, 20, 30, 40, 50, 60]\n", + "\n", + "print(lista[2:5]) # tomamos del 2 al 5 (sin incluir el 5)\n", + "print(lista[4:]) # tomamos del 4 hasta el final\n", + "print(lista[:2]) # tomamos desde el principio hasta el 2 (sin incluir)\n", + "print(lista[1:6:2]) # tomamos 1 de cada 2 elementos desde el 1 hasta el 6 (sin incluir)\n", + "print(lista[4:1:-1]) # tomamos en orden inverso desde el 4 al 1 (sin incluir)\n", + "print(lista[:]) # tomamos desde el principio hasta el final (es como hacer una copia de la lista)\n", + "print(lista[::-1]) # tomamos desde el final hasta el principip (orden inverso) " + ], + "metadata": { + "id": "rxqQW9h2Hvja" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# 15. Entrada por teclado\n", + "\n", + "Si necesitamos hacer un programa o script interactivo, a menudo necesitaremos pedir algún valor al usuario por teclado.\n", + "\n", + "Python nos proporciona la función integrada \"input\" que nos sirve precisamente para eso. Al ejecutarse \"input\" el programa se queda esperando a que el usuario introduzca un valor y pulse intro. Posteriormente ese valor se guarda en la variable que queramos en formato string.\n", + "\n", + "Podemos hacer la conversión a un tipo numérico si así lo deseamos llamando a las funciones int o float." + ], + "metadata": { + "id": "BBXUukIZOJ3n" + } + }, + { + "cell_type": "code", + "source": [ + "entrada = input('Dame tu nombre, por favor: ')\n", + "print(f'¡Hola, {entrada}!')\n", + "entrada = input('Dame un número entero, por favor: ')\n", + "numero = int(entrada) # convertimos entrada a int\n", + "print(f'El número es {numero}')" + ], + "metadata": { + "id": "RnvW1ddeJU-1" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "# Ejercicio final: juego de adivinar un número entre 1 y 10\n", + "\n", + "Para finalizar este tutorial, voy a realizar un pequeño juego en el que el usuario tiene que adivinar un número generado al azar entre 1 y 10 y en el que solo tendrá 3 intentos para hacerlo.\n", + "\n", + "Para esto voy a utilizar muchas de las cosas contadas arriba. Además, comentaré el código para que todo quede perfectamente claro. Léelo con calma intentando comprender cada línea.\n", + "\n", + "Y, por supuesto, ¡puedes ejecutarlo para jugar tú!\n" + ], + "metadata": { + "id": "XCN38-bphFTC" + } + }, + { + "cell_type": "code", + "source": [ + "import random # necesitamos esta librería para poder generar un número al azar\n", + "\n", + "numero_secreto = random.randint(1, 10) # esto nos genera un número aleatorio entre 1 y 10\n", + "oportunidades = 3 # el número de oportunidades que nos quedan\n", + "acertado = False # esta variable nos servirá para saber si el usuario ha acertado\n", + "\n", + "print('* Bienvenido a nuestro pequeño juego del Tutorial Básico Interactivo de Código Pitón')\n", + "print() # imprimimos por pantalla una línea en blanco\n", + "print('Acabo de pensar un número secreto entre 1 y 10. Tienes tres oportunidades para')\n", + "print('adivinarlo. Te iré guiando un poco hacia la solución. ¡Suerte!')\n", + "print()\n", + "\n", + "# Hacemos un bucle mientras queden oportunidades y mientras no se haya acertado el número secreto\n", + "while oportunidades > 0 and not acertado:\n", + " \n", + " # Pedimos un número al usuario (y transformamos lo que escriba a entero mediante la función int)\n", + " # ¡Cuidado! Si lo que escribe el usuario no es un entero el programa generará un error\n", + " # El error puede ser controlado con try-except como vimos más arriba\n", + " numero = int(input('Dime un número entre 1 y 10: '))\n", + "\n", + " # Ahora vamos a hacer la comprobación\n", + " # e indicamos al usuario si el número secreto es mayor, menor o si lo ha averiguado\n", + " if numero < numero_secreto:\n", + " print('Te has quedado corto, el número secreto es más grande.')\n", + " elif numero > numero_secreto:\n", + " print('Te has pasado, el número secreto es más pequeño.')\n", + " else:\n", + " print(f'¡Enhorabuena! Has acertado en el intento {4-oportunidades}.')\n", + " acertado = True # ponemos acertado a cierto para que se detenga el bucle\n", + "\n", + " if not acertado: # si no ha acertado indicamos las oprtunidades que le quedan\n", + " oportunidades = oportunidades - 1 # restamos 1 a las oportunidades\n", + " print(f'Te quedan {oportunidades} oportunidades.')\n", + "\n", + " print()\n", + "\n", + "# cuando termine el bucle de juego mostramos el número de adinivinar\n", + "# y nos despedimos del usuario\n", + "\n", + "if not acertado: # si no se acierta el número se muestra por pantalla\n", + " print(f'* El número secreto era {numero_secreto}.')\n", + "\n", + "print('* ¡Gracias por jugar! ¡Hasta pronto!') \n", + "\n" + ], + "metadata": { + "id": "8hziKM46ho_K" + }, + "execution_count": null, + "outputs": [] + }, + { + "cell_type": "markdown", + "source": [ + "**¡Muchas gracias por haber usado este tutorial!**\n", + "\n", + "Recurre a él todas las veces que te haga falta hasta que te queden claros sus conceptos.\n", + "\n", + "Y no dejes de visitar [Código Pitón](https://www.codigopiton.com/).\n", + "\n", + "Un saludo,\n", + " \n", + "Juan.-\n", + "\n", + "P.S. ¿Te atreves a modificar el juego que hemos visto para que al terminar el juego el programa le pregunte al usuario si quiere volver a jugar? Si el usuario dice que sí, se vuelve a \"pensar\" un número secreto y se juega de nuevo. Si el usuario dice que no, se termina el programa." + ], + "metadata": { + "id": "0MrEzDjjnuD8" + } + } + ] +} \ No newline at end of file From 6ae55380ac4331d6dc8b6325fc27c3bc6381a3d9 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sun, 22 Jan 2023 02:36:24 -0300 Subject: [PATCH 02/16] =?UTF-8?q?Actualizaci=C3=B3n=20220123?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- Workbench/Taller/Apuntes01.ipynb | 80 ++++ Workbench/Taller/EstructurasControl.py | 1 + Workbench/Taller/Funciones | 33 ++ Workbench/Taller/Hello-world.py | 2 + Workbench/Taller/Mix_ejercicios.py | 634 +++++++++++++++++++++++++ Workbench/Taller/aritmetica.py | 22 + Workbench/Taller/comment.py | 16 + Workbench/Taller/datatypes.py | 51 ++ Workbench/Taller/listas.py | 77 +++ Workbench/Taller/variables.py | 11 + 10 files changed, 927 insertions(+) create mode 100644 Workbench/Taller/Apuntes01.ipynb create mode 100644 Workbench/Taller/EstructurasControl.py create mode 100644 Workbench/Taller/Funciones create mode 100644 Workbench/Taller/Hello-world.py create mode 100644 Workbench/Taller/Mix_ejercicios.py create mode 100644 Workbench/Taller/aritmetica.py create mode 100644 Workbench/Taller/comment.py create mode 100644 Workbench/Taller/datatypes.py create mode 100644 Workbench/Taller/listas.py create mode 100644 Workbench/Taller/variables.py diff --git a/Workbench/Taller/Apuntes01.ipynb b/Workbench/Taller/Apuntes01.ipynb new file mode 100644 index 000000000..a07c97eb9 --- /dev/null +++ b/Workbench/Taller/Apuntes01.ipynb @@ -0,0 +1,80 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 1, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Hello World\n" + ] + } + ], + "source": [ + "print (\"Hello World\")" + ] + }, + { + "cell_type": "code", + "execution_count": 1, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "página1\n", + "página2\n", + "página3\n", + "página4\n" + ] + } + ], + "source": [ + "libro = ['página1', 'página2', 'página3', 'página4']\n", + "marcapaginas = iter(libro)\n", + "print(next(marcapaginas))\n", + "print(next(marcapaginas))\n", + "print(next(marcapaginas))\n", + "print(next(marcapaginas))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.10.6" + }, + "orig_nbformat": 4, + "vscode": { + "interpreter": { + "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" + } + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/Workbench/Taller/EstructurasControl.py b/Workbench/Taller/EstructurasControl.py new file mode 100644 index 000000000..36623ca54 --- /dev/null +++ b/Workbench/Taller/EstructurasControl.py @@ -0,0 +1 @@ +# Uso de IF/ELIF/ELSE, FOR, WHILE, otros ciclos diff --git a/Workbench/Taller/Funciones b/Workbench/Taller/Funciones new file mode 100644 index 000000000..41dcd2983 --- /dev/null +++ b/Workbench/Taller/Funciones @@ -0,0 +1,33 @@ + +def misuma (a,b): + return a+b + +res= misuma (2,3) +print (res) + +def suma(a, b): + return a + b + + + +# min y max son funciones integradas en Python que nos devuelven +# los valores mínimo y máximo de un iterable (como las listas o las tuplas) +def min_y_max(lista): + return min(lista), max(lista) + + +# ahora vamos a usar estas funciones +valor = suma(10, 15) +print(valor) + +minimo, maximo = min_y_max([30, 10, 50, 40, 20]) +print(f'min y max son {minimo} y {maximo}') + +""" +def test_OrdenarDiccionario_03(self): + dicc = {'clave1':['c','a','b'], 'clave2':['casa','auto','barco'], 'clave3':[3,1,2]} + valor_test = ch.OrdenarDiccionario(dicc, 'clave3', False) + valor_esperado = {'clave1':['b','a','c'], 'clave2':['barco','auto','casa'], 'clave3':[3,2,1]} + """ + +""" \ No newline at end of file diff --git a/Workbench/Taller/Hello-world.py b/Workbench/Taller/Hello-world.py new file mode 100644 index 000000000..c7a3e0986 --- /dev/null +++ b/Workbench/Taller/Hello-world.py @@ -0,0 +1,2 @@ +print ("Hello World") +print ("hello", "world", 2023) diff --git a/Workbench/Taller/Mix_ejercicios.py b/Workbench/Taller/Mix_ejercicios.py new file mode 100644 index 000000000..c7df605fb --- /dev/null +++ b/Workbench/Taller/Mix_ejercicios.py @@ -0,0 +1,634 @@ +Variables +a = 'Hola ' +b = 'Mundo !' +print(a + b) +# Hola Mundo ! +x = 3 +y = 12 +print(x + y) +15 +print(a + x) +""" +"---------------------------------------------------------------------------" + +TypeError Traceback (most recent call last) +~\AppData\Local\Temp/ipykernel_18232/136165486.py in +----> 1 print(a + x) + +TypeError: can only concatenate str (not "int") to str +""" +# Dividir "y" entre "x" +y = 9 +x = 3 +print(y/x) +3.0 +# Potencia de "y" elevado a la "x" +y = 2 +x = 4 +print(y**x) +16 +# Devolver el resto de la división +y = 13 +x = 3 +print(y%x) +1 +# Ciclo IF/ELIF/ELSE +valor = 0 +if (valor < 0): + print('El número es negativo') +elif (valor > 0): + print('El número es positivo') +else: + print('El número es igual a cero') +# El número es igual a cero + +# Ciclo FOR - Caso 1 +for n in range(1,10): #Incluye el primero y excluye el último + print(n, end(", ")) + +# Ciclo WHILE +n = 1 +while (n < 10): + print(n) + n = n + 1 +""" +1 +2 +3 +4 +5 +6 +7 +8 +9 +""" +# Lista + +# Caso 1 - Inicializa una lista y muestra la cantidad de elementos + +edad = (3,1,0.2,8,7) #Declara un objeto lista y le asigna elementos +print (len(edad)) #Imprime la cantidad de elementos de la lista usando la función LEN +#5 # La función retorno 5 + +# Caso 2 - Identificar el tipo de variable usando la función TYPE, retorno el tipo de dato +mi_lista = ['Rojo','Azul','Amarillo','Naranja','Violeta','Verde'] +type(mi_lista) +# list +print(mi_lista) +['Rojo', 'Azul', 'Amarillo', 'Negro', 'Naranja', 'Violeta', 'Verde'] +print(mi_lista[0:2]) +['Rojo', 'Azul'] +print(mi_lista[:2]) +['Rojo', 'Azul'] +print(mi_lista[1:]) +['Azul', 'Amarillo'] +mi_lista.insert(3,'Negro') +print(mi_lista.index('Azul')) +# 1 +mi_lista.insert(3,'Negro') +mi_lista.extend(['Marrón','Gris']) +print(['a','b','c'] * 3) +# ['a', 'b', 'c', 'a', 'b', 'c', 'a', 'b', 'c'] +print(mi_lista.index('Azul')) +# 1 +mi_lista.remove('Blanco') + +""" +--------------------------------------------------------------------------- +ValueError Traceback (most recent call last) +~\AppData\Local\Temp/ipykernel_10044/2480624766.py in +----> 1 mi_lista.remove('Blanco') + +ValueError: list.remove(x): x not in list +mi_lista.remove('Negro') +--------------------------------------------------------------------------- +ValueError Traceback (most recent call last) +~\AppData\Local\Temp/ipykernel_10044/298389232.py in +----> 1 mi_lista.remove('Negro') + +ValueError: list.remove(x): x not in list +""" +ultimo = mi_lista.pop() +ultimo = mi_lista.pop() +print(ultimo) +# Gris +ultimo = mi_lista.pop() +ultimo +# 'Amarillo' +mi_tupla=tuple(mi_lista) +print(mi_tupla[1]) +# Azul +'Rojo' in mi_tupla +# True +mi_tupla.count('Rojo') +# 1 +print(mi_lista[:] * 3) +# ['Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris', 'Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris', 'Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris'] +mi_tupla.count('Rojo') +# 1 +mi_tupla='Gaspar', 5, 8, 1999 +nombre, dia, mes, año = mi_tupla +print("Nombre: ", nombre, " - Dia:", dia, " - Mes: ", mes, " - Año: ", año) +# Nombre: Gaspar - Dia: 5 - Mes: 8 - Año: 1999 +nombre = 'Darío' +edad = 39 +print(nombre, edad) +print("Mi nombre es", nombre, ". Mi edad es", edad, "años") +print("Mi nombre es {}. Mi edad es {} años". format(nombre, edad)) +# Darío 39 +# Mi nombre es Darío . Mi edad es 39 años +# Mi nombre es Darío. Mi edad es 39 años + +mi_diccionario = { 'Colores Primarios': ['Rojo','Azul','Amarillo'], + 'Colores secundarios': ['Naranja','Violeta','Verde'], + 'Clave3': 10, + 'Clave4': False} +print(mi_diccionario['Colores secundarios']) +# ['Naranja', 'Violeta', 'Verde'] + +mi_diccionario={'Clave1':'Valor1', 'Clave2':{'numeros':[1,2,3,4,5]}} +print(mi_diccionario.keys()) +# dict_keys(['Clave1', 'Clave2']) +print(mi_diccionario.values()) +# dict_values(['Valor1', {'numeros': [1, 2, 3, 4, 5]}]) +len (mi_diccionario) +# 2 + +edad = 60 +edad_compa = 50 +if (edad < edad_compa): + print(edad) + if (edad < 100): + print(edad + 100) + else: + print(edad - 100) +else: + print(edad_compa) +# 50 + +primeros_10 = [0,1,2,3,4,5,6,7,8,9] +print(primeros_10) +# [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] + +for n in primeros_10: + if (n%2 == 0): + print(n) + primeros_10[n]=0 +print("\va de nuevo....\n") +""" +0 +2 +4 +6 +8 +# va de nuevo.... +""" + +print(primeros_10) +# [0, 1, 0, 3, 0, 5, 0, 7, 0, 9] + +for n in primeros_10: + print(primeros_10[n]) +print("\va de nuevo....\n") +""" +0 +1 +0 +3 +0 +5 +0 +7 +0 +9 +va de nuevo.... +""" + +print(primeros_10[9]) +# 9 +primeros_10 = ['a','b','c','d'] +primeros_10[4] +""" +--------------------------------------------------------------------------- +IndexError Traceback (most recent call last) + in +----> 1 primeros_10[4] + +IndexError: list index out of range +""" +n = 40 +sequence = [0,1] +for i in range(2,n): + sequence.append(sequence[i-1]+sequence[i-2]) +print (sequence) +# [0, 1, 1, 2, 3, 5, 8, 13, 21, 34, 55, 89, 144, 233, 377, 610, 987, 1597, 2584, 4181, +# 6765, 10946, 17711, 28657, 46368, 75025, 121393, 196418, 317811, 514229, 832040, 1346269, +# 2178309, 3524578, 5702887, 9227465, 14930352, 24157817, 39088169, 63245986] + +mi_diccionario = { 'Colores Primarios': ['Rojo','Azul','Amarillo'], + 'Colores secundarios': ['Naranja','Violeta','Verde'], + 'Clave3': 10, + 'Clave4': False} +print(mi_diccionario['Colores secundarios']) +# ['Naranja', 'Violeta', 'Verde'] + +mi_diccionario['Clave3']=2 + +mi_diccionario +{'Argentina': 'Buenos Aires', 'Italia': 'Roma', 'Inglaterra': 'Londres'} +mi_diccionario['Clave5']='Otro ejemplo' +mi_tupla=("Argentina", "Italia", "Inglaterra") +mi_diccionario={mi_tupla[0]:"Buenos Aires", mi_tupla[1]:"Roma", mi_tupla[2]:"Londres"} +mi_diccionario={'Clave1':'Valor1', 'Clave2':(1,2,3,4,5)} +type(mi_diccionario['Clave2']) +# tuple +mi_diccionario={'Clave1':'Valor1', 'Clave2':{'numeros':[1,2,3,4,5]}} +type(mi_diccionario['Clave2']) +# dict +mi_diccionario={'Clave1':'Valor1', 'Clave2':[1,2,3,4,5]} +type(mi_diccionario['Clave2']) +# list +print(mi_diccionario.keys()) +# dict_keys(['Clave1', 'Clave2']) +print(mi_diccionario.values()) +# dict_values(['Valor1', [1, 2, 3, 4, 5]]) +len(mi_tupla) +# 3 + +def imprimir_valor_variable(var): + print('El valor de la variable es' + str(var)) +imprimir_valor_variable(mi_lista) +# El valor de la variable es['Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris'] + +def ordenar_dos_numeros(num1, num2): + if (num1 > num2): + return num2, num1 + else: + return num1, num2 + +ordenar_dos_numeros(8,1) +# (1, 8) + +def factorial(numero): +# Devuelve el factorial + if (numero > 1): + numero = numero * factorial(numero - 1) + return numero + +factorial(3) +# 6 +#help(factorial) +#Help on function factorial in module __main__: + +#factorial(numero) +# Devuelve el factorial + +def dividir(dividendo, divisor = 1): + if (divisor == 0): + return 'No se puede dividir por cero' + else: + return dividendo / divisor +print(dividir(10)) +# 10.0 +print(divisor) +""" +--------------------------------------------------------------------------- +NameError Traceback (most recent call last) +~\AppData\Local\Temp/ipykernel_10044/1862935505.py in +----> 1 print(divisor) + +NameError: name 'divisor' is not defined +""" + +divisor = 5 +def dividir(dividendo): + if (divisor == 0): + return 'No se puede dividir por cero' + else: + return dividendo / divisor +print(dividir(10)) +# 2.0 +print(divisor) +# 5 + +divisor = 5 + +def dividir(dividendo, divisor = 1): + if (divisor == 0): + return 'No se puede dividir por cero' + else: + return dividendo / divisor + +print(dividir(10)) +# 10.0 + +print(divisor) +# 5 + +lambda_producto = lambda x, y: x * y +lambda_producto(3, 4) +# 12 + +class Animal: + ''' + En esta clase se crean los animales + ''' + def __init__(self, especie, edad, color): + self.especie = especie + self.edad = edad + self.color = color + def mePresento(self): + print('Hola, soy ', self.especie, ', de color', self.color, ' y tengo ', self.edad, ' años') + def cumplirAños(self): + self.edad = self.edad + 1 + +a1 = Animal('Ratón', 2, 'Marrón') + +print(a1.especie) +print(a1.edad) + +a2 = Animal('Liebre', 3, 'Gris') +print(a2.especie) +print(a2.edad) +# Ratón +# 2 +# Liebre +# 3 + +a1.mePresento() +# Hola, soy Ratón , de color Marrón y tengo 2 años +a2.mePresento() +# Hola, soy Liebre , de color Gris y tengo 3 años +a1.cumplirAños() +a1.mePresento() +# Hola, soy Ratón , de color Marrón y tengo 3 años + +# Caja Negra +import unittest +def suma(num_1, num_2): + return num_1 + num_2 +class CajaNegraTest(unittest.TestCase): + + def test_suma_dos_positivos(self): + num_1 = 10 + num_2 = 5 + + resultado = suma(num_1, num_2) + + self.assertEqual(resultado, 15) + + def test_suma_dos_negativos(self): + num_1 = -10 + num_2 = -7 + + resultado = suma(num_1, num_2) + + self.assertEqual(resultado, -17) + +unittest.main(argv=[''], verbosity=2, exit=False) + +""" +" test_suma_dos_negativos (__main__.CajaNegraTest) ... ok +" test_suma_dos_positivos (__main__.CajaNegraTest) ... ok + +---------------------------------------------------------------------- +Ran 2 tests in 0.004s + +OK + +if __name__ == '__main__': + unittest.main() +""" +#Caja de Cristal + +import unittest + +def es_mayor_de_edad(edad): + if edad >= 18: + return True + else: + return False + +class PruebaDeCristalTest(unittest.TestCase): + + def test_es_mayor_de_edad(self): + edad = 20 + + resultado = es_mayor_de_edad(edad) + + self.assertEqual(resultado, True) + + def test_es_menor_de_edad(self): + edad = 15 + + resultado = es_mayor_de_edad(edad) + + self.assertEqual(resultado, False) + +unittest.main(argv=[''], verbosity=2, exit=False) + +""" +test_suma_dos_negativos (__main__.CajaNegraTest) ... ok +test_suma_dos_positivos (__main__.CajaNegraTest) ... ok +test_es_mayor_de_edad (__main__.PruebaDeCristalTest) ... ok +test_es_menor_de_edad (__main__.PruebaDeCristalTest) ... ok + +---------------------------------------------------------------------- +Ran 4 tests in 0.006s + +OK + +if __name__ == '__main__': + unittest.main() +""" + +# Python + +def busca_pais(paises, pais): +# Paises es un diccionario. Pais es la llave. +# Codigo con el principio EAFP (Easier to Ask Forgiveness than Permission/Mejor pedir perdón que pedir permiso) +# Otro LBYL (Look Before You Leap/Piensa antes de actuar 🤐). + + try: + return paises[pais] + except KeyError: + return None + +def divide_elementos_de_lista(lista, divisor): + + ''' + Cada elemento de una lista es dividida por un divisor definido. + En caso de error de tipo ZeroDivisionError que + significa error al dividir en cero + la función devuelve la lista inicial + ''' + try: + return [i / divisor for i in lista] + + except ZeroDivisionError as e: + print(e) + return lista + +lista = list(range(10)) +divisor = 0 + +print(divide_elementos_de_lista(lista, divisor)) +# division by zero +# [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] + +divisor = 3 +print(divide_elementos_de_lista(lista, divisor)) +# [0.0, 0.3333333333333333, 0.6666666666666666, 1.0, 1.3333333333333333, +# 1.6666666666666667, 2.0, 2.3333333333333335, 2.6666666666666665, 3.0] + +lista = [5, 4, 9, 2] +i = 0 +while i < len(lista): + elemento = lista[i] + print(elemento) + i += 1 + +""" +5 +4 +9 +2 +""" + +lista = [5, 4, 9, 2] +for elemento in lista: + print(elemento) + +""" +5 +4 +9 +2 +""" +from collections import Iterable +cadena = "Hola" +numero = 3 +print("cadena", isinstance(cadena, Iterable)) +print("numero", isinstance(numero, Iterable)) + +""" +cadena True +numero False +C:\Users\lopez\AppData\Local\Temp/ipykernel_10044/1562366592.py:1: DeprecationWarning: Using or importing the ABCs from 'collections' instead of from 'collections.abc' is deprecated since Python 3.3, and in 3.10 it will stop working + from collections import Iterable +""" + +print(list("Hola")) +# ['H', 'o', 'l', 'a'] +print(sum([1, 2, 3])) +# 6 +print("-".join("Hola")) +# H-o-l-a + +mi_dict = {'a':1, 'b':2, 'c':3} +for i in mi_dict: + print(i) +""" +a +b +c +""" + +libro = ['página1', 'página2', 'página3', 'página4'] +marcapaginas = iter(libro) +print(next(marcapaginas)) +print(next(marcapaginas)) +print(next(marcapaginas)) +print(next(marcapaginas)) +""" +página1 +página2 +página3 +página4 +print(next(marcapaginas)) +--------------------------------------------------------------------------- +StopIteration Traceback (most recent call last) +~\AppData\Local\Temp/ipykernel_10044/1391636315.py in +----> 1 print(next(marcapaginas)) + +StopIteration: +14 % 3 +2 +14 // 3 +4 +""" +a = [1,2] +b = a.copy() +b.append(3) +print(a) +# [1, 2] + +print(b) +# [1, 2, 3] +b.append(4) +print(a) +# [1, 2, 3] +print(b) +# [1, 2, 3, 4] +x = 7 +# 7 & 7 +# 2 +print(x) +# 2 +a = [1, 2] +b = ["Uno", "Dos"] +c = zip(a, b) +type(c) +# zip +list(c) +[(1, 'Uno'), (2, 'Dos')] +frase = "El perro de san roque no tiene rabo" +errores = [i for i in frase if i == 'r'] +print(errores) +# ['r', 'r', 'r', 'r'] +n = 40 +sequence = [0,1] +for i in range(2,n): + sequence.append(sequence[i-1]+sequence[i-2]) + print (sequence) + +"""2 +3 +4 +5 +6 +7 +8 +9 +10 +11 +12 +13 +14 +15 +16 +17 +18 +19 +20 +21 +22 +23 +24 +25 +26 +27 +28 +29 +30 +31 +32 +33 +34 +35 +36 +37 +38 +39 +4 << 1 +8""" \ No newline at end of file diff --git a/Workbench/Taller/aritmetica.py b/Workbench/Taller/aritmetica.py new file mode 100644 index 000000000..7fd04e8f3 --- /dev/null +++ b/Workbench/Taller/aritmetica.py @@ -0,0 +1,22 @@ +#print (3.5 // 4) +#print ("7"+"0") +#print (int("7"+"0")/2) #Este es un ejemplo de casteo +#print ( 2**1 / 12) +#print (4*9) +#Intersante como se pueden declarar variables +""" +a, b, c, d = 26, 11.3, 5, 3.5 +print (a) +print (c) +print (b) +print (d) +print (type (a)) +print (type (b)) +print (type (d)) +""" +#print (4*9) +#print (2+4) +print (30%10) +i = 5 +i -= 1 +print(i) # 4 \ No newline at end of file diff --git a/Workbench/Taller/comment.py b/Workbench/Taller/comment.py new file mode 100644 index 000000000..e26328386 --- /dev/null +++ b/Workbench/Taller/comment.py @@ -0,0 +1,16 @@ +# Este es un comentario en Python +print ("This is an example of comments") +print ("also, this is an other example of comments") +print ("comments are preceded by a hash symbol #") +print ("and other way to do this it's preceeding a paragraph") +print ("by 3 dots at the beginig, and 3 at the end") + +"""este es un ejemplo de comentarios en varias líneas +es otra forma para organizar textos largos...""" +''' +otro +ejemplo +de lineas +múltiple +''' +print ("fin de los comments") \ No newline at end of file diff --git a/Workbench/Taller/datatypes.py b/Workbench/Taller/datatypes.py new file mode 100644 index 000000000..41f532a07 --- /dev/null +++ b/Workbench/Taller/datatypes.py @@ -0,0 +1,51 @@ +#On this file we going to learn about different data types +#Boolean, int, float, cmplex mumbers +#Boolean true or false +#String, list (dictionary +current_year=2023 +print (current_year) +next_year=current_year+1 +print (next_year) +print (type (current_year)) +print(type (3.14)) +print (type (1+2j)) +print (type (9.81)) +#a = input ("Ingresa un texto") +#print ("El texto ingresado es", a) +#converting data type e.g int to float o vs +print (int(9.81)) +print (round (9.81)) +#BOOLEAN CASES +enjoying_lesson=True +is_light_on=True +is_single=False +value = 3 < 2 #almacena el valor lógico de la expresión +print (value) +#STRINGS ==> Son datos almacenados del tipo cadena de texto +#Concatenación se suman las variables de texto +firstname = "Jota" +print (firstname) +lastname="Cordova" +print (lastname) +print (firstname+" "+ lastname) +country = "Finland" +print (country) +#Recordar +fullname = firstname + " "+lastname +print (fullname,", aquí usamos la variable concatenada") +print (type (firstname)) +print (country.upper()) #métodos de la clase print +print (fullname.title()) +#LIST ==> It's a list of something, could be task, groceries +empty_list1 = list() #dos formas de inicializar listas +empty_list2 = [] #la nombro y luego declaro como list() +# la nombre y asigno una lista vacia con corchetes [] +print (empty_list1, "esta es la lista 1") +print (empty_list2, "esta es la lista 2") +numbers = [1,2,3,4,5,6] +groceries = ["tomato", "carrot", "letuce"] +print (groceries [0]) #el puntero va con corchete y parte de 0 +print (numbers [3]) #es una COLECCION +print (len(groceries)) #conocer el largo de la la lista con len +mix_of_data_types_list = [1, "Jota", lastname, 2+5, 1-3j, 3.14] +#podemos almacenar un mix de datos diff --git a/Workbench/Taller/listas.py b/Workbench/Taller/listas.py new file mode 100644 index 000000000..731dbf055 --- /dev/null +++ b/Workbench/Taller/listas.py @@ -0,0 +1,77 @@ +#Ejericio 1 + +listadeletras = [] # Crea un objeto list llamado lista +for unaletra in "paralelepipedo": # Define una variable car para recorrer el string "casa" + listadeletras.append(unaletra) # Agrega cada caracter del string en la lista +print(listadeletras) # Imprime los valores de la lista que son los caracteres de la palabra casa o pera, lo que sea + # Salida esperada ['c', 'a', 's', 'a'] + +""" +#Ejercicio 2 +# Lista de 4 elementos y para cada elemento calcularle la potencia de 2, usando el método tradicional, eso seria así: +#Alternativa 1 + +lista_potencias = [] #Crea una lista llamada "lista_potencias" +for i in range(4): #ciclo for para recorrer lista de 4 elementos, va de 0 a 3, el índice lo llamamos "i" + lista_potencias.append(i**2) #a la lista "lista_potencias", la voy poblando con el dato calculado. +print(lista_potencias) #Imprime los 4 valores almacendaos en la lista #Obs: como no cambié el nombre, concatenó los valores de la lista al final +# [0, 1, 4, 9] + +#Alternativa 2 +# Entonces el ejemplo anterior usando listas de comprensión, eso seria así: +lista_potencias2 = [i**2 for i in range(4)] +print ("Esta es la lista de potencias Nr2", lista_potencias2) +# [0, 1, 4, 9] + +#Ejercicio 3 +#Lista con las potencias de 2 de los primeros 10 números, método tradicional: +""" +""" +Método 3-1 +lista1_pot10_2 = [] #Creamos un objeto lista vacio [] +for num in range (0, 11): #incluye el primero y no el últimmo. Usando un ciclo FOR usando la var "num" en el tramo de 0-10, ambos incluidos + lista1_pot10_2.append (num**2) #Llenamos la lista con potencias PARTIENDO DE 0, a 10 (11-1) +print(lista1_pot10_2) + +#[4, 9, 16] +#[0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100] +#Método 3-2 +#Entonces el ejemplo anterior usando listas de comprensión, eso seria así: +#lista2_pot10_2 = [num2**2 for num2 in range(0, 11)] #Creamos la lista con los valores según condición +#print("Este es el método 3-2, para crear la lista de 10 números y sus potencias",lista2_pot10_2) +#[0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100] +#De este código anterior usted puede aprender que es posible modificar al vuelo los elementos los cuales van a formar la lista. + +# Ej +# Con este ejemplo se ve como funciona el conteo de posiciones en una lista (cada elemento es una posX) +lista = ["pos0", "pos1", "pos2", "pos3", "pos4", "pos5"] +print("Esta es la lista:\n", lista, "\n") +print("1° Mostrar 'lista[2:5]', significa la pos2, pero excluye la 5, ojo!\n", lista[2:5]) # tomamos del 2 al 5 (sin incluir el 5) +print("2° Mostrar 'lista[4:]', significa desde la pos4 hasta la última\n",lista[4:]) # tomamos del 4 hasta el final +print("3° Mostrar 'lista[:2]', significa desde el BOF hasta la pos2, excluye la pos2\n", lista[:2]) # tomamos desde el principio hasta el 2 (sin incluir) +print("4° Mostrar 'lista[1:6:2]', significa 1 por medio, desde la pos1, incluye la 5\n", lista[1:6:2]) # tomamos 1 de cada 2 elementos desde el 1 hasta el 6 (sin incluir) +print("5° Mostrar 'lista[4:1:-1]', significa orden desc de la pos4 a la 2, excluye la pos1",lista[4:1:-1]) +print("6° Mostrar 'lista[:]', significa mostrar todos los elementos de la lista\n",lista[:]) # tomamos desde el principio hasta el final (es como hacer una copia de la lista) +print("7° Mostrar 'lista[::-1]', significa mostrar todos los elementos de la lista en orden inverso\n",lista[::-1]) # tomamos desde el final hasta el principip (orden inverso) +""" +# EJ 5 +# Con este ejemplo usamos un truco para controlar la salida, un método de print llamado end +# +for i in range (15): + if i < 14: + print (i, end=", ") + else: + print (i) + +""" +# Ej 6 +# Mismo ejemplo sin controlar la salida, cada linea se ejecuta y se apilan. +#for i in range (15): +# print (i) +""" +""" +# Revisar formas de ordenar listas +lista_desordenada = (5,7,2,8,3,6) +print (lista_desordenada) +print (lista_desordenada.sort()) +""" \ No newline at end of file diff --git a/Workbench/Taller/variables.py b/Workbench/Taller/variables.py new file mode 100644 index 000000000..cb71de421 --- /dev/null +++ b/Workbench/Taller/variables.py @@ -0,0 +1,11 @@ +#Variables +#It's memory location to assign data to store and use ir later +a=10 +b=3 +print (a) + +print ("what's the value of a", a) +print ("what's the value of b", b) +print (a+b) +total =2+4 +print (total) \ No newline at end of file From 4bf5e17acc8ca378c99d3b28df2f1ef6367a0ab1 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sun, 22 Jan 2023 20:48:44 -0300 Subject: [PATCH 03/16] 220123...tratando de avanzar --- ...urse_Homework_03-Resuelto-checkpoint.ipynb | 12 +- ...ep_Course_Homework_03-Resuelto Clase.ipynb | 16 +- .../Prep_Course_Homework_03-Resuelto.ipynb | 12 +- Workbench/Taller/Apuntes01.ipynb | 2 +- Workbench/Taller/Ciclos.py | 26 +++ .../Taller/{comment.py => ComoComentar.py} | 0 Workbench/Taller/CrearMenu.py | 105 ++++++++++ Workbench/Taller/Diccionarios.py | 139 +++++++++++++ Workbench/Taller/Funciones | 59 +++--- Workbench/Taller/Matrices.py | 27 +++ Workbench/Taller/datatypes.py | 31 +-- Workbench/Taller/listas.py | 184 +++++++++++++----- Workbench/Taller/variables.py | 4 +- 13 files changed, 505 insertions(+), 112 deletions(-) create mode 100644 Workbench/Taller/Ciclos.py rename Workbench/Taller/{comment.py => ComoComentar.py} (100%) create mode 100644 Workbench/Taller/CrearMenu.py create mode 100644 Workbench/Taller/Diccionarios.py create mode 100644 Workbench/Taller/Matrices.py diff --git a/03 - Flujos de Control/.ipynb_checkpoints/Prep_Course_Homework_03-Resuelto-checkpoint.ipynb b/03 - Flujos de Control/.ipynb_checkpoints/Prep_Course_Homework_03-Resuelto-checkpoint.ipynb index 8b24b6405..24c961bd1 100644 --- a/03 - Flujos de Control/.ipynb_checkpoints/Prep_Course_Homework_03-Resuelto-checkpoint.ipynb +++ b/03 - Flujos de Control/.ipynb_checkpoints/Prep_Course_Homework_03-Resuelto-checkpoint.ipynb @@ -716,11 +716,8 @@ } ], "metadata": { - "interpreter": { - "hash": "c85384e4cb51c8b72350f3a8712cc8351fdc3955e32a27f9b60c6242ab125f01" - }, "kernelspec": { - "display_name": "Python 3.9.7 64-bit ('henry': conda)", + "display_name": "Python 3", "language": "python", "name": "python3" }, @@ -734,7 +731,12 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.9.7" + "version": "3.10.6 (tags/v3.10.6:9c7b4bd, Aug 1 2022, 21:53:49) [MSC v.1932 64 bit (AMD64)]" + }, + "vscode": { + "interpreter": { + "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" + } } }, "nbformat": 4, diff --git a/03 - Flujos de Control/Prep_Course_Homework_03-Resuelto Clase.ipynb b/03 - Flujos de Control/Prep_Course_Homework_03-Resuelto Clase.ipynb index ce4105c8d..e031e08b2 100644 --- a/03 - Flujos de Control/Prep_Course_Homework_03-Resuelto Clase.ipynb +++ b/03 - Flujos de Control/Prep_Course_Homework_03-Resuelto Clase.ipynb @@ -443,8 +443,8 @@ " num2 = num * num2\n", " num = num - 1\n", " print(num2) \n", - " else:\n", - " print('el número {num} es menor que 0') \n" + "else:\n", + " print('el número {num} es menor que 0') \n" ] }, { @@ -34589,11 +34589,8 @@ } ], "metadata": { - "interpreter": { - "hash": "c85384e4cb51c8b72350f3a8712cc8351fdc3955e32a27f9b60c6242ab125f01" - }, "kernelspec": { - "display_name": "Python 3 (ipykernel)", + "display_name": "Python 3", "language": "python", "name": "python3" }, @@ -34607,7 +34604,12 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.9.7" + "version": "3.10.6 (tags/v3.10.6:9c7b4bd, Aug 1 2022, 21:53:49) [MSC v.1932 64 bit (AMD64)]" + }, + "vscode": { + "interpreter": { + "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" + } } }, "nbformat": 4, diff --git a/03 - Flujos de Control/Prep_Course_Homework_03-Resuelto.ipynb b/03 - Flujos de Control/Prep_Course_Homework_03-Resuelto.ipynb index 39f94f511..f2e303cbf 100644 --- a/03 - Flujos de Control/Prep_Course_Homework_03-Resuelto.ipynb +++ b/03 - Flujos de Control/Prep_Course_Homework_03-Resuelto.ipynb @@ -716,11 +716,8 @@ } ], "metadata": { - "interpreter": { - "hash": "c85384e4cb51c8b72350f3a8712cc8351fdc3955e32a27f9b60c6242ab125f01" - }, "kernelspec": { - "display_name": "Python 3 (ipykernel)", + "display_name": "Python 3", "language": "python", "name": "python3" }, @@ -734,7 +731,12 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.9.7" + "version": "3.10.6 (tags/v3.10.6:9c7b4bd, Aug 1 2022, 21:53:49) [MSC v.1932 64 bit (AMD64)]" + }, + "vscode": { + "interpreter": { + "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" + } } }, "nbformat": 4, diff --git a/Workbench/Taller/Apuntes01.ipynb b/Workbench/Taller/Apuntes01.ipynb index a07c97eb9..7b28b9a52 100644 --- a/Workbench/Taller/Apuntes01.ipynb +++ b/Workbench/Taller/Apuntes01.ipynb @@ -66,7 +66,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.10.6" + "version": "3.10.6 (tags/v3.10.6:9c7b4bd, Aug 1 2022, 21:53:49) [MSC v.1932 64 bit (AMD64)]" }, "orig_nbformat": 4, "vscode": { diff --git a/Workbench/Taller/Ciclos.py b/Workbench/Taller/Ciclos.py new file mode 100644 index 000000000..bf1ab9a44 --- /dev/null +++ b/Workbench/Taller/Ciclos.py @@ -0,0 +1,26 @@ +print ("Inicio de números pares") +lista_p=[] # Creo lista pares, para poder imprimirlos hor. +lista_i=[] # Creo lista impares, para poder imprmirlos ver. +for par in range(0, 21, 2): # En el rango 0-20, cada 2, partiendo de 0 + lista_p.append(par) + print (par) +print(lista_p) # Escribe la lista vertical +print ("Fin de números pares") # Escribe la lista horizontal +print ("Inicio de números impares") +for impar in range(1, 21, 2): # En el rango 1-20, cada 2, partiendo de 1 + lista_i.append(impar) + print (impar) # Escrbe la lista vertical + # Escribe la lista horizontal +print(lista_i) +print ("Fin de números impares") +""" +"""# Dado un valor entero, ejecutar el mismo número de ciclos con un while +a= 5 +num=1 +while num < a+1: + #print ("a vale ", a) + #print ("num vale ", num) + print ("Este es el ciclo", num) + num=num+1 + + diff --git a/Workbench/Taller/comment.py b/Workbench/Taller/ComoComentar.py similarity index 100% rename from Workbench/Taller/comment.py rename to Workbench/Taller/ComoComentar.py diff --git a/Workbench/Taller/CrearMenu.py b/Workbench/Taller/CrearMenu.py new file mode 100644 index 000000000..ebe1a4193 --- /dev/null +++ b/Workbench/Taller/CrearMenu.py @@ -0,0 +1,105 @@ + +""" +def accion1(): + print('Has elegido la opción 1') + + +def accion2(): + print('Has elegido la opción 2') + + +def accion3(): + print('Has elegido la opción 3') + + +def salir(): + print('Saliendo') + +#Guardamos en en un diccionario de tuplas, la opción y la acción +opciones = { + '1': ('Opción 1', accion1), + '2': ('Opción 2', accion2), + '3': ('Opción 3', accion3), + '4': ('Salir', salir) +} + +def generar_menu(opciones, opcion_salida): + opcion = None + while opcion != opcion_salida: + mostrar_menu(opciones) + opcion = leer_opcion(opciones) + ejecutar_opcion(opcion, opciones) + print() # se imprime una línea en blanco para clarificar la salida por pantalla + +def mostrar_menu(opciones): + print('Seleccione una opción:') + for clave in sorted(opciones): + print(f' {clave}) {opciones[clave][0]}') + +def leer_opcion(opciones): + while (a := input('Opción: ')) not in opciones: + print('Opción incorrecta, vuelva a intentarlo.') + return a + +def ejecutar_opcion(opcion, opciones): + opciones[opcion][1]() + +def menu_principal(): + opciones = { + '1': ('Opción 1', accion1), + '2': ('Opción 2', accion2), + '3': ('Opción 3', accion3), + '4': ('Salir', salir) + } +generar_menu(opciones, '4')""" + +# Creamos funciones asociadas a cada acción del menú +# Tercer paso es unir la lógica y para ellos crearemos con tres objetivos: +# 1) Mostrar el menú al usuario +# 2) Pedir una opción al usuario y leer esa opción por teclado. +# 3) Ejecutar la opción correspondiente. + +def mostrar_menu(opciones): + print('Seleccione una opción:') + for clave in sorted(opciones): + print(f' {clave}) {opciones[clave][0]}') + +def leer_opcion(opciones): + while (a := input('Opción: ')) not in opciones: + print('Opción incorrecta, vuelva a intentarlo.') + return a + +def ejecutar_opcion(opcion, opciones): + opciones[opcion][1]() + +def generar_menu(opciones, opcion_salida): + opcion = None + while opcion != opcion_salida: + mostrar_menu(opciones) + opcion = leer_opcion(opciones) + ejecutar_opcion(opcion, opciones) + print() + +def menu_principal(): + opciones = { + '1': ('Opción 1', accion1), + '2': ('Opción 2', accion2), + '3': ('Opción 3', accion3), + '4': ('Salir', salir) + } + generar_menu(opciones, '4') + +def accion1(): + print('Has elegido la opción 1') + +def accion2(): + print('Has elegido la opción 2') + +def accion3(): + print('Has elegido la opción 3') + +def salir(): + print('Saliendo') + +if __name__ == '__main__': + menu_principal() \ No newline at end of file diff --git a/Workbench/Taller/Diccionarios.py b/Workbench/Taller/Diccionarios.py new file mode 100644 index 000000000..3479a15af --- /dev/null +++ b/Workbench/Taller/Diccionarios.py @@ -0,0 +1,139 @@ +#******************************************************************* +#* * +#* TEORIA DICCIONARIOS * +#* * +#******************************************************************* +# Un dict es una colección de pares, no ordenados, compuestos por una KEY y un VALUE (valor) +# La KEY debe ser HASHEABLE, INMUTABLE, ÚNICA, NO REPETIBLE, los valores pueden ser cualquier cosa MUTABLE. +# Un VALUE puede ser otro DICCIONARIO, TUPLA, LISTA, más los tipos clásicos, como BOOLEAN, etc. +# Otras caracteristicas: Similar al tipo MAPA en otros lenguajes, no confundir con función map(), +# aunque retorna un DICT. La funicón map() es para objetos iterables como listas. +# Método keys() => nom_dic.keys() retorna una clase especial llamada dict_keys, sólo nombra las keys, +# Para acceder a las KEYS, se debe pasar a LISTA ==> nom_var = list(nom_dic.keys()) +# para poder iterar sobre cada LLAVE +# Método clear() => Borra todos los elementos del diccionario mi_dic.clear(), retorna {} +# Método del(key) => Elimina un elemento con su clave, le paso la clave como parámetro +# Método values() => devuelve todos los VALORES +# Método dict.items()=> Retorna tuplas (clave, valor), también se pasa a list siguen siendo TUPLAS. +# Función in retorna bool si encuentra valor de una clave "mi_key" in "mi_dic" +# Sólo sirve para claves, y es un booleano, TRUE o FALSE, si quiero preguntar po un valor, agregro +# VALUE de esta forma "mi_valor" in "mi_dic.value". +# Recorridos en diccionarios + + + +# Inicialización de DICCIONARIOS (dict) +# El constructor dict y argumentos. Ej: dict(color='Azul', num=4) +# Constructor dict y pares de valores. Ej: dict([('color', 'Azul'), ('num', 4)]) +# Usando un literal de pares separados por ':' y rodeado por {}. Ej: {'color': 'Azul', 'num': 4} +# + +# Ejemplo 1 +# Este es un dic de 4 elementos o pares cualquiera str, int, str y str. +# Obtenemos sus claves y las pasamos a una lista +d = {1: 'str cualquiera', 89: 'soy un valor', 'clave a': 'b', 'clave c': 27} # Inicializa el dict +listkey_d = list(d.keys()) # Hay que convertirlo a lista para acceder a las keys como índice +print (listkey_d) # Ahora veo los índices y los puedo trabajar como LISTA +print ("'D' es del tipo ", type (d)) # Retorna +print ("'listkey_d' es del tipo ", type (listkey_d)) # Retorna , se ve la diferencia +print ("El nombre de la clave en la posición 1 es ", listkey_d [1], " y es de tipo", type(listkey_d [1])) +print ("El nombre de la clave en la posición 3 es ", listkey_d [3], " y es de tipo", type(listkey_d [3])) +print ("") + +# Ejemplo 2 +# Crea un diccionario con 4 pares lógicos, colores primarios, colores secundarios, clave 3 y clave 4 + +mi_dic = {'Colores Primarios': ['Rojo','Azul','Amarillo'], + 'Colores secundarios': ['Naranja','Violeta','Verde'], + 'Clave3': 10, + 'Clave4': False} +mi_dic_keys = list (mi_dic.keys()) # Obtenemos las keys y las pasamos a una list "mi_dic_keys" +print (mi_dic_keys) # Imprime la lista +print (type (mi_dic_keys)) # Imprime el tipo de la variable mi_dic_keys, retorna +print ("Los colores de la clave ", mi_dic_keys [1], "son ", mi_dic['Colores secundarios']) +print ("") +print (mi_dic.keys()) + +print ("Los colores de la clave ", mi_dic_keys [0], "son ", mi_dic['Colores Primarios']) +print ("El valor de la clave 3", mi_dic_keys [2], "es ", mi_dic['Clave3']) +print ("El valor de la clave 4", mi_dic_keys [3], "son ", mi_dic['Clave4']) + +# Ejemplo 3 +dd2 = dict (width=4, members=['1', False], name='Pepe') # 3 elementos, 1 int, 1 dict, un str +print ("El contenido de 'dd2' es ", dd2) # # Retorna {'width': 4, 'members': ['1', False], 'name': 'Pepe'} +print (dd2.values()) # Retorna 4, ['1', False], "Pepe" + + +# Ejemplo 4 +print("") +dict2 = {} # Inicializa un diccionario vacío +print ("El contenido de 'dict2' debe ser vacío ", dict2) # Mostrará {} +# El contenido de 'dict2' debe ser {} + +# Ejemplo 5 +print ("") +# Observar varias formas de declarar diccionarios +{'1': 'primero', '2': 'segundo', 'tercero': 4 * 5 * 6} # Tres pares, str-str, str-str y str-int +{'1': 'primero', '2': 'segundo', 'tercero': 120} # Igual que el anterior, pero el último no es una operación +{str(x): x + 1 for x in range(5)} # Clave es un str x, el valor de x+1 en el rango 0-5 +{'0': 1, '1': 2, '2': 3, '3': 4, '4': 5} # 4 pare, str-int, str-int, str-int, str-int +dict(enumerate(range(5), start=10)) +{10: 0, 11: 1, 12: 2, 13: 3, 14: 4} +[(x, chr(x)) for x, idx in enumerate(range(5), start=65)] +[(65, 'A'), (66, 'B'), (67, 'C'), (68, 'D'), (69, 'E')] +#Este ejemplo crea un diccionario compuesto por un int (start=65), y el valor es un str que se calcula +# usando la función chr(), al pasarle el valor de x, retornará 5 letras sucesivas entre 65 y 69 (5 valores) +letters = [(x, chr(x)) for x, idx in enumerate(range(5), start=65)] +dict(letters) +print (letters) +{65: 'A', 66: 'B', 67: 'C', 68: 'D', 69: 'E'} + +# Ejemplo 6 +# Este es un diccionario +# Se define como nombre_dic = dict(pos=valor, key=valor, valor=valor), hay otras formas +# +miprimer_dic = dict(tipo='Moto', marca='Honda', power=599) +print(list(enumerate(miprimer_dic))) #convertimos el dict en lista. +#[(0, 'tipo'), (1, 'marca'), (2, 'power')] +print("") +print ("Inicio del ciclo for") +# En este ejemplo iteramos los elementos de un diccionario y me muestran los pares según posición +# Usamos el método "enumerate" que pertenece al tipo list, para recorrer el dict convertido en lista +# +print ("caso con f") +for idx, key in enumerate(miprimer_dic): # El enumerador de la forma ind, key, recorre el diccionario + print(f'Pos: {idx} - dict_key {key} - value {miprimer_dic[key]}') + #print('Pos: {idx} - dict_key {key} - value {miprimer_dic[key]}') +print("") +print ("caso sin f") +for idx, key in enumerate(miprimer_dic): # El enumerador de la forma ind, key, recorre el diccionario + #print(f'Pos: {idx} - dict_key {key} - value {miprimer_dic[key]}') + print('Pos: {idx} - dict_key {key} - value {miprimer_dic[key]}') + +#Pos: 0 - dict_key tipo - value Moto +#Pos: 1 - dict_key marca - value Honda +#Pos: 2 - dict_key power - value 599 + +# Ejemplo 7 +# Consultar a un dicc, si una clase existe => retorna un booleano TRUE o FALSE +# Ojo si preguntas por un valor, puede existir, pero retornará FALSE +# Si quiero preguntar por un valor, agrego el método .value() + +print ("") +letters2 = [(x, chr(x)) for x, idx in enumerate(range(5), start=65)] +dd = dict(letters2) +print ("Este es el diccionario dd", dd) +mi_key1=65 +print (type(letters2)) +if mi_key1 in dd: + print ("La clave ", mi_key1," existe") +else: + print ("La clave ", mi_key1, ". No existe") +print ("") + +restaurant = {"Hamburguesa": 100, "Pizza": 50, "Jugo": 30} +if "Hamburguesa" in restaurant: + print ("SI está") +else: + print ("NO está") +print (restaurant) \ No newline at end of file diff --git a/Workbench/Taller/Funciones b/Workbench/Taller/Funciones index 41dcd2983..cdcc063de 100644 --- a/Workbench/Taller/Funciones +++ b/Workbench/Taller/Funciones @@ -1,33 +1,38 @@ - -def misuma (a,b): - return a+b - -res= misuma (2,3) -print (res) - -def suma(a, b): - return a + b - - - +#******************************************************************* +#* * +#* B I E N V E N I D O A F U N C I O N E S * +#* * +#******************************************************************* +# Una función es una operación o procedimiento que retorna un valor o acción +# Se declaran con la palabra reservada 'def' y se cierra con ':', debe incluir 'return' y la logica +# del cálculo o lo que hace la función. +# Operaciones o métodos habituales como insert, append, sort...son funciones, porque hacen o retornan cosas. +# Para usar la función, le paso los parámetros definidos, ojo con los tipos y el control de las excepciones + +# Ejemplo 1 +def misuma (a,b): # Esta es una función, toma dos enteros a,b y los suma + return a+b # El calculo viene después de la palabra return + +res= misuma (2,3) # Uso la función, le paso los parámetros 2,3 y, el resultado lo almaceno en la variable res +print ("Resultado de sumar 2 y 3, es ", res) # Puedo ver su contenido con un print + +# Ejemplo 2 # min y max son funciones integradas en Python que nos devuelven # los valores mínimo y máximo de un iterable (como las listas o las tuplas) -def min_y_max(lista): - return min(lista), max(lista) - +def min_y_max(lista): # Declaro la función y le digo que le pasaré un argumento de tipo lista + return min(lista), max(lista) # Usando la funciones min y max que pertenecen a objetos iterables + # obtengo los valores y los devuelvo # ahora vamos a usar estas funciones -valor = suma(10, 15) -print(valor) +valor = misuma(10, 15) +print("Usando la función 'misuma', el resultado de sumar 10 y 15 es ", valor) minimo, maximo = min_y_max([30, 10, 50, 40, 20]) -print(f'min y max son {minimo} y {maximo}') - -""" -def test_OrdenarDiccionario_03(self): - dicc = {'clave1':['c','a','b'], 'clave2':['casa','auto','barco'], 'clave3':[3,1,2]} - valor_test = ch.OrdenarDiccionario(dicc, 'clave3', False) - valor_esperado = {'clave1':['b','a','c'], 'clave2':['barco','auto','casa'], 'clave3':[3,2,1]} - """ - -""" \ No newline at end of file +print("Para el vector 30,10,50,40 y 20, los ",f'min y max son {minimo} y {maximo}') + +# Ejemplo 3 #Lo veremos más adelante +# En este ejemplo, creamos una función que realiza un test unitario +#def test_OrdenarDiccionario_03(self): +# dicc = {'clave1':['c','a','b'], 'clave2':['casa','auto','barco'], 'clave3':[3,1,2]} +# valor_test = ch.OrdenarDiccionario(dicc, 'clave3', False) +# valor_esperado = {'clave1':['b','a','c'], 'clave2':['barco','auto','casa'], 'clave3':[3,2,1]} \ No newline at end of file diff --git a/Workbench/Taller/Matrices.py b/Workbench/Taller/Matrices.py new file mode 100644 index 000000000..ed2f911ab --- /dev/null +++ b/Workbench/Taller/Matrices.py @@ -0,0 +1,27 @@ +# Ejemplo 1 +# Uso de 'enumerate' para recorrer matrices +m = [['enteros', 1, 2, 3, 4], #Define una matriz 'm' + ['complex', 1j, 2j, 3j, 4j], + ['float', 1.0, 2.0, 3.0, 4.0]] +# [['enteros', 1, 2, 3, 4], ['complex', 1j, 2j, 3j, 4j], ['float', 1.0, 2.0, 3.0, 4.0]] +for i, elems in enumerate(m): + for j, jelem in enumerate(elems): + print(f'row {i} - column {j}: {jelem}') + +""" +row 0 - column 0: enteros +row 0 - column 1: 1 +row 0 - column 2: 2 +row 0 - column 3: 3 +row 0 - column 4: 4 +row 1 - column 0: complex +row 1 - column 1: 1j +row 1 - column 2: 2j +row 1 - column 3: 3j +row 1 - column 4: 4j +row 2 - column 0: float +row 2 - column 1: 1.0 +row 2 - column 2: 2.0 +row 2 - column 3: 3.0 +row 2 - column 4: 4.0 +""" \ No newline at end of file diff --git a/Workbench/Taller/datatypes.py b/Workbench/Taller/datatypes.py index 41f532a07..642414419 100644 --- a/Workbench/Taller/datatypes.py +++ b/Workbench/Taller/datatypes.py @@ -1,7 +1,9 @@ -#On this file we going to learn about different data types -#Boolean, int, float, cmplex mumbers -#Boolean true or false -#String, list (dictionary + +# On this file we going to learn about different data types +# Boolean, int, float, complex mumbers +# Boolean true or false +# String, list (dictionary) + current_year=2023 print (current_year) next_year=current_year+1 @@ -10,9 +12,9 @@ print(type (3.14)) print (type (1+2j)) print (type (9.81)) -#a = input ("Ingresa un texto") -#print ("El texto ingresado es", a) -#converting data type e.g int to float o vs +a = input ("Ingresa un texto") +print ("El texto ingresado es", a) +# Convertir data type e.g int to float o viceversa print (int(9.81)) print (round (9.81)) #BOOLEAN CASES @@ -35,17 +37,4 @@ print (fullname,", aquí usamos la variable concatenada") print (type (firstname)) print (country.upper()) #métodos de la clase print -print (fullname.title()) -#LIST ==> It's a list of something, could be task, groceries -empty_list1 = list() #dos formas de inicializar listas -empty_list2 = [] #la nombro y luego declaro como list() -# la nombre y asigno una lista vacia con corchetes [] -print (empty_list1, "esta es la lista 1") -print (empty_list2, "esta es la lista 2") -numbers = [1,2,3,4,5,6] -groceries = ["tomato", "carrot", "letuce"] -print (groceries [0]) #el puntero va con corchete y parte de 0 -print (numbers [3]) #es una COLECCION -print (len(groceries)) #conocer el largo de la la lista con len -mix_of_data_types_list = [1, "Jota", lastname, 2+5, 1-3j, 3.14] -#podemos almacenar un mix de datos +print (fullname.title()) \ No newline at end of file diff --git a/Workbench/Taller/listas.py b/Workbench/Taller/listas.py index 731dbf055..704f13cbe 100644 --- a/Workbench/Taller/listas.py +++ b/Workbench/Taller/listas.py @@ -1,49 +1,79 @@ -#Ejericio 1 +#******************************************************************* +#* * +#* TEORIA LISTAS * +#* * +#******************************************************************* -listadeletras = [] # Crea un objeto list llamado lista -for unaletra in "paralelepipedo": # Define una variable car para recorrer el string "casa" - listadeletras.append(unaletra) # Agrega cada caracter del string en la lista -print(listadeletras) # Imprime los valores de la lista que son los caracteres de la palabra casa o pera, lo que sea - # Salida esperada ['c', 'a', 's', 'a'] +# Una LIST, es un objeto, es una colección de cosas, pueden ser tareas, +# vegetales, nombres +# mercaderías, cualquier cosa. -""" -#Ejercicio 2 -# Lista de 4 elementos y para cada elemento calcularle la potencia de 2, usando el método tradicional, eso seria así: -#Alternativa 1 +# Dos formas paa declararlas e iniciaizarlas + +# 1) Defino una variable y le asigno un tipo lista VACÍO con paréntesis +empty_list1 = list() # Note que se debe indicar el tipo lista o lo considerará una TUPLA +print (empty_list1, "esta es la lista 1 con '()'") +print (type(empty_list1)) + +# 2) Defino una variable y sé que es del tipo lista por los corchetes '[]' +empty_list2 = [] # A la variable se le asigna una lista vacía con CORCHETES +print (empty_list2, "esta es la lista 2") +print (type (empty_list2)) + +# Ejemplo 1 +numbers = [1,2,3,4,5,6] # Lista de números +print("'numbers' es del tipo ", type(numbers)) # De devolver el texto+ type 'list' + +# Ejemplo 2 +groceries = ["tomato", "carrot", "letuce"] # Una lista con 3 strings de 'vegentales' +print (groceries [0]) # El puntero va con corchetes y parte de 0, imprime "tomato" +print (numbers [3]) # Es una COLECCION, imprime todos los elementos +print (len(groceries)) # Conocer el largo de la la lista con len, devuelve 3 + +# Ejemplo 3 +lastname = "cordova" # Variable de tipo string, contiene "cordova" +mix_of_data_types_list = [1, "Jota", lastname, 2+5, 1-3j, 3.14] # Lista con distintos tipos de var +print ("'mix_of_data_types_list' es del tipo-", type(mix_of_data_types_list)) #devuelve 'list' +#podemos almacenar un mix de datos + +# Ejemplo 4 +listadeletras = [] # Crea un objeto list llamado listadeletras +for unaletra in "paralelepipedo": # Define una variable 'unaletra' y recorre el string "paralelepípedo" + listadeletras.append(unaletra)# Agrega cada caracter del string a 'listadeletras' usando el método 'append' +print (listadeletras) # Imprime los valores de la lista que son los caracteres de la palabra 'paralelepípedo'', lo que sea + # Salida esperada ['p', 'a', 'r', 'a', 'l', 'e', 'l', 'e', 'p', 'i', 'p', 'e', 'd', 'o'] -lista_potencias = [] #Crea una lista llamada "lista_potencias" -for i in range(4): #ciclo for para recorrer lista de 4 elementos, va de 0 a 3, el índice lo llamamos "i" - lista_potencias.append(i**2) #a la lista "lista_potencias", la voy poblando con el dato calculado. -print(lista_potencias) #Imprime los 4 valores almacendaos en la lista #Obs: como no cambié el nombre, concatenó los valores de la lista al final -# [0, 1, 4, 9] +# Ejemplo 5 +# Crear una lista de 4 elementos y, para cada elemento, calcularle la potencia de 2, usando +# el método tradicional, eso seria así: +# Alternativa 1 +lista_potencias = [] # Crea una lista llamada "lista_potencias" +for i in range(4): # Ciclo for para recorrer lista de 4 elementos, va de 0 a 3, el índice lo llamamos "i" + lista_potencias.append(i**2)# La lista "lista_potencias", la voy poblando con el dato calculado. +print(lista_potencias) # Imprime los 4 valores almacendaos en la lista [0, 1, 4, 9] -#Alternativa 2 +# Ejemplo 6 # Entonces el ejemplo anterior usando listas de comprensión, eso seria así: -lista_potencias2 = [i**2 for i in range(4)] -print ("Esta es la lista de potencias Nr2", lista_potencias2) -# [0, 1, 4, 9] +lista_potencias2 = [i**2 for i in range(4)] # Usa un for +print ("Esta es la lista de potencias Nr2", lista_potencias2) # Imprime [0, 1, 4, 9] -#Ejercicio 3 -#Lista con las potencias de 2 de los primeros 10 números, método tradicional: -""" -""" -Método 3-1 -lista1_pot10_2 = [] #Creamos un objeto lista vacio [] -for num in range (0, 11): #incluye el primero y no el últimmo. Usando un ciclo FOR usando la var "num" en el tramo de 0-10, ambos incluidos - lista1_pot10_2.append (num**2) #Llenamos la lista con potencias PARTIENDO DE 0, a 10 (11-1) -print(lista1_pot10_2) +# Ejemplo 7 +# Lista con las potencias de 2 de los primeros 10 números, método tradicional: +# Alternativa 1 +lista1_pot10_2 = [] # Creamos un objeto lista vacio [] +for num in range (0, 11): # Incluye el primero y no el últimmo. Usando un ciclo FOR usando la var "num" en el tramo de 0-10, ambos incluidos + lista1_pot10_2.append (num**2) # Llenamos la lista con potencias PARTIENDO DE 0, a 10 (11-1) +print(lista1_pot10_2) # Salida por pantalla [0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100] -#[4, 9, 16] -#[0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100] -#Método 3-2 +# Alternativa 2 #Entonces el ejemplo anterior usando listas de comprensión, eso seria así: #lista2_pot10_2 = [num2**2 for num2 in range(0, 11)] #Creamos la lista con los valores según condición #print("Este es el método 3-2, para crear la lista de 10 números y sus potencias",lista2_pot10_2) #[0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100] #De este código anterior usted puede aprender que es posible modificar al vuelo los elementos los cuales van a formar la lista. -# Ej -# Con este ejemplo se ve como funciona el conteo de posiciones en una lista (cada elemento es una posX) +# Ejemplo 8 +# Este ejemplo muestra como operan las posiciones en una lista (cada elemento es una posX) lista = ["pos0", "pos1", "pos2", "pos3", "pos4", "pos5"] print("Esta es la lista:\n", lista, "\n") print("1° Mostrar 'lista[2:5]', significa la pos2, pero excluye la 5, ojo!\n", lista[2:5]) # tomamos del 2 al 5 (sin incluir el 5) @@ -53,8 +83,8 @@ print("5° Mostrar 'lista[4:1:-1]', significa orden desc de la pos4 a la 2, excluye la pos1",lista[4:1:-1]) print("6° Mostrar 'lista[:]', significa mostrar todos los elementos de la lista\n",lista[:]) # tomamos desde el principio hasta el final (es como hacer una copia de la lista) print("7° Mostrar 'lista[::-1]', significa mostrar todos los elementos de la lista en orden inverso\n",lista[::-1]) # tomamos desde el final hasta el principip (orden inverso) -""" -# EJ 5 + +# Ejemplo 9 # Con este ejemplo usamos un truco para controlar la salida, un método de print llamado end # for i in range (15): @@ -63,15 +93,81 @@ else: print (i) -""" -# Ej 6 +# Ejemplo 10 # Mismo ejemplo sin controlar la salida, cada linea se ejecuta y se apilan. -#for i in range (15): -# print (i) +for i in range (15): + print (i) + +# Ejemplo 11 +# Revisar otra formas de ordenar listas +lista_desordenada = [5,7,2,8,3,6] +lista_desordenada.sort() +print ("Resultado esperado 2,3,5,6,7,8, lista generada :", lista_desordenada) +print (type(lista_desordenada)) + +# Ejemplo 12 +# Lista negada = los inversos y lista doble = multiplicadas por algo +lista = [10, 20, 30] +lista_negada = [ -e for e in lista ] # Los inversos de los elementos +lista_doble = [ e*2 for e in lista] # Los elementos multiplicados por 2 +print(lista_negada) +print(lista_doble) + +# Ejemplo 13 +# Una lista de valores float, no se pueden negar strings +lista2 = [True, True, False, 5, 2-3j] +lista_negada2 = [ -e for e in lista2] # Los inversos de los elementos numéricos +lista_doble2 = [ e*2 for e in lista2] # Los elementos multiplicados por 2 +print(lista_negada2) # Nótese la salida [-1, -1, 0, -5, (-2+3j)], los booleanos los tomo como 1 y 0 +print(lista_doble2) # Nótese la salida [2, 2, 0, 10, (4-6j)], fijarse en los booleanos + +# Ejemplo 14 +# Con un ciclo for, alimenta dos listas dependiendo de una condición y muestra la información horizontal. +lista_i = [] +lista_p = [] +for i in range (1,21): + n=(i%2) + if n==1: + lista_i.append (i) + elif n==0: + lista_p.append (i) +print ("Los números impares entre 1 y 20 son ", lista_i) +print ("Los números pares entre 1 y 20 son ", lista_p) + +# Ejemplo 15 +# Usos de 'enumerate' en listas, tuplas, diccionarios, cadenas +for i, val in enumerate(['A', 'B', 'C']): + print(i, val) """ +0 A +1 B +2 C """ -# Revisar formas de ordenar listas -lista_desordenada = (5,7,2,8,3,6) -print (lista_desordenada) -print (lista_desordenada.sort()) -""" \ No newline at end of file + +# En este caso imprime la posición o puntero, y e contenido de la posición, vertical + +# Ejemplo 16 + +for i, val in enumerate(['A', 'B', 'C'], start=5): # Mismo anterior, pero cambia el valor del puntero que parte en 5 + print(i, val) +""" +5 A +6 B +7 C +""" +# La salida va de 5 a 7 + +# Ejemplo 17 +# En este caso va de 5 a 14, se salta 3, y el puntero inicia en 1 +for i, val in enumerate(range(5, 15, 3), start=1): + print(f'Pos: {i} -> {val}') +""" +Pos: 1 -> 5 +Pos: 2 -> 8 +Pos: 3 -> 11 +Pos: 4 -> 14 +""" +# La salida va con los textos 'Pos: ' y '->' +print ("") + +# Ejemplo \ No newline at end of file diff --git a/Workbench/Taller/variables.py b/Workbench/Taller/variables.py index cb71de421..bfd2c9c5b 100644 --- a/Workbench/Taller/variables.py +++ b/Workbench/Taller/variables.py @@ -1,5 +1,5 @@ #Variables -#It's memory location to assign data to store and use ir later +#It's a memory location to assign data to store and use it later a=10 b=3 print (a) @@ -8,4 +8,4 @@ print ("what's the value of b", b) print (a+b) total =2+4 -print (total) \ No newline at end of file +print (total) From c1ca111b4efb2652840a75f3cd79264f12371132 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Mon, 23 Jan 2023 04:26:48 -0300 Subject: [PATCH 04/16] 230123-0432 Atualizacion --- ...B\303\241sico_Interactivo_de_Python.ipynb" | 982 ------------------ Workbench/Taller/listas.py | 2 +- 2 files changed, 1 insertion(+), 983 deletions(-) delete mode 100644 "Copia_de_Tutorial_B\303\241sico_Interactivo_de_Python.ipynb" diff --git "a/Copia_de_Tutorial_B\303\241sico_Interactivo_de_Python.ipynb" "b/Copia_de_Tutorial_B\303\241sico_Interactivo_de_Python.ipynb" deleted file mode 100644 index 8a4ee6328..000000000 --- "a/Copia_de_Tutorial_B\303\241sico_Interactivo_de_Python.ipynb" +++ /dev/null @@ -1,982 +0,0 @@ -{ - "nbformat": 4, - "nbformat_minor": 0, - "metadata": { - "colab": { - "provenance": [], - "private_outputs": true, - "include_colab_link": true - }, - "kernelspec": { - "name": "python3", - "display_name": "Python 3" - }, - "language_info": { - "name": "python" - }, - "gpuClass": "standard" - }, - "cells": [ - { - "cell_type": "markdown", - "metadata": { - "id": "view-in-github", - "colab_type": "text" - }, - "source": [ - "\"Open" - ] - }, - { - "cell_type": "markdown", - "source": [ - "# Tutorial Básico Interactivo de Python de Código Pitón\n", - "\n", - "![cp.png]()\n", - "\n", - "¡Hola! **Bienvenido al Tutorial Básico Interactivo de Python de [Código Pitón](https://www.codigopiton.com/)**.\n", - "\n", - "Este tutorial recoge una guía básica de los fundamentos de Python en forma de cuaderno de Jupyter alojado en Google Colab (Colaboratory).\n", - "\n", - "Está estrechamente ligado a la [Hoja de Referencia de Python de Código Pitón](https://www.codigopiton.com/la-hoja-de-referencia-de-python/) que recibiste cuando te suscribiste a la lista de correo de Código Pitón.\n", - "\n", - "Si no tienes la Hoja de Referencia (por ejemplo, porque alguien te compartió este tutorial) puedes [conseguirla de manera gratuita al susbscribirte a Código Pitón](https://www.codigopiton.com/la-hoja-de-referencia-de-python/) y te llegará inmediatamente por correo electrónico.\n", - "\n", - "La **idea principal de este tutorial** es que tengas una guía interactiva para complementar perfectamente a la Hoja de Referencia y a la que puedas recurrir durante tu aprendizaje si te surge alguna duda. Espero que te sea de mucha utilidad.\n", - "\n", - "El tutorial tiene 15 apartados, exactamente igual que la Hoja de Referencia, y en el mismo orden, para que no te pierdas en ningún momento. Además, les he puesto el mismo nombre para que no quede lugar a ningún tipo de duda.\n", - "\n", - "¡Vamos allá!\n", - "\n", - "## Antes de empezar\n", - "\n", - "Si no estás muy familiarizado con los cuadernos de Jupyter, ¡no te preocupes! Aquí es todo muy fácil. Todo se organiza en celdas. Podrás ver celdas de texto explicativo (como este) y celdas con fragmentos de código Python ejecutable, como el siguiente:\n" - ], - "metadata": { - "id": "EZslL1PpIsde" - } - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": { - "id": "9NrJqYoyINXn" - }, - "outputs": [], - "source": [ - "print('¡Hola desde el Tutorial Básico Interactivo de Código Pitón! 😊') " - ] - }, - { - "cell_type": "markdown", - "source": [ - "Siéntete libre de ejecutar los fragmentos de código que quieras y de modificarlos a tu gusto para experimentar y aprender, ¡ese es el objetivo de este tutorial interactivo!\n", - "\n", - "Para ejecutar un fragmento de código basta con que hagas click en el icono de ejecutar a la izquierda de cada celda. También puedes ejecutarlos con la combinación de teclas Ctrl + Enter y verás el resultado justo debajo.\n", - "\n", - "Y ahora sí, vamos con el tutorial.\n", - "\n", - "\n", - "\n", - "\n", - "\n", - "Los contenidos son los siguientes:\n", - "\n", - "\n", - "1. Asignación de variables\n", - "2. Acceso a valor de variables\n", - "3. Aritmética básica\n", - "4. Importación de módulos\n", - "5. Gestión de excepciones\n", - "6. Salida y formato de texto\n", - "7. Listas\n", - "8. Condicionales\n", - "9. Booleanos y comparaciones\n", - "10. Comprensión de listas\n", - "11. Comentarios\n", - "12. Funciones\n", - "13. Bucles\n", - "14. Notación de porciones\n", - "15. Entrada por teclado\n", - "\n", - "\n", - "\n" - ], - "metadata": { - "id": "IAHwNotEQtNy" - } - }, - { - "cell_type": "markdown", - "source": [ - "# 1. Asignación de variables\n", - "\n", - "Los principales tipos de datos son números enteros (int), números decimales (float), cadenas de texto (str) y valores booleanos (verdadero o falso, te cuento más sobre esto más adelante).\n", - "\n", - "Para realizar asignaciones utiliza nombres de variables identificativos, el símbolo = y el valor que quieras asociar a la variable." - ], - "metadata": { - "id": "qhinAwWbPwsG" - } - }, - { - "cell_type": "code", - "source": [ - "x = 10 # enteros\n", - "y = 0.5 # decimales\n", - "z = 'hola' # texto\n", - "b = True # booleanos\n", - "print(x)\n", - "print(y)\n", - "print(z)\n", - "print(b)" - ], - "metadata": { - "id": "bl-PHta-TM7D" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "Las principales colecciones de datos son las listas (modificables), las tuplas (no modificables), los conjuntos (que no admiten repetidos) y los diccionarios (que guardan pares clave-valor)." - ], - "metadata": { - "id": "ltpQ4vgOTgx6" - } - }, - { - "cell_type": "code", - "source": [ - "tupla = (1, 2, 3)\n", - "lista = [4, 5.5, 'a6']\n", - "conjunto = ('a', 'b', 'c')\n", - "\n", - "print(tupla)\n", - "print(lista)\n", - "print(conjunto)\n", - "\n", - "diccionario = {10: 1.1, 20: 1.0, 30: 1.3}\n", - "diccionario[40] = 1.5 # asignando un valor (1.5) a una nueva clave (40)\n", - "print(diccionario)\n", - "\n", - "x, y, z = 1, 2, 3 # asignación múltiple\n", - "print('Tras la asignación múltiple: ')\n", - "print(x)\n", - "print(y)\n", - "print(z)\n", - "\n", - "print('Tras intercambiar valores: ')\n", - "x, y = y, x # intercambio de valores\n", - "print(x)\n", - "print(y)\n", - "\n", - "print('Tras desempaquetar una tupla en variables: ')\n", - "x, y, z = (10, 20, 30)\n", - "print(x)\n", - "print(y)\n", - "print(z)\n" - ], - "metadata": { - "id": "mBTQ6WUbTmSX" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 2. Acceso a valor de variables\n", - "\n", - "Cuando ya hemos hecho asignaciones y tenemos variables con valores, podemos acceder a esos valores utilizando el nombre de las variables en otras expresiones.\n", - "\n", - "Además, podemos acceder a los elementos de una lista o una tupla a través de su índice (número de posición, comenzando en 0) indicándolo entre corchetes \\[ y \\].\n", - "\n", - "Para acceder a los valores de un diccionario utilizaremos la clave asociada a cada valor, de nuevo entre corchetes.\n", - "\n", - "También podemos acceder a los atributos de una clase utilizando el nombre de la clase, un punto y a continuación el nombre del atributo. De igual manera, podemos acceder a los atributos de un objeto o instancia utilizando el nombre del objeto, un punto y a continuación el nombre del atributo.\n" - ], - "metadata": { - "id": "xUu-z6MPQTn8" - } - }, - { - "cell_type": "code", - "source": [ - "lista = [10, 20, 30, 40, 50]\n", - "valor = lista[2]\n", - "print(valor)\n", - "\n", - "diccionario = {10: 5, 20: 7, 30: 9}\n", - "valor = diccionario[20]\n", - "print(valor)\n", - "valor = diccionario.get(40, '0') # valor por defecto 0 si clave (40) no existe\n", - "\n", - "class Clase:\n", - "\n", - " atributo_de_clase = 10\n", - "\n", - " def __init__(self):\n", - " self.atributo_de_instancia = 20\n", - "\n", - "\n", - "print(Clase.atributo_de_clase)\n", - "\n", - "instancia = Clase()\n", - "print(instancia.atributo_de_instancia)" - ], - "metadata": { - "id": "Dv3EgoExVqhr" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "Más información sobre variables: https://www.codigopiton.com/variables-locales-y-globales-en-python/" - ], - "metadata": { - "id": "hllJO5IAMPS1" - } - }, - { - "cell_type": "markdown", - "source": [ - "# 3. Aritmética básica\n", - "\n", - "Podemos realizar operaciones matemáticas aritméticas básicas utilizando los símbolos +, -, * (multiplicación), / (división), // (división entera), % (resto de la división entera o módulo) y \\*\\* (potencia).\n" - ], - "metadata": { - "id": "GXjjRcl4QzB8" - } - }, - { - "cell_type": "code", - "source": [ - "print(3 + 5)\n", - "print(5 - 3)\n", - "print(5 * 3)\n", - "print(5 / 3)\n", - "print(5 // 3)\n", - "print(5 % 3)\n", - "print(5 ** 3)" - ], - "metadata": { - "id": "SSDZqkv8XRer" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 4. Importación de módulos\n", - "\n", - "Si necesitas utilizar una librería (tanto de Python como externa) tendrás que importar el módulo correspondiente con import. \n", - "\n", - "Podrás darle un alias al módulo si utilizas as.\n", - "\n", - "También puedes importar un componente concreto de un módulo a través de from." - ], - "metadata": { - "id": "WItnb6q8Q-fp" - } - }, - { - "cell_type": "code", - "source": [ - "import datetime\n", - "\n", - "print(datetime.datetime.now())" - ], - "metadata": { - "id": "aVd-5GYuYY8f" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "code", - "source": [ - "import datetime as dt\n", - "\n", - "print(dt.datetime.now())" - ], - "metadata": { - "id": "pmez2i-FYx0G" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "code", - "source": [ - "from datetime import datetime as dt\n", - "\n", - "print(dt.now())" - ], - "metadata": { - "id": "u52AMnEFY3Cf" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 5. Gestión de excepciones\n", - "\n", - "Para manejar errores y excepciones tienes que usar la construcción try - except - finally. De no hacerlo, el código interrumpe su ejecución en caso de surgir algún error.\n", - "\n", - "Algunos de los errores más comunes son los siguientes:\n", - "* SyntaxError: sintaxis incorrecta\n", - "* ValueError: valor argumento no válido\n", - "* ZeroDivisionError: división por cero\n", - "* NameError: variable no definida\n", - "* ModuleNotFoundError: modulo no existe\n", - "* FileNotFoundError: fichero no existe\n", - "* IndexError: índice no existe\n", - "* KeyError: clave no existe\n", - "\n", - "\n", - "\n" - ], - "metadata": { - "id": "j_bTR38XRB1Y" - } - }, - { - "cell_type": "code", - "source": [ - "# El siguiente código genera un error\n", - "\n", - "a = 10\n", - "b = 0\n", - "\n", - "print(a/b) # no se puede dividir por cero" - ], - "metadata": { - "id": "-XPkB0XRbR88" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "code", - "source": [ - "# Vamos a controlar el error para que no se interrumpa la ejecución\n", - "\n", - "a = 10\n", - "b = 0\n", - "\n", - "try:\n", - " print(a/b)\n", - "except ZeroDivisionError:\n", - " print('Lo siento, no puedo dividir por cero.')\n", - "finally:\n", - " print('Bloque try-except finalizado') # esto, que es opcional, se ejecuta siempre, haya error o no\n", - " " - ], - "metadata": { - "id": "fp6wj4dybZI4" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 6. Salida y formato de texto\n", - "\n", - "Ya has visto que la función *print* se utiliza para mostrar información por pantalla.\n", - "\n", - "Podemos personalizar la manera en que se muestra esa información de múltiples maneras. Algunas formas sencillas y básicas son la siguientes:" - ], - "metadata": { - "id": "e-4K3kjIRIee" - } - }, - { - "cell_type": "code", - "source": [ - "a = 10\n", - "b = 20\n", - "c = 30.158\n", - "print(a)\n", - "print('b=' + str(b)) # convertimos un numero a string con str\n", - "\n", - "print('a=%i' % a) # usamos una máscara de número entero (%i) dentro de la cadena de texto\n", - "print('a=%i, b=%i' % (a, b))\n", - "\n", - "print('a={}, b={}'.format(a, b))\n", - "print('c={:.2f}'.format(c)) # puedes indicar se se usen solo dos decimales para un float\n", - "\n", - "print(f'a={a}, b={b}') # usamos f-strings, la forma preferida\n" - ], - "metadata": { - "id": "soEeTeTKcHDu" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 7. Listas\n", - "\n", - "Podemos hacer muchas cosas con las listas, pues son secuencias muy potentes. Veamos algunas:" - ], - "metadata": { - "id": "OowBr9SiOINH" - } - }, - { - "cell_type": "code", - "source": [ - "lista = [5, 6, 7]\n", - "\n", - "lista.append(8) # añadimos un elemento al final\n", - "print(lista)\n", - "\n", - "lista.insert(1, 10) # insertamos un elemento en la posición que queramos\n", - "print(lista)\n", - "\n", - "lista.remove(6) # eliminamos un elemento\n", - "del lista[0] # eliminamos una posición\n", - "print(lista)\n", - "\n", - "lista.clear() # vacíamos la lista\n", - "print(lista)\n", - "\n", - "lista = [5, 6, 7]\n", - "elementos = [8, 9]\n", - "\n", - "lista.extend(elementos) # añadimos al final los elementos de otra lista\n", - "print(lista)\n", - "\n", - "lista.reverse() # invertimos la lista (le damos la vuelta)\n", - "print(lista)\n", - "\n", - "print(len(lista)) # obtenemos el número de elementos (o longitud) de una lista\n", - "\n", - "print(lista.index(7)) # obtenemos el índice de un elemento\n", - "\n" - ], - "metadata": { - "id": "ahagt7kyeE5J" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "Aquí tienes más información sobre cómo obtener la posición o índice de un elemento en una lista: https://www.codigopiton.com/encontrar-indice-de-elemento-en-lista-en-python/" - ], - "metadata": { - "id": "nyQRye6VfOcC" - } - }, - { - "cell_type": "markdown", - "source": [ - "# 8. Condicionales\n", - "\n", - "Las condicionales nos permiten ejecutar un determinado fragmento de código si se cumple una determinada condición (rama if).\n", - "\n", - "Además, podemos indicar que, si no se cumple dicha condición, se ejecute otro código (rama else).\n", - "\n", - "Finalmente, se permite encadenar varias ramas ifs con distintas condiciones (elif) y una rama else si no se cumple ninguna de las condiciones indicadas. Las ramas aquí son excluyentes." - ], - "metadata": { - "id": "ju3H-DAjOId7" - } - }, - { - "cell_type": "code", - "source": [ - "a = 10\n", - "b = 20\n", - "\n", - "if a < 15:\n", - " print('a es menor que 15') # esto se ejecutará ya que se cumple la condición\n", - "\n", - "\n", - "if a > 15:\n", - " print('a es mayor que 15') # esto no se ejecutará ya que no se cumple la condición\n", - "\n", - "if a > 30:\n", - " print('a es mayor que 30') # esto no se ejecutará ya que no se cumple la condición\n", - "else:\n", - " print('a no es mayor que 30') # esto sí se ejecutará ya que no se cumple la condición\n", - "\n", - "\n", - "if b > 10:\n", - " print('b es mayor que 10') # esto se ejecutará ya que se cumple la condición\n", - "else:\n", - " print('b no es mayor que 10') # esto no se ejecutará ya que se cumple la condición\n", - "\n", - "\n", - "# a continuación se comprobaran las condiciones secuencialmente y se ejecutara \n", - "# solo el fragmento de código de la condición que se cumpla (condiciones excluyentes)\n", - "\n", - "if a < 10:\n", - " print('a es menor que 10')\n", - "elif a > 12:\n", - " print('a es mayor que 12')\n", - "elif b > 15:\n", - " print('b es mayor que 15') # esta es la rama que se ejecuta\n", - "elif b == 20:\n", - " print('b es igual a 20') # aunque la condición de esta rama es cierta no se ejcuta\n", - " # pues ya se ejecutó otra rama antes\n", - "else:\n", - " print('no se ha cumplido ninguna de las condiciones anteriores')" - ], - "metadata": { - "id": "JV2mITN3a2TG" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "Más información sobre condicionales: https://www.codigopiton.com/condicionales-en-python-mucho-mas-que-if-else/\n", - "\n", - "La estrucutura de control switch no existe en Python. Más información sobre cómo hacer switch en Python: https://www.codigopiton.com/como-hacer-switch-case-en-python/\n", - "\n", - "En Python existe, además, un operador ternario condicional: https://www.codigopiton.com/el-operador-ternario-condicional-en-python/\n", - "\n", - "Aunque desde la versión 3.10 de Python existe un mecanismo de \"pattern matching\" que se puede utilizar para emular un switch. Más información: https://peps.python.org/pep-0636/" - ], - "metadata": { - "id": "EPh-Axa2cc1L" - } - }, - { - "cell_type": "markdown", - "source": [ - "# 9. Booleanos y comparaciones\n", - "\n", - "Ahora que ya sabes cómo hacer condicionales, vamos a revisar los valores booleanos y las principales posibles comparaciones y comprobaciones que se pueden hacer en Python que devuelven valores booleanos.\n", - "\n", - "Los valores booleanos, son True y False (escritos con inicial mayúscula) y cuyo significado es \"cierto\" y \"falso\" respectivamente.\n", - "\n", - "Comparaciones y comprobaciones principales:\n", - "* Mayor: >\n", - "* Mayor o igual: >=\n", - "* Menor: <\n", - "* Menor o igual: <=\n", - "* Igual: ==\n", - "* Diferente: !=\n", - "* Pertenencia: in\n", - "\n", - "Puedes negar un valor booleano o condición para obtener el valor contrario con la palabra reservada \"not\"." - ], - "metadata": { - "id": "rQKB2F9AOIr2" - } - }, - { - "cell_type": "code", - "source": [ - "a = 2\n", - "b = 3\n", - "\n", - "print('Comparaciones simples:')\n", - "print(a > b)\n", - "print(a >= b)\n", - "print(a < b)\n", - "print(a <= b)\n", - "print(a == b)\n", - "print(a != b)\n", - "\n", - "print('Comprobación de pertenencia:')\n", - "lista = [1, 3, 5]\n", - "print(a in lista)\n", - "print(b in lista)\n", - "\n", - "print('Negación con not')\n", - "print(not True)\n", - "print(not False)\n", - "print(not a > b)\n", - "print(not a == b)\n" - ], - "metadata": { - "id": "aBjkpZRyd8V9" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "Más información sobre booleanos, comparaciones, condicionales, etc.: https://www.codigopiton.com/condicionales-en-python-mucho-mas-que-if-else/" - ], - "metadata": { - "id": "ZZKF7GPaeoZO" - } - }, - { - "cell_type": "markdown", - "source": [ - "Puedes combinar distintas comparaciones para crear una más compleja con las palabras reservadas \"and\" y \"or\".\n", - "\n", - "Cuando usas and entre dos comparaciones o condiciones, ambas deben ser True para que la condición combinada sea True.\n", - "\n", - "Cuando usas or entre dos comparaciones o condiciones, al menos una de ellas tiene que ser True para que la condición combinada sea True." - ], - "metadata": { - "id": "2tzz0ZRjwqHo" - } - }, - { - "cell_type": "code", - "source": [ - "a = 2\n", - "b = 3\n", - "print(b >= 3 and a == 2)\n", - "print(a < 10 and b < 2)\n", - "print(a == 2 or b == 0)\n", - "print(a < 0 or b < 0)" - ], - "metadata": { - "id": "Mu96IFV6xECQ" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 10. Comprensión de listas\n", - "\n", - "En Python podemos generar listas \"al vuelo\" utilizando un bucle for que devuelva un elemento e en cada iteración, aplicando un cálculo o expresión sobre e y encerrándolo todo entre [corchetes](https://www.codigopiton.com/parentesis-corchetes-llaves-en-python/). \n", - "\n", - "De esta manera se genera una lista con todos los elementos generados a partir de e.\n", - "\n", - "Ejemplos:" - ], - "metadata": { - "id": "MVkNPcwDOI6A" - } - }, - { - "cell_type": "code", - "source": [ - "lista = [10, 20, 30]\n", - "\n", - "lista_negada = [ -e for e in lista ]\n", - "lista_doble = [ e*2 for e in lista]\n", - "\n", - "print(lista_negada)\n", - "print(lista_doble)" - ], - "metadata": { - "id": "gEhGP1_bfcp2" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 11. Comentarios\n", - "\n", - "En el código que escribas puedes (y debes) incluir comentarios explicativos.\n", - "\n", - "Los comentarios no son interpretados por el interprete de Python y no afectan al código ni a su ejecución.\n", - "\n", - "Puedes usar el símbolo \\# para añadir un comentario al principio o al final de una línea (como ya has visto en este tutorial).\n", - "\n", - "Además, si necesitas hacer un comentario de varias líneas basta con que lo encierres en triples comillas ' ' ' o \" \" \".\n", - "\n", - "Ejemplos:\n" - ], - "metadata": { - "id": "NZjQEM3MOJGX" - } - }, - { - "cell_type": "code", - "source": [ - "# inicialización de variables (este es un comentario de una línea)\n", - "a = 10\n", - "b = 20\n", - "\n", - "''' En este comentario de varias líneas\n", - "voy a explicar lo que hago a continuación:\n", - "sumaré los valores de a y b y si suman más de 25\n", - "mostraré un mensaje de éxito por pantalla '''\n", - "\n", - "if a + b > 25:\n", - " print('¡Éxito!') # este será mi mensaje de éxito" - ], - "metadata": { - "id": "HtJvtFjbgbMA" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 12. Funciones\n", - "\n", - "Tanto para estructurar nuestro código así como para favorecer la reutilización del mismo se utilizan funciones.\n", - "\n", - "Las funciones nos permiten encapsular un fragmento de código y darle un nombre.\n", - "\n", - "Para definir una función usamos la palabra reservada \"def\" a continuación el nombre de la función y los parámetros que necesitemos entre paréntesis. La función puede devolver uno o varios valores si lo necesita (o ninguno).\n", - "\n", - "Después se puede invocar una función creada a través de su nombre." - ], - "metadata": { - "id": "QWnzNyKROJSs" - } - }, - { - "cell_type": "code", - "source": [ - "def suma(a, b):\n", - " return a + b\n", - "\n", - "\n", - "# min y max son funciones integradas en Python que nos devuelven\n", - "# los valores mínimo y máximo de un iterable (como las listas o las tuplas)\n", - "def min_y_max(lista):\n", - " return min(lista), max(lista)\n", - "\n", - "\n", - "# ahora vamos a usar estas funciones\n", - "valor = suma(10, 15)\n", - "print(valor)\n", - "\n", - "minimo, maximo = min_y_max([30, 10, 50, 40, 20])\n", - "print(f'min y max son {minimo} y {maximo}')\n" - ], - "metadata": { - "id": "DD5-_oeLsiNX" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 13. Bucles\n", - "\n", - "Los bucles son un mecanismo de control de flujo que nos permite repetir un fragmento de código un número determinado de veces.\n", - "\n", - "Hay dos tipos:\n", - "\n", - "\n", - "1. while, que nos permite controlar mediante una condición el número de repeticiones.\n", - "2. for, que nos permite iterar por los elementos de una colección de manera sencilla y cómoda.\n", - "\n", - "El código que queremos repetir, también llamado \"cuerpo del bucle\" debe indentarse tras el for o el while.\n", - "\n" - ], - "metadata": { - "id": "yJaf1DpiOJeh" - } - }, - { - "cell_type": "code", - "source": [ - "# ejemplo de while\n", - "a = 0\n", - "\n", - "while (a < 10): # mientras a sea < 10 el cuerpo del bucle se repetirá\n", - " print(a)\n", - " a = a + 1 # sumamos 1 a la variable a para asegurarnos de que la condición del bucle será False en algún momento\n", - "\n", - "# ejemplo de for\n", - "lista = [10, 20, 30, 40]\n", - "\n", - "for elemento in lista:\n", - " print(elemento)\n", - "\n" - ], - "metadata": { - "id": "lIfvC-pN_QhY" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "Dentro de los bucles puedes utilizar las sentencias de control break y continue:\n", - "* break termina anticipadamente el bucle\n", - "* continue interrumpe la vuelta actual del bucle y continúa con la siguiente." - ], - "metadata": { - "id": "6_U1A3i9AEdq" - } - }, - { - "cell_type": "markdown", - "source": [ - "# 14. Notación de porciones\n", - "\n", - "Cuando tenemos una colección de elementos indexados por posición (como una lista o una tupla), podemos acceder a una porción concreta utilizando la notación de porciones.\n", - "\n", - "Se utilizan los corchetes entre los que indicamos tres números separados por el carácter ':'. De esta manera\n", - "\n", - "lista\\[ini:fin:paso\\]\n", - "\n", - "Donde:\n", - "* ini es la posición del elemento primero en nuestra porción.\n", - "* fin es la posición del elemeto último (no incluido) de nuestra porción (el último incluido será el correspondiente a la posición fin -1).\n", - "* paso (optativo) indica la manera en la que tomaremos la porción: si es un número positivo tomaremos los elementos en el orden en el que aparecen, si es negativo los tomaremos en orden inverso (fin tiene que ser anterior a ini). Si la magnitud es 1, tomaremos todos los elementos, si es 2, tomaremos uno y saltaremos otro, si es 3, tomaremos uno y saltaremos 2, etc.\n", - "\n", - "Si dejamos ini o fin sin indicar se interpreta que la porción se toma desde el comienzo o el final respectivamente.\n", - "\n", - "Veamos algunos ejemplos:\n" - ], - "metadata": { - "id": "WQw19GRlOJrp" - } - }, - { - "cell_type": "code", - "source": [ - "lista = [10, 20, 30, 40, 50, 60]\n", - "\n", - "print(lista[2:5]) # tomamos del 2 al 5 (sin incluir el 5)\n", - "print(lista[4:]) # tomamos del 4 hasta el final\n", - "print(lista[:2]) # tomamos desde el principio hasta el 2 (sin incluir)\n", - "print(lista[1:6:2]) # tomamos 1 de cada 2 elementos desde el 1 hasta el 6 (sin incluir)\n", - "print(lista[4:1:-1]) # tomamos en orden inverso desde el 4 al 1 (sin incluir)\n", - "print(lista[:]) # tomamos desde el principio hasta el final (es como hacer una copia de la lista)\n", - "print(lista[::-1]) # tomamos desde el final hasta el principip (orden inverso) " - ], - "metadata": { - "id": "rxqQW9h2Hvja" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# 15. Entrada por teclado\n", - "\n", - "Si necesitamos hacer un programa o script interactivo, a menudo necesitaremos pedir algún valor al usuario por teclado.\n", - "\n", - "Python nos proporciona la función integrada \"input\" que nos sirve precisamente para eso. Al ejecutarse \"input\" el programa se queda esperando a que el usuario introduzca un valor y pulse intro. Posteriormente ese valor se guarda en la variable que queramos en formato string.\n", - "\n", - "Podemos hacer la conversión a un tipo numérico si así lo deseamos llamando a las funciones int o float." - ], - "metadata": { - "id": "BBXUukIZOJ3n" - } - }, - { - "cell_type": "code", - "source": [ - "entrada = input('Dame tu nombre, por favor: ')\n", - "print(f'¡Hola, {entrada}!')\n", - "entrada = input('Dame un número entero, por favor: ')\n", - "numero = int(entrada) # convertimos entrada a int\n", - "print(f'El número es {numero}')" - ], - "metadata": { - "id": "RnvW1ddeJU-1" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "# Ejercicio final: juego de adivinar un número entre 1 y 10\n", - "\n", - "Para finalizar este tutorial, voy a realizar un pequeño juego en el que el usuario tiene que adivinar un número generado al azar entre 1 y 10 y en el que solo tendrá 3 intentos para hacerlo.\n", - "\n", - "Para esto voy a utilizar muchas de las cosas contadas arriba. Además, comentaré el código para que todo quede perfectamente claro. Léelo con calma intentando comprender cada línea.\n", - "\n", - "Y, por supuesto, ¡puedes ejecutarlo para jugar tú!\n" - ], - "metadata": { - "id": "XCN38-bphFTC" - } - }, - { - "cell_type": "code", - "source": [ - "import random # necesitamos esta librería para poder generar un número al azar\n", - "\n", - "numero_secreto = random.randint(1, 10) # esto nos genera un número aleatorio entre 1 y 10\n", - "oportunidades = 3 # el número de oportunidades que nos quedan\n", - "acertado = False # esta variable nos servirá para saber si el usuario ha acertado\n", - "\n", - "print('* Bienvenido a nuestro pequeño juego del Tutorial Básico Interactivo de Código Pitón')\n", - "print() # imprimimos por pantalla una línea en blanco\n", - "print('Acabo de pensar un número secreto entre 1 y 10. Tienes tres oportunidades para')\n", - "print('adivinarlo. Te iré guiando un poco hacia la solución. ¡Suerte!')\n", - "print()\n", - "\n", - "# Hacemos un bucle mientras queden oportunidades y mientras no se haya acertado el número secreto\n", - "while oportunidades > 0 and not acertado:\n", - " \n", - " # Pedimos un número al usuario (y transformamos lo que escriba a entero mediante la función int)\n", - " # ¡Cuidado! Si lo que escribe el usuario no es un entero el programa generará un error\n", - " # El error puede ser controlado con try-except como vimos más arriba\n", - " numero = int(input('Dime un número entre 1 y 10: '))\n", - "\n", - " # Ahora vamos a hacer la comprobación\n", - " # e indicamos al usuario si el número secreto es mayor, menor o si lo ha averiguado\n", - " if numero < numero_secreto:\n", - " print('Te has quedado corto, el número secreto es más grande.')\n", - " elif numero > numero_secreto:\n", - " print('Te has pasado, el número secreto es más pequeño.')\n", - " else:\n", - " print(f'¡Enhorabuena! Has acertado en el intento {4-oportunidades}.')\n", - " acertado = True # ponemos acertado a cierto para que se detenga el bucle\n", - "\n", - " if not acertado: # si no ha acertado indicamos las oprtunidades que le quedan\n", - " oportunidades = oportunidades - 1 # restamos 1 a las oportunidades\n", - " print(f'Te quedan {oportunidades} oportunidades.')\n", - "\n", - " print()\n", - "\n", - "# cuando termine el bucle de juego mostramos el número de adinivinar\n", - "# y nos despedimos del usuario\n", - "\n", - "if not acertado: # si no se acierta el número se muestra por pantalla\n", - " print(f'* El número secreto era {numero_secreto}.')\n", - "\n", - "print('* ¡Gracias por jugar! ¡Hasta pronto!') \n", - "\n" - ], - "metadata": { - "id": "8hziKM46ho_K" - }, - "execution_count": null, - "outputs": [] - }, - { - "cell_type": "markdown", - "source": [ - "**¡Muchas gracias por haber usado este tutorial!**\n", - "\n", - "Recurre a él todas las veces que te haga falta hasta que te queden claros sus conceptos.\n", - "\n", - "Y no dejes de visitar [Código Pitón](https://www.codigopiton.com/).\n", - "\n", - "Un saludo,\n", - " \n", - "Juan.-\n", - "\n", - "P.S. ¿Te atreves a modificar el juego que hemos visto para que al terminar el juego el programa le pregunte al usuario si quiere volver a jugar? Si el usuario dice que sí, se vuelve a \"pensar\" un número secreto y se juega de nuevo. Si el usuario dice que no, se termina el programa." - ], - "metadata": { - "id": "0MrEzDjjnuD8" - } - } - ] -} \ No newline at end of file diff --git a/Workbench/Taller/listas.py b/Workbench/Taller/listas.py index 704f13cbe..fc5b6cc56 100644 --- a/Workbench/Taller/listas.py +++ b/Workbench/Taller/listas.py @@ -144,7 +144,7 @@ 2 C """ -# En este caso imprime la posición o puntero, y e contenido de la posición, vertical +# En este caso imprime la posición o puntero, y el contenido de la posición, vertical # Ejemplo 16 From eb3f44e7d3c39f1e96f185c2a7c1ee4dc48a0c82 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Mon, 23 Jan 2023 04:38:09 -0300 Subject: [PATCH 05/16] =?UTF-8?q?230123=5F0437=20Actualizaci=C3=B3n=20Root?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit From 7f0397d2f4b817d811aede3f42de0a412322a3d0 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Mon, 23 Jan 2023 04:50:38 -0300 Subject: [PATCH 06/16] Actualizar From 572d2aabfe8739774def48a43088b973e25f76d0 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Mon, 23 Jan 2023 08:44:25 -0300 Subject: [PATCH 07/16] 230123-0843 Mover Apuntes01.ipynb y cambio extension py --- Workbench/Taller/Apuntes01.ipynb | 80 -------------------- Workbench/Taller/{Funciones => Funciones.py} | 0 2 files changed, 80 deletions(-) delete mode 100644 Workbench/Taller/Apuntes01.ipynb rename Workbench/Taller/{Funciones => Funciones.py} (100%) diff --git a/Workbench/Taller/Apuntes01.ipynb b/Workbench/Taller/Apuntes01.ipynb deleted file mode 100644 index 7b28b9a52..000000000 --- a/Workbench/Taller/Apuntes01.ipynb +++ /dev/null @@ -1,80 +0,0 @@ -{ - "cells": [ - { - "cell_type": "code", - "execution_count": 1, - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "Hello World\n" - ] - } - ], - "source": [ - "print (\"Hello World\")" - ] - }, - { - "cell_type": "code", - "execution_count": 1, - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "página1\n", - "página2\n", - "página3\n", - "página4\n" - ] - } - ], - "source": [ - "libro = ['página1', 'página2', 'página3', 'página4']\n", - "marcapaginas = iter(libro)\n", - "print(next(marcapaginas))\n", - "print(next(marcapaginas))\n", - "print(next(marcapaginas))\n", - "print(next(marcapaginas))" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [] - } - ], - "metadata": { - "kernelspec": { - "display_name": "Python 3", - "language": "python", - "name": "python3" - }, - "language_info": { - "codemirror_mode": { - "name": "ipython", - "version": 3 - }, - "file_extension": ".py", - "mimetype": "text/x-python", - "name": "python", - "nbconvert_exporter": "python", - "pygments_lexer": "ipython3", - "version": "3.10.6 (tags/v3.10.6:9c7b4bd, Aug 1 2022, 21:53:49) [MSC v.1932 64 bit (AMD64)]" - }, - "orig_nbformat": 4, - "vscode": { - "interpreter": { - "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" - } - } - }, - "nbformat": 4, - "nbformat_minor": 2 -} diff --git a/Workbench/Taller/Funciones b/Workbench/Taller/Funciones.py similarity index 100% rename from Workbench/Taller/Funciones rename to Workbench/Taller/Funciones.py From edef9841cba5a460194bdeaec337c040d143457b Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Mon, 23 Jan 2023 09:00:41 -0300 Subject: [PATCH 08/16] 230123-0900 Creacion Archivo txt, simula prueba --- Estaesunaprueba.txt | 1 + 1 file changed, 1 insertion(+) create mode 100644 Estaesunaprueba.txt diff --git a/Estaesunaprueba.txt b/Estaesunaprueba.txt new file mode 100644 index 000000000..fd5fe2a25 --- /dev/null +++ b/Estaesunaprueba.txt @@ -0,0 +1 @@ +Subir prueba \ No newline at end of file From 08633da0897604297cefba45bba26a987a08ecdc Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Wed, 25 Jan 2023 05:51:06 -0300 Subject: [PATCH 09/16] 2501230549 Sync --- Workbench/Substrings.py | 29 +++++++++++++++++++++++++++ Workbench/Taller/Clases.py | 34 ++++++++++++++++++++++++++++++++ Workbench/Taller/Funciones.py | 7 ++++++- Workbench/Taller/Prueba240123.py | 0 4 files changed, 69 insertions(+), 1 deletion(-) create mode 100644 Workbench/Substrings.py create mode 100644 Workbench/Taller/Clases.py create mode 100644 Workbench/Taller/Prueba240123.py diff --git a/Workbench/Substrings.py b/Workbench/Substrings.py new file mode 100644 index 000000000..40ea5c555 --- /dev/null +++ b/Workbench/Substrings.py @@ -0,0 +1,29 @@ +# Buscar una subcadena con index +import re +obj_iter="palabra" +varany = int +pos_ini = int +pos_fin = int +obj_iter.sub[varany, pos_ini, pos_fin]) +#es similar a find() pero en caso de que no se encuentre la subcadena sub lanza la excepción ValueError. +cadena = 'me gusta la mermelada' +cadena.index('lo') +#La cadena 'lo' no existe, por lo que provocará un error +# Traceback (most recent call last): +# File "", line 1, in +# ValueError: substring not found + +cadena.index('la') +9 +# Encontrar la última posición de una subcadena con RFIND +cadena = 'me gusta la mermelada' +cadena.rfind('la') +print (cadena.rfind('la')) +# 17 +print (cadena.rfind('lo')) +# -1 +# Encontrar la última posición de una subcadena con RINDEX +print (cadena.rindex('la')) +# 17 +# print (cadena.rindex('lo')) +# Debe arrojar un error porque no existe la cadena (ValueError: substring not found) diff --git a/Workbench/Taller/Clases.py b/Workbench/Taller/Clases.py new file mode 100644 index 000000000..f37c01c35 --- /dev/null +++ b/Workbench/Taller/Clases.py @@ -0,0 +1,34 @@ +class Car1: + def __init__(self, color, aceleracion): + self.color = color + self.aceleracion = aceleracion + self.velocidad = 0 + self.ruedas = 4 + self.direccion = 90 + def Acelera(self): + self.acelera = self.aceleracion + self.velocidad + def frena(self): + v.frena = self.aceleracion - self.velocidad + if v < 0: + v = 0 + self.velocidad = 0 + + +class Perro (): + # El método __init__ es llamado al crear el objeto + def __init__(self, nombre, raza): + print(f"Creando perro {nombre}, {raza}") + # Atributos de instancia + self.nombre = nombre + self.raza = raza + +c1 = Car1('rojo', 20) +print (c1.color) +# rojo +print (c1.ruedas) +# 4 +c2 = Car1('azul', 30) +print(c2.color) +# azul +print(c2.ruedas) +# 4 \ No newline at end of file diff --git a/Workbench/Taller/Funciones.py b/Workbench/Taller/Funciones.py index cdcc063de..82282c2f9 100644 --- a/Workbench/Taller/Funciones.py +++ b/Workbench/Taller/Funciones.py @@ -11,7 +11,12 @@ # Ejemplo 1 def misuma (a,b): # Esta es una función, toma dos enteros a,b y los suma - return a+b # El calculo viene después de la palabra return + """ + Los valores deben ser números + """ + suma =a+b + return suma # El calculo viene después de la palabra return +print (misuma(5,6)) res= misuma (2,3) # Uso la función, le paso los parámetros 2,3 y, el resultado lo almaceno en la variable res print ("Resultado de sumar 2 y 3, es ", res) # Puedo ver su contenido con un print diff --git a/Workbench/Taller/Prueba240123.py b/Workbench/Taller/Prueba240123.py new file mode 100644 index 000000000..e69de29bb From 00e22c49bcc2c31b8d3031dc2c3290d835aaaf6d Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Thu, 26 Jan 2023 16:47:23 -0300 Subject: [PATCH 10/16] 26011646 Up --- .../Preliminares - 01-checkpoint.ipynb" | 29 +- .../Preliminares - 01.ipynb" | 9 +- Workbench/Substrings.py | 72 ++- Workbench/Taller/Clases.py | 177 +++++- Workbench/Taller/HW08_POO_Sol.py | 352 +++++++++++ Workbench/Taller/Herramientas.py | 0 Workbench/Taller/LibroAlumnos.py | 76 +++ Workbench/Taller/Mix_ejercicios.py | 302 ++++----- Workbench/Taller/Problemasumas.py | 36 ++ Workbench/Taller/TodasLasOperaciones.py | 27 + Workbench/Taller/listas.py | 367 ++++++++--- Workbench/Taller/pruebaerror.ipynb | 586 ++++++++++++++++++ 12 files changed, 1745 insertions(+), 288 deletions(-) create mode 100644 Workbench/Taller/HW08_POO_Sol.py create mode 100644 Workbench/Taller/Herramientas.py create mode 100644 Workbench/Taller/LibroAlumnos.py create mode 100644 Workbench/Taller/Problemasumas.py create mode 100644 Workbench/Taller/TodasLasOperaciones.py create mode 100644 Workbench/Taller/pruebaerror.ipynb diff --git "a/01 - Introducci\303\263n a la Programaci\303\263n/.ipynb_checkpoints/Preliminares - 01-checkpoint.ipynb" "b/01 - Introducci\303\263n a la Programaci\303\263n/.ipynb_checkpoints/Preliminares - 01-checkpoint.ipynb" index a62bcd0ee..b91bde2df 100644 --- "a/01 - Introducci\303\263n a la Programaci\303\263n/.ipynb_checkpoints/Preliminares - 01-checkpoint.ipynb" +++ "b/01 - Introducci\303\263n a la Programaci\303\263n/.ipynb_checkpoints/Preliminares - 01-checkpoint.ipynb" @@ -564,7 +564,7 @@ } ], "source": [ - " mi_tupla.count('Rojo')" + "mi_tupla.count('Rojo')" ] }, { @@ -1308,23 +1308,11 @@ }, { "cell_type": "code", - "execution_count": 14, + "execution_count": 1, "metadata": {}, - "outputs": [ - { - "ename": "NameError", - "evalue": "name 'divisor' is not defined", - "output_type": "error", - "traceback": [ - "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m", - "\u001b[1;31mNameError\u001b[0m Traceback (most recent call last)", - "\u001b[1;32m~\\AppData\\Local\\Temp/ipykernel_10044/1862935505.py\u001b[0m in \u001b[0;36m\u001b[1;34m\u001b[0m\n\u001b[1;32m----> 1\u001b[1;33m \u001b[0mprint\u001b[0m\u001b[1;33m(\u001b[0m\u001b[0mdivisor\u001b[0m\u001b[1;33m)\u001b[0m\u001b[1;33m\u001b[0m\u001b[1;33m\u001b[0m\u001b[0m\n\u001b[0m", - "\u001b[1;31mNameError\u001b[0m: name 'divisor' is not defined" - ] - } - ], + "outputs": [], "source": [ - "print(divisor)" + "# print(divisor)" ] }, { @@ -2322,7 +2310,7 @@ ], "metadata": { "kernelspec": { - "display_name": "Python 3 (ipykernel)", + "display_name": "Python 3", "language": "python", "name": "python3" }, @@ -2336,7 +2324,12 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.9.7" + "version": "3.10.6" + }, + "vscode": { + "interpreter": { + "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" + } } }, "nbformat": 4, diff --git "a/01 - Introducci\303\263n a la Programaci\303\263n/Preliminares - 01.ipynb" "b/01 - Introducci\303\263n a la Programaci\303\263n/Preliminares - 01.ipynb" index a0181f9c0..325046170 100644 --- "a/01 - Introducci\303\263n a la Programaci\303\263n/Preliminares - 01.ipynb" +++ "b/01 - Introducci\303\263n a la Programaci\303\263n/Preliminares - 01.ipynb" @@ -2342,7 +2342,7 @@ ], "metadata": { "kernelspec": { - "display_name": "Python 3 (ipykernel)", + "display_name": "Python 3", "language": "python", "name": "python3" }, @@ -2356,7 +2356,12 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.9.7" + "version": "3.10.6 (tags/v3.10.6:9c7b4bd, Aug 1 2022, 21:53:49) [MSC v.1932 64 bit (AMD64)]" + }, + "vscode": { + "interpreter": { + "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" + } } }, "nbformat": 4, diff --git a/Workbench/Substrings.py b/Workbench/Substrings.py index 40ea5c555..0c47a6cad 100644 --- a/Workbench/Substrings.py +++ b/Workbench/Substrings.py @@ -4,21 +4,67 @@ varany = int pos_ini = int pos_fin = int -obj_iter.sub[varany, pos_ini, pos_fin]) -#es similar a find() pero en caso de que no se encuentre la subcadena sub lanza la excepción ValueError. -cadena = 'me gusta la mermelada' -cadena.index('lo') -#La cadena 'lo' no existe, por lo que provocará un error +# obj_iter.sub[varany, pos_ini, pos_fin]) +# es similar a find() pero en caso de que no se encuentre la subcadena sub lanza la excepción ValueError. +# TypeError : Ocurre cuando se aplica una operación o función a un dato del tipo inapropiado. +# ZeroDivisionError : Ocurre cuando se itenta dividir por cero. +# OverflowError : Ocurre cuando un cálculo excede el límite para un tipo de dato numérico. +# IndexError : Ocurre cuando se intenta acceder a una secuencia con un índice que no existe. +# KeyError : Ocurre cuando se intenta acceder a un diccionario con una clave que no existe. +# FileNotFoundError : Ocurre cuando se intenta acceder a un fichero que no existe en la ruta indicada. +# ImportError : Ocurre c +# Manejo de excepciones con TRY y EXCEPT +# try: + # Codigo a ejecutar + # Pero podria haber errores en este bloque +# +# except : + # Haz esto para manejar la excepcion + # El bloque except se ejecutara si el bloque try lanza un error +# +# else: + # Esto se ejecutara si el bloque try se ejecuta sin errores +# +# finally: + # Este bloque se ejecutara siempre +print ("") +frase = 'me gusta la mermelada' +busca = "lo" +try: + cadena = frase + print (cadena.index(busca)) + # La cadena 'lo' no existe, por lo que provocará un error +except ValueError: + print ("En el texto ", "'",cadena,"'", "no existe la cadena", busca) + +# Otro ejemplo, creamos una función "dividir" que divide dos números +num = 10 +div = 0 +def dividir(num,div): + try: + res = dividir(num, div) + print(res) + except ZeroDivisionError: + print("Trataste de dividir entre cero :( ") + return num/div +#Sin embargo no controla la división por 0, que no esta definida y devolverá un error +#Aquí usamos el control de errores con try y except + # Traceback (most recent call last): -# File "", line 1, in +# File "", line 1, in # ValueError: substring not found -cadena.index('la') -9 -# Encontrar la última posición de una subcadena con RFIND +# Ejemplo +# Buscar la posición de una cadena, en el ejemplo "la" +# Debe retornar la pos anterior a dónde incia la cadena, en este caso 9 +print ("La posición anterior a iniciar la primera cadena 'la' que encuentra, es la pos ", cadena.index('la')) +print ("") + +# Ejemplo +# Encontrar la última posición de una subcadena con RFIND, la busca todas y devuelve la ÚLTIMA cadena = 'me gusta la mermelada' -cadena.rfind('la') -print (cadena.rfind('la')) +cadena.rfind('la') # ocupan las pos 18 y 19 +print ("La última posición anterior, a iniciar la cadena 'la', es la pos ", cadena.rfind('la')) # 17 print (cadena.rfind('lo')) # -1 @@ -27,3 +73,7 @@ # 17 # print (cadena.rindex('lo')) # Debe arrojar un error porque no existe la cadena (ValueError: substring not found) +import re +texto = "tres tristes tigres comen trigo en un trigal" +busqueda = re.sub(" ", "-", texto) +print(busqueda) \ No newline at end of file diff --git a/Workbench/Taller/Clases.py b/Workbench/Taller/Clases.py index f37c01c35..d071497fb 100644 --- a/Workbench/Taller/Clases.py +++ b/Workbench/Taller/Clases.py @@ -1,3 +1,40 @@ +#******************************************************************* +#* * +#* TALLLER CLASES y OBJETOS * +#* * +#******************************************************************* +# En Python todo son clases, porque es un lenguaje flexible +# Una clase es la abstracción de un objeto, un molde para crear entidades similares. +# Una clase consta de ATRIBUTOS y MÉTODOS +# Con los atributos o CONSTRUCTOR se instancia (crea) el objeto, es una copia +# Con los métodos se manipula, se hacen cálculos, se accede al objeto. +# Un ATRIBUTO es una carcterística, cuantificable o no, que define al objeto, ej, su color, número de patas +# Como ATRIBUTO, a un objeto le puedo definir cualquuier cosa ej diccionario, listas, tuplas +# Agregamos los atributos que necesitemos y si es numérico se inicializan con algún valor, ej velocidad=0. +# Los ATRIBUTOS o se deben acceder desde fuera de la clase(ej print(a1.color), a1 es un objeto animal, +# con un atributo llamado color, en principio, la sentencia devolvería el color de a1, con el que fue +# creado, pero la buena práctica dice que debemos crear un método para acceder a su color y luego podemos +# imprimir lo que retorna el método. +# Para proteger un ATRIBUTO, se le agregan dos lineas bajas o underscore al INICIO del atributo. +# Luego creo los métodos o funciones asociados a él o los ATRIBUTOS, similar a los geters y seters. +# Este es un ejemplo de ENCAPSULACIÓN +# Un MÉTODO, básicamente, es una FUNCIóN, usada para ejecutar procedimientos u operaciones sobre la CLASE +# con los ATRIBUTOS de la CLASE. Por ejemplo, un objeto auto, tiene un atributo velocidad, por lo que puede acelerar o frenar. +# Qué es ABSTRACCIÓN => Separar los datos +# Qué es ENCAPSULAMIENTO => Proteger el objeto (lo accedo o conozco a través de sus métodos) +# Qué es HERENCIA => Permite crear nuevas clases heredando sus atributos,métodos y agregando nuevos, +# ej. Animales=>Humano +# Qué es POLIMORFISMO => Mismo nombre pero distinto comportamiento +# Se usa la palabara reservada class, seguida de __INIT__, y detro de los paréntesis (), la primera palabra +# DEBE ser self, seguido de sus atributos. A esto se denomina el método CONSTRUCTOR de la clase. +# SELF es una palabra reservada que le dice a Python que lo que viene son atributos y no genere conflictos. +# Para que la ayuda o help(), despliegue un mensaje de qué hace una CLASE o FUNCIÓN, se abren +# tres comillas dobles, se agrega una breve descripción con los tipos de varibles o sintaxis, y se vuelve +# a cerrar con tres comillas dobles. +# + +# Ej 1) Crear una clase que cree objetos del tipo automóvil con los atributos color y aceleración + class Car1: def __init__(self, color, aceleracion): self.color = color @@ -31,4 +68,142 @@ def __init__(self, nombre, raza): print(c2.color) # azul print(c2.ruedas) -# 4 \ No newline at end of file +# 4 + +# Ej 5 Crear una función que cree la clase Emprendedor +# El constructor de la clase Emprenddedor recibe los valores +# nombre (str), apellido (str), libros (array), mascotas (array de str) +# Inicializar las propiedades de la clase Emprendedor con los valores recibidos +class Emprendedor: + """ + recibe los valores nombre (str), apellido (str), libros (array), + mascotas (array de str) + """ + def __init__(self, nombre, apellido, libros, mascotas): + self.nombre = nombre + self. apellido = apellido #Este es el constructor de la clase + self.libros = libros + self. mascotas = mascotas + +# Estos los métodos de la clase Emprendedor + def getNombre (self): + pass + def getApellido (self): + pass + def getLibros (self): + pass + def getMascotas (self): + pass + def setNombre (self): + pass + def setApellido (self): + pass + def setLibros (self): + pass + def setMascotas (self): + pass + +# Ej 6 Creamos el objeto emp1 con el constructor Emprendedor +emp1 = Emprendedor ("Lionel", "Cordova", ["Dos palmeras", 1917, 'abc123'], ('Perro', 'Gato')) +print ("") +print (type(emp1)) # Debe retornar +print (type(emp1.nombre)) # Debe retornar +print (type(emp1.apellido)) # Debe retornar +print (type(emp1.libros)) # Debe retornar +print (type(emp1.mascotas)) # Debe retornar +print("") + +# Ej 8 ENCAPSULAMIENTO +# Encapsular, consiste en hacer que los atributos o métodos internos a una clase no se puedan +# acceder ni modificar desde fuera, sino que tan solo el propio objeto pueda acceder a ellos. +# Python por defecto NO OCULTA los atributos y métodos de una clase al exterior. +# +class miSaludo: + atributo_clase = "Hola" + def __init__(self, atributo_instancia): + self.atributo_instancia = atributo_instancia +# Mira lo que pasa +prueba_mi_clase = miSaludo("Que tal") #Instancio el objeto con el parámetro 'Que tal'=atributo_instancia +print (prueba_mi_clase.atributo_clase) # Le he pasado el valor de la variable +print (prueba_mi_clase.atributo_instancia) # Le he pasado el parámetro de la instancición de la clase + +# 'Hola' +# 'Que tal' + +# Primera reflexión: Ambos atributos son perfectamente accesibles desde el exterior!, va contra las buenas prácticas. +# Hay métodos o atributos que queremos que pertenezcan sólo a la clase o al objeto, y que sólo puedan ser accedidos +# por los mismos. Para ello podemos usar la doble __ (underscore) para ocultar un atributo o método. +# Esto hará que Python los interprete como “privados”, y ya no podrán ser accedidos desde el exterior. +# Eso es "ENCAPSULAMIENTO" +# Volvamos a revisar el ejemplo +class Clase: + atributo_clase = "Hola" # Es accesible desde el exterior + __atributo_clase = "Hola" # No es accesible desde el exterior de la clase + # Acá protegemos el método, ahora no es accesible desde el exterior + def __mi_metodo(self): + print("Este es un ejemplo de ENCAPSULAMIENTO") + self.__variable = 0 # La variable, también la hacemos privada + + # Este método lo exponemos para acceder a la clase, debe ser accesible desde el exterior + def metodo_normal(self): + # El método si es accesible desde el interior + self.__mi_metodo() + +mi_clase = Clase() +#mi_clase.__atributo_clase # Error! El atributo no es accesible +#mi_clase.__mi_metodo() # Error! El método no es accesible +mi_clase.atributo_clase # Ok! +mi_clase.metodo_normal() # Ok! +# Podemos hacer uso de 'dir' para ver el listado de métodos y atributos de nuestra clase que son PUBLICOS. +# Al hacer 'privados' el '_atributo_clase' y '_mi_metodo', no los podremos encontrar en la lista. +print(dir(mi_clase)) +#['_Clase__atributo_clase', '_Clase__mi_metodo', '_Clase__variable', +#'__class__', '__delattr__', '__dict__', '__dir__', '__doc__', '__eq__', +#'__format__', '__ge__', '__getattribute__', '__gt__', '__hash__', '__init__', +#'__init_subclass__', '__le__', '__lt__', '__module__', '__ne__', '__new__', +#'__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', +#'__str__', '__subclasshook__', '__weakref__', 'atributo_clase', 'metodo_normal'] + +# Se puede acceder a los atribtos y métodos ocultos de una clase, como '__atributo_clase' y a '__mi_metodo', +# haciendo un poco de trampa. +# Python los guarda con un nombre distinto para ocultarlos (encapsularlos) y evitar su uso indebido. +# Podemos llamarlos con un 'truco sucio' de la siguiente manera aunque, por buenas prácticas, no es recomendable. +print("") +a = mi_clase._Clase__atributo_clase +print ("Escribiendo 'la ruta completa' del atributo oculto") +print ("de esta forma: 'mi_clase._Clase__atributo_clase', retornará su contenido") +print ("en este caso ", a) +# 'Hola' +print ("Caso 2, al escribir 'la ruta completa' del método así 'mi_clase._Clase__mi_metodo', retorna su contenido.") +print ("en este caso ", mi_clase._Clase__mi_metodo()) +# Conclusión, hay una precedencia en las operaciones...la función primero que el +# print, y se repite porque imprime la función y lo que retorna que es none. +# Por esa razón, a veces parece que se imprime en otra parte. + + +# Ej 7 POLIMORFISMO +# Suponga que tiene una clase ANIMAL, que tiene un atributo HABLAR +print("") +class Animal: # Creamos la clase con 1 atributo hablar + def hablar(self): + pass +# Por otro lado, creamos dos clases: Perro y Gato, que heredan de la anterior. +# Además, implementan el método hablar() de formas distintas. +# Entonces: +print ("") +class Perro(Animal): # Nótese que en este caso se le pasa como parámetro, la otra + def hablar(self): # clase entre paréntesis. + print("Guau!") + +class Gato(Animal): + def hablar(self): + print("Miau!") + +# Ahora creamos un objeto de cada clase y llamamos al método hablar(). +# Podemos observar que cada animal se comporta de manera distinta al usar hablar(). + +for sonidos in Perro(), Gato(): + sonidos.hablar() +# Guau! +# Miau! + diff --git a/Workbench/Taller/HW08_POO_Sol.py b/Workbench/Taller/HW08_POO_Sol.py new file mode 100644 index 000000000..b411e5ab9 --- /dev/null +++ b/Workbench/Taller/HW08_POO_Sol.py @@ -0,0 +1,352 @@ + +# 1) Crear la clase vehículo que contenga los atributos: +# 'Color' +# 'Tipo' (Si es moto, auto, camioneta ó camión) +# 'Cilindrada' (en decimal, e.g. 1200cc = 1.2 cc de motor) + +class Vehiculo: + def __init__(self, color, tipo, cilindrada): + self.color = color + self.tipo = tipo + self.cilindrada = cilindrada + +# 2) A la clase Vehiculo creada en el punto 1, agregar los siguientes métodos: +# Acelerar => El ejercicio no lo dice, pero necesito crear lo atributos que usaré +# Frenar para mostrar que mi objeto vehículo acelera y frena. +# Doblar Las acciones requieren de respectivo atributo, si doblo (acción), +# necesito que se refiera a un atributo de la clase, en este caso +# la 'dirección' o rumbo que lleva el móvil. + +class Vehiculo: + def __init__(self, color, tipo, cilindrada): + self.color = color + self.tipo = tipo + self.cilindrada = cilindrada + self.velocidad = 0 # Aquí creamos el atributo velocidad, no se requieren 2 + self.direccion = 0 # Aquí creamos el atributo velocidad + + def Acelerar(self, vel): # Recibe un parámetro velocidad + self.velocidad += vel # Este es método que modifica el atributo velocidad + + def Frenar(self, vel): # Recibe un parámetro velocidad, es sólo un valor + self.velocidad -= vel # Calcula la nueva velocidad + + def Doblar(self, grados): # Recibe la cantidad de grados del giro (0-360) + self.direccion += grados # Calcula la nueva dirección + +# 3) Instanciar 3 objetos de la clase vehículo y ejecutar sus métodos, probar luego el resultado + +a1 = Vehiculo ('rojo', 'auto', 2) +a2 = Vehiculo ('blanco', 'camioneta', 3.6) +a3 = Vehiculo ('negro', 'moto', 1) + +a1.Acelerar(40) # Si se hace un print se verá que el contenido de los atributos +a2.Acelerar(60) # velocidad y dirección, han cambiado +a3.Acelerar(30) # Para mostrar el contenido del atributo usar la sentencia +a1.Doblar(30) +a3.Doblar(-30) +a2.Frenar(-50) + +# 4) Agregar a la clase Vehiculo, un método que muestre su estado, es decir, a que velocidad se encuentra y su dirección. Y otro método que muestre color, tipo y cilindrada + +class Vehiculo: + def __init__(self, color, tipo, cilindrada): + self.color = color + self.tipo = tipo + self.cilindrada = cilindrada + self.velocidad = 0 + self.direccion = 0 + + def Acelerar(self, vel): + self.velocidad += vel + + def Frenar(self, vel): + self.velocidad -= vel + + def Doblar(self, grados): + self.direccion += grados + + def Estado(self): + print('La velocidad actual es :', self.velocidad, '- y su rumbo actual es:', self.direccion, 'grados') + + def Detalle(self): + print('Soy del tipo ', self.tipo, 'de color', self.color, 'y mi cilindrada es de', self.cilindrada, 'litros') + +a1 = Vehiculo('rojo', 'auto', 2) +a1.Detalle() + +a1.Estado() +a1.Acelerar(30) +a1.Estado() + + +# 5) Crear una clase que permita utilizar las funciones creadas en la práctica del módulo 6
+# Verificar Primo
+# Valor modal
+# Conversión grados
+# Factorial
+ +# In[33]: + + +class Herramientas: + def __init__(self) -> None: + pass + + def verifica_primo(self, nro): + es_primo = True + for i in range(2, nro): + if nro % i == 0: + es_primo = False + break + return es_primo + + def valor_modal(self, lista, menor): + lista_unicos = [] + lista_repeticiones = [] + if len(lista) == 0: + return None + if (menor): + lista.sort() + else: + lista.sort(reverse=True) + for elemento in lista: + if elemento in lista_unicos: + i = lista_unicos.index(elemento) + lista_repeticiones[i] += 1 + else: + lista_unicos.append(elemento) + lista_repeticiones.append(1) + moda = lista_unicos[0] + maximo = lista_repeticiones[0] + for i, elemento in enumerate(lista_unicos): + if lista_repeticiones[i] > maximo: + moda = lista_unicos[i] + maximo = lista_repeticiones[i] + return moda, maximo + + def conversion_grados(self, valor, origen, destino): + valor_destino = None + if (origen == 'celsius'): + if (destino == 'celsius'): + valor_destino = valor + elif (destino == 'farenheit'): + valor_destino = (valor * 9 / 5) + 32 + elif (destino == 'kelvin'): + valor_destino = valor + 273.15 + else: + print('Parámetro de Destino incorrecto') + elif (origen == 'farenheit'): + if (destino == 'celsius'): + valor_destino = (valor - 32) * 5 / 9 + elif (destino == 'farenheit'): + valor_destino = valor + elif (destino == 'kelvin'): + valor_destino = ((valor - 32) * 5 / 9) + 273.15 + else: + print('Parámetro de Destino incorrecto') + elif (origen == 'kelvin'): + if (destino == 'celsius'): + valor_destino = valor - 273.15 + elif (destino == 'farenheit'): + valor_destino = ((valor - 273.15) * 9 / 5) + 32 + elif (destino == 'kelvin'): + valor_destino = valor + else: + print('Parámetro de Destino incorrecto') + else: + print('Parámetro de Origen incorrecto') + return valor_destino + + def factorial(self, numero): + if(type(numero) != int): + return 'El numero debe ser un entero' + if(numero < 0): + return 'El numero debe ser pisitivo' + if (numero > 1): + numero = numero * self.factorial(numero - 1) + return numero + + +# In[34]: + + +h = Herramientas() + + +# 6) Probar las funciones incorporadas en la clase del punto 5 + +# In[28]: + + +h.verifica_primo(7) + + +# In[29]: + + +listado = [1,8,2,5,4,8,10,7] +moda, repe = h.valor_modal(listado, True) +print('El valor modal es', moda, 'y se reptie', repe, 'veces') + + +# In[31]: + + +h.conversion_grados(10, 'celsius', 'kelvin') + + +# In[35]: + + +h.factorial(6) + + +# 7) Es necesario que la clase creada en el punto 5 contenga una lista, sobre la cual se aplquen las funciones incorporadas + +# In[55]: + + +class Herramientas: + def __init__(self, lista_numeros): + self.lista = lista_numeros + + def verifica_primo(self): + for i in self.lista: + if (self.__verifica_primo(i)): + print('El elemento', i, 'SI es un numero primo') + else: + print('El elemento', i, 'NO es un numero primo') + + def conversion_grados(self, origen, destino): + for i in self.lista: + print(i, 'grados', origen, 'son', self.__conversion_grados(i, origen, destino),'grados',destino) + + def factorial(self): + for i in self.lista: + print('El factorial de ', i, 'es', self.__factorial(i)) + + def __verifica_primo(self, nro): + es_primo = True + for i in range(2, nro): + if nro % i == 0: + es_primo = False + break + return es_primo + + def valor_modal(self, menor): + lista_unicos = [] + lista_repeticiones = [] + if len(self.lista) == 0: + return None + if (menor): + self.lista.sort() + else: + self.lista.sort(reverse=True) + for elemento in self.lista: + if elemento in lista_unicos: + i = lista_unicos.index(elemento) + lista_repeticiones[i] += 1 + else: + lista_unicos.append(elemento) + lista_repeticiones.append(1) + moda = lista_unicos[0] + maximo = lista_repeticiones[0] + for i, elemento in enumerate(lista_unicos): + if lista_repeticiones[i] > maximo: + moda = lista_unicos[i] + maximo = lista_repeticiones[i] + return moda, maximo + + def __conversion_grados(self, valor, origen, destino): + valor_destino = None + if (origen == 'celsius'): + if (destino == 'celsius'): + valor_destino = valor + elif (destino == 'farenheit'): + valor_destino = (valor * 9 / 5) + 32 + elif (destino == 'kelvin'): + valor_destino = valor + 273.15 + else: + print('Parámetro de Destino incorrecto') + elif (origen == 'farenheit'): + if (destino == 'celsius'): + valor_destino = (valor - 32) * 5 / 9 + elif (destino == 'farenheit'): + valor_destino = valor + elif (destino == 'kelvin'): + valor_destino = ((valor - 32) * 5 / 9) + 273.15 + else: + print('Parámetro de Destino incorrecto') + elif (origen == 'kelvin'): + if (destino == 'celsius'): + valor_destino = valor - 273.15 + elif (destino == 'farenheit'): + valor_destino = ((valor - 273.15) * 9 / 5) + 32 + elif (destino == 'kelvin'): + valor_destino = valor + else: + print('Parámetro de Destino incorrecto') + else: + print('Parámetro de Origen incorrecto') + return valor_destino + + def __factorial(self, numero): + if(type(numero) != int): + return 'El numero debe ser un entero' + if(numero < 0): + return 'El numero debe ser pisitivo' + if (numero > 1): + numero = numero * self.__factorial(numero - 1) + return numero + + +# In[56]: + + +h = Herramientas([1,1,2,5,8,8,9,11,15,16,16,16,18,20]) + + +# In[57]: + + +h.conversion_grados('celsius','farenheit') + + +# In[58]: + + +h.verifica_primo() + + +# In[59]: + + +moda, repe = h.valor_modal(False) +print('El valor modal es', moda, 'y se reptie', repe, 'veces') + + +# In[60]: + + +h.factorial() + + +# 8) Crear un archivo .py aparte y ubicar allí la clase generada en el punto anterior. Luego realizar la importación del módulo y probar alguna de sus funciones + +# In[1]: + + +from herramientas import * + + +# In[2]: + + +h2 = Herramientas([1,1,2,3,5,6,8,8]) + + +# In[3]: + + +h2.verifica_primo() \ No newline at end of file diff --git a/Workbench/Taller/Herramientas.py b/Workbench/Taller/Herramientas.py new file mode 100644 index 000000000..e69de29bb diff --git a/Workbench/Taller/LibroAlumnos.py b/Workbench/Taller/LibroAlumnos.py new file mode 100644 index 000000000..dc300f7d8 --- /dev/null +++ b/Workbench/Taller/LibroAlumnos.py @@ -0,0 +1,76 @@ + +class Alumnos: + + def __init__(self): + self.nombres=[] + self.notas=[] + +# El método menu muestra una serie de opciones y solicita al usuario que +# elija una de ellas, según cual de ellas selecciona procede a llamar al método respectivo: + def menu(self): + opcion=0 + while opcion!=4: + print("1- Cargar alumnos") + print("2- Listar alumnos") + print("3- Listado de alumnos con notas mayores o iguales a 7") + print("4- Finalizar programa") + opcion=int(input("Ingrese su opcion:")) + if opcion==1: + self.cargar() + elif opcion==2: + self.listar() + elif opcion==3: + self.notas_altas() +# Algo que no utilizamos hasta ahora del lenguaje Python, es una forma +# simplificada de if anidados con la sentencia elif: + if opcion==1: + self.cargar() + elif opcion==2: + self.listar() + elif opcion==3: + self.notas_altas() +# Nosotros, hasta ahora, lo resolvíamos y podemos sin problema seguir utilizando +# la sintaxis:: + if opcion==1: + self.cargar() + else: + if opcion==2: + self.listar() + else: + if opcion==3: + self.notas_altas() +# Pero podemos comprobar que, si hay muchos if anidados la nueva sintaxis es más +# clara. +# Un ciclo WHILE, repite el método menu, mientras no se ingrese como opción en la +# variable local, el valor 4. + +# El método cargar, se llama desde el método menu, en el mismo procedemos a cargar +# las dos listas paralelas, con los nombres de alumnos y sus notas: + + def cargar(self): + for x in range(5): + nom=input("Ingrese nombre del alumno:") + self.nombres.append(nom) + no=int(input("Nota del alumno:")) + self.notas.append(no) + +# El método listar muestra las dos listas paralelas por completo e imprime una línea separadora para que se vea in forma más clara: + + def listar(self): + print("Listado completo de alumnos") + for x in range(5): + print(self.nombres[x],self.notas[x]) + print("_____________________") +# Finalmente el método notas_altas muestra solo los elementos de las listas cuyas +# notas sean igual o superior a 7: + + def notas_altas(self): + print("Alumnos con notas superiores o iguales a 7") + for x in range(5): + if self.notas[x]>=7: + print(self.nombres[x],self.notas[x]) + print("_____________________") +# bloque principal + +alumnos=Alumnos() +alumnos.menu() diff --git a/Workbench/Taller/Mix_ejercicios.py b/Workbench/Taller/Mix_ejercicios.py index c7df605fb..56a8fa9d0 100644 --- a/Workbench/Taller/Mix_ejercicios.py +++ b/Workbench/Taller/Mix_ejercicios.py @@ -1,221 +1,153 @@ -Variables +# Variables + +# Ej 1) Cocatenar cadenas de caracteres, deben ser del mismo tipo (str+str) + a = 'Hola ' b = 'Mundo !' +# Ej 2) Sumar dos enteros, puedo imprimir directo el resultado + print(a + b) -# Hola Mundo ! + +# Ej 3) Mismo ejemplo, almaceno en variable x = 3 y = 12 -print(x + y) -15 -print(a + x) -""" -"---------------------------------------------------------------------------" +print(x + y) # 15 -TypeError Traceback (most recent call last) -~\AppData\Local\Temp/ipykernel_18232/136165486.py in -----> 1 print(a + x) +# Ej 4) Manejo de errores por tipo, no sumar tipos distintos. +# print(a + x)==> Da un error porque son de distinto tipo, concatencación +# a= string Para que funcione, puedo cambiar el tipo a str(3) +# x= int quedaría como 'Hola 3' -TypeError: can only concatenate str (not "int") to str -""" -# Dividir "y" entre "x" +# Ej 5) Dividir "y" entre "x" y = 9 x = 3 -print(y/x) -3.0 -# Potencia de "y" elevado a la "x" +print(y/x) # => 3.0 + +# Ej 6) Potencia de "y" elevado a la "x" y = 2 x = 4 -print(y**x) -16 -# Devolver el resto de la división +print(y**x) # si elevo a 0.5, Python entiende que es raíz cuadrada igual que 1/2 +# R=> 16 + +# Ej 7) Devolver el resto de la división y = 13 x = 3 -print(y%x) -1 -# Ciclo IF/ELIF/ELSE -valor = 0 +print(y%x) # Sirve para todas las operaciones en que deba detectar pares, impares, primos + +# Ej 8) Ciclo IF/ELIF/ELSE +valor = 0 # Inicializo un contador para entrar al ciclo if (valor < 0): print('El número es negativo') elif (valor > 0): print('El número es positivo') else: - print('El número es igual a cero') -# El número es igual a cero - -# Ciclo FOR - Caso 1 -for n in range(1,10): #Incluye el primero y excluye el último - print(n, end(", ")) - -# Ciclo WHILE -n = 1 -while (n < 10): - print(n) - n = n + 1 -""" -1 -2 -3 -4 -5 -6 -7 -8 -9 -""" -# Lista - -# Caso 1 - Inicializa una lista y muestra la cantidad de elementos - -edad = (3,1,0.2,8,7) #Declara un objeto lista y le asigna elementos -print (len(edad)) #Imprime la cantidad de elementos de la lista usando la función LEN -#5 # La función retorno 5 - -# Caso 2 - Identificar el tipo de variable usando la función TYPE, retorno el tipo de dato -mi_lista = ['Rojo','Azul','Amarillo','Naranja','Violeta','Verde'] -type(mi_lista) -# list -print(mi_lista) -['Rojo', 'Azul', 'Amarillo', 'Negro', 'Naranja', 'Violeta', 'Verde'] -print(mi_lista[0:2]) -['Rojo', 'Azul'] -print(mi_lista[:2]) -['Rojo', 'Azul'] -print(mi_lista[1:]) -['Azul', 'Amarillo'] -mi_lista.insert(3,'Negro') -print(mi_lista.index('Azul')) -# 1 -mi_lista.insert(3,'Negro') -mi_lista.extend(['Marrón','Gris']) -print(['a','b','c'] * 3) -# ['a', 'b', 'c', 'a', 'b', 'c', 'a', 'b', 'c'] -print(mi_lista.index('Azul')) -# 1 -mi_lista.remove('Blanco') - -""" ---------------------------------------------------------------------------- -ValueError Traceback (most recent call last) -~\AppData\Local\Temp/ipykernel_10044/2480624766.py in -----> 1 mi_lista.remove('Blanco') - -ValueError: list.remove(x): x not in list -mi_lista.remove('Negro') ---------------------------------------------------------------------------- -ValueError Traceback (most recent call last) -~\AppData\Local\Temp/ipykernel_10044/298389232.py in -----> 1 mi_lista.remove('Negro') - -ValueError: list.remove(x): x not in list -""" -ultimo = mi_lista.pop() -ultimo = mi_lista.pop() -print(ultimo) -# Gris -ultimo = mi_lista.pop() -ultimo -# 'Amarillo' -mi_tupla=tuple(mi_lista) -print(mi_tupla[1]) -# Azul -'Rojo' in mi_tupla -# True -mi_tupla.count('Rojo') -# 1 -print(mi_lista[:] * 3) -# ['Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris', 'Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris', 'Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris'] -mi_tupla.count('Rojo') -# 1 -mi_tupla='Gaspar', 5, 8, 1999 -nombre, dia, mes, año = mi_tupla -print("Nombre: ", nombre, " - Dia:", dia, " - Mes: ", mes, " - Año: ", año) -# Nombre: Gaspar - Dia: 5 - Mes: 8 - Año: 1999 -nombre = 'Darío' -edad = 39 -print(nombre, edad) -print("Mi nombre es", nombre, ". Mi edad es", edad, "años") -print("Mi nombre es {}. Mi edad es {} años". format(nombre, edad)) -# Darío 39 -# Mi nombre es Darío . Mi edad es 39 años -# Mi nombre es Darío. Mi edad es 39 años - -mi_diccionario = { 'Colores Primarios': ['Rojo','Azul','Amarillo'], - 'Colores secundarios': ['Naranja','Violeta','Verde'], - 'Clave3': 10, + print('El número es igual a cero') # R=> El número es igual a cero + +# Ej 9) Ciclo FOR - Simple (ver ciclos listas dobles) +for n in range(1,11): #Incluye el primero y excluye el último + print(n,(')')) + +# Ej 10) Ciclo WHILE - Simple con un contador +n = 1 # Contador definido en 0 +while (n < 10): # Mientras n sea menor que 10, haga lo que está dentro + print(n) # Imprimir el contenido de la variable en cada ciclo + n = n + 1 # El contador es la condición de termino. Al llegar a 11, no entra el nuevo ciclo. + +# Ej 11) Lista Simple - Inicializa una lista y obtener la cantidad de elementos con LEN + +edad = (3,1,0.2,8,7) # Declara un objeto lista y le asigna elementos, la lista es mutable, no ordenada +print (len(edad)) # Imprime la cantidad de elementos de la lista usando la función LEN +#5 # La función retornó 5 + +# Ej 12) Lista - Retornar tipo de variable usando TYPE, isertar con INSERT, pegar dos listas con EXTEND, +# eliminar un elemento con REMOVE, retornar un elemento usando su índice con INDEX[]y modificadores en la salida + +mi_lista = ['Rojo','Azul','Amarillo','Naranja','Violeta','Verde'] # Lista de 6 elementos +type(mi_lista) # la lista, como objeto es de tipo list, pero sus objetos no, pueden ser de cualquier tipo. +# R => list +print(mi_lista) # Imprime los elementos de la lista, en el orden que están...se pueden ordenar +# R=> ['Rojo', 'Azul', 'Amarillo', 'Negro', 'Naranja', 'Violeta', 'Verde'] +print(mi_lista[0:2]) # Imprimo la lista desde el índice 0, al 2, es decir el 0 y el 1, excluye el 2 +# R=> ['Rojo', 'Azul'] +print(mi_lista[:2]) # Imprime la lista desde el inicio, hasta el indice, desde el 0 al 1, excluye el 2 +# R=> ['Rojo', 'Azul'] +print(mi_lista[1:]) # Imprime la lista desde la posición 1, hasta el final, excluye la posición 0. +# R=> ['Azul', 'Amarillo', 'Naranja', 'Violeta', 'Verde'] +mi_lista.insert(3,'Negro') # INSERT, inserta un elemento en la posición del índice dado. +print(mi_lista.index('Azul')) #Retorna el valor (int) del índice cuando halla la coincidencia, este caso=1. +print(mi_lista [1]) # => Azul, retorna el valor del elemento en el indice, en este caso [1]= Azul +mi_lista.insert(3,'Negro') # Inserta el elemento 'Negro', en la posición 3. +mi_lista.extend(['Marrón','Gris']) # EXTEND, 'pega' la lista ('Marrón','Gris'), al final de mi_lista +print(['a','b','c'] * 3 ) # Igual que la concatenación, puedo 'multiplizar str =>['a', 'b', 'c', 'a', 'b', 'c', 'a', 'b', 'c'] +mi_lista.remove('Blanco') # Recorre la lista, si existe el elemento, lo borra 1 vez, si no, da ERROR (not in list). +ultimo = mi_lista.pop() # Remueve el último elemento de la lista +print(ultimo) # Conserva el último elemento eliminado con POP, si ejecuto otra vez, elimina el anterior. + +# Ej 13) Tuplas - Operaciones de cambio de tipo, recorrer la tupla, contar elementos, imprimir, asignar +mi_tupla=tuple(mi_lista) # La lista fue 'casteada?, se le ambio el tipo a TUPLE (lista INMUTABLE) +print(mi_tupla[1]) # Se accede a sus elementos igual que la lista, NO SE PUEDE ORDENAR R=> Index 1 = Azul +'Rojo' in mi_tupla # Puedo hacer evaluaciones BOOLEANAS (T/F), está el elemento en la tupla, retorna T/F =>T +mi_tupla.count('Rojo') # Puedo contar los elementos que coinciden con un valor, retorna 1 entero +print(mi_lista[:] * 3) # Concatena la lista veces, igual que los strings. +# R=> ['Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris', 'Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris', 'Rojo', 'Azul', 'Amarillo', 'Negro', 'Marrón', 'Gris'] +mi_tupla='Gaspar', 5, 8, 1999 # Crea una tupla a partir asignarle elementos +nombre, dia, mes, año = mi_tupla # Asigna los valores de la tupla a variables +print("Nombre: ", nombre, " - Dia:", dia, " - Mes: ", mes, " - Año: ", año) # Imprime el contenido de las variables +# R=> Nombre: Gaspar - Dia: 5 - Mes: 8 - Año: 1999 + +# Ej 14) Formateo de impresión - 3 casos (sólo variables, con texto y con formato) +nombre = 'Darío' # Inicializo var nombre con el str 'Darío' +edad = 39 # Inicializo var edad con el int 39 +print(nombre, edad) # Caso 1) Imprimo el contenido de las variables. Puede ser cualquier variable. +print("Mi nombre es", nombre, ". Mi edad es", edad, "años") # Caso 2) Impresión tradicional con variables. +print("Mi nombre es {}. Mi edad es {} años". format(nombre, edad)) # Caso 3) Impresión con FORMATO +# Caso 1) Darío 39 +# Caso 2) Mi nombre es Darío . Mi edad es 39 años +# Casi 3) Mi nombre es Darío. Mi edad es 39 años + +# Ej 15) Diccionarios - Creación y operaciones (pares de elementos, {key:elemento}) +mi_diccionario = { 'Colores Primarios': ['Rojo','Azul','Amarillo'], # Crear con {key:Elm, key:Elm...} + 'Colores secundarios': ['Naranja','Violeta','Verde'], # Elm= Cualquier cosa, mutable + 'Clave3': 10, # Key= Hasheable, inmutable 'Clave4': False} -print(mi_diccionario['Colores secundarios']) -# ['Naranja', 'Violeta', 'Verde'] +print (mi_diccionario['Colores secundarios']) # Lo puedo acceder por sus claves o índices y retorna los VALORES +# R=> ['Naranja', 'Violeta', 'Verde'] # Para la clave dad, retorno los elementos respectivos -mi_diccionario={'Clave1':'Valor1', 'Clave2':{'numeros':[1,2,3,4,5]}} -print(mi_diccionario.keys()) -# dict_keys(['Clave1', 'Clave2']) -print(mi_diccionario.values()) -# dict_values(['Valor1', {'numeros': [1, 2, 3, 4, 5]}]) -len (mi_diccionario) -# 2 +mi_diccionario = {'Clave1':'Valor1', 'Clave2':{'numeros':[1,2,3,4,5]}} # Dic key1=str y val1=str, key2=str, val2=lista +print (mi_diccionario.keys()) # Retorna R=> dict_keys(['Clave1', 'Clave2']) +print(mi_diccionario.values()) # Retorna R=> dict_values(['Valor1', {'numeros': [1, 2, 3, 4, 5]}]) +len (mi_diccionario) # R=> 2, la función LEN es útil cuando se debe recorrer el DICT + +# Ej 16) Ciclo IF/ELIF/ELSE edad = 60 edad_compa = 50 -if (edad < edad_compa): +if (edad < edad_compa): # Compara dos números, y establece dos condiciones print(edad) if (edad < 100): print(edad + 100) else: - print(edad - 100) + print(edad - 100) else: - print(edad_compa) -# 50 + print(edad_compa) # No cumple ninguna e imprime el contenido de la var edd_compa R=> 50 -primeros_10 = [0,1,2,3,4,5,6,7,8,9] -print(primeros_10) -# [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] +# Ej 17) Recorre una lista con un ciclo FOR y extrae los PARES -for n in primeros_10: - if (n%2 == 0): - print(n) - primeros_10[n]=0 -print("\va de nuevo....\n") -""" -0 -2 -4 -6 -8 -# va de nuevo.... -""" +primeros_10 = [0,1,2,3,4,5,6,7,8,9] +print(primeros_10) # R=> [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] +outlist = [] # Esta lista acumula los valores encontrados +for n in primeros_10: # For 'var' in 'lista/tupla/dict' + if (n%2 == 0): # Uso la función resto para reconocer los PARES + outlist.append(n) # Los guardo en una lista para poder mostrarlos horizontalmente +print ('Los pares son', outlist) # R=> Los pares son [0, 2, 4, 6, 8] -print(primeros_10) -# [0, 1, 0, 3, 0, 5, 0, 7, 0, 9] +# Ej 18) Recorrer una lista con su índice y ver error fuera de rango -for n in primeros_10: - print(primeros_10[n]) -print("\va de nuevo....\n") -""" -0 -1 -0 -3 -0 -5 -0 -7 -0 -9 -va de nuevo.... -""" +print(primeros_10[9]) # R=> 9, el valor existe dentro del rango +primeros_10 = ['a','b','c','d'] # Esta lista de str, tiene 4 elm, índices del 0 al 3. +primeros_10[4] # Al intentar accesar a una posición que NO existe, retornará un error (out of range) -print(primeros_10[9]) -# 9 -primeros_10 = ['a','b','c','d'] -primeros_10[4] -""" ---------------------------------------------------------------------------- -IndexError Traceback (most recent call last) - in -----> 1 primeros_10[4] - -IndexError: list index out of range -""" +# Ej 19) Uso de la función SEQUENCE - Recorre un rango n = 40 sequence = [0,1] for i in range(2,n): diff --git a/Workbench/Taller/Problemasumas.py b/Workbench/Taller/Problemasumas.py new file mode 100644 index 000000000..93d84b855 --- /dev/null +++ b/Workbench/Taller/Problemasumas.py @@ -0,0 +1,36 @@ +# Crear una clase Operación que solicite en el método __init__ +# la carga de dos enteros e inmediatamente muestre +# su suma, resta, multiplicación y división. +# Hacer cada operación en otro método de la clase Operación y llamarlos +# desde el mismo método __init__ + +class Operacion: + + def __init__(self): + self.valor1=int(input("Ingrese primer valor:")) + self.valor2=int(input("Ingrese segundo valor:")) + self.sumar() + self.restar() + self.multiplicar() + self.dividir() + + def sumar(self): + suma=self.valor1+self.valor2 + print("La suma es",suma) + + def restar(self): + resta=self.valor1-self.valor2 + print("La resta es",resta) + + def multiplicar(self): + multi=self.valor1*self.valor2 + print("El producto es",multi) + + def dividir(self): + divi=self.valor1/self.valor2 + print("La division es",divi) + + +# bloque principal + +operacion1=Operacion() \ No newline at end of file diff --git a/Workbench/Taller/TodasLasOperaciones.py b/Workbench/Taller/TodasLasOperaciones.py new file mode 100644 index 000000000..1b7ae6522 --- /dev/null +++ b/Workbench/Taller/TodasLasOperaciones.py @@ -0,0 +1,27 @@ +class Operacion: + + def __init__(self): + self.valor1=int(input("Ingrese primer valor:")) + self.valor2=int(input("Ingrese segundo valor:")) + self.sumar() + self.restar() + self.multiplicar() + self.dividir() + + def sumar(self): + suma=self.valor1+self.valor2 + print("La suma es",suma) + + def restar(self): + resta=self.valor1-self.valor2 + print("La resta es",resta) + + def multiplicar(self): + multi=self.valor1*self.valor2 + print("El producto es",multi) + + def dividir(self): + divi=self.valor1/self.valor2 + print("La division es",divi) + +operacion1=Operacion() \ No newline at end of file diff --git a/Workbench/Taller/listas.py b/Workbench/Taller/listas.py index fc5b6cc56..964da9bd3 100644 --- a/Workbench/Taller/listas.py +++ b/Workbench/Taller/listas.py @@ -1,51 +1,51 @@ #******************************************************************* #* * -#* TEORIA LISTAS * -#* * +#* TEORIA LISTAS - TUPLAS - DICCIONARIOS - ETC * +#* C O L E C C I O N E S Y MUCHO MAAASSSS * #******************************************************************* # Una LIST, es un objeto, es una colección de cosas, pueden ser tareas, -# vegetales, nombres -# mercaderías, cualquier cosa. +# vegetales, nombres, mercaderías, cualquier cosa. -# Dos formas paa declararlas e iniciaizarlas +# Dos formas para declararlas o iniciaizarlas, aunque hay otras. # 1) Defino una variable y le asigno un tipo lista VACÍO con paréntesis -empty_list1 = list() # Note que se debe indicar el tipo lista o lo considerará una TUPLA -print (empty_list1, "esta es la lista 1 con '()'") +empty_list1 = list() # Note que se debe indicar el tipo lista o lo +print (empty_list1, "esta es la lista 1 con '()'") # considerará una TUPLA print (type(empty_list1)) # 2) Defino una variable y sé que es del tipo lista por los corchetes '[]' -empty_list2 = [] # A la variable se le asigna una lista vacía con CORCHETES -print (empty_list2, "esta es la lista 2") +empty_list2 = [] # A la variable se le asigna una lista vacía con +print (empty_list2, "esta es la lista 2") # CORCHETES print (type (empty_list2)) # Ejemplo 1 numbers = [1,2,3,4,5,6] # Lista de números -print("'numbers' es del tipo ", type(numbers)) # De devolver el texto+ type 'list' +print("'numbers' es del tipo ", type(numbers)) # Imprime un texto + su 'type' # Ejemplo 2 -groceries = ["tomato", "carrot", "letuce"] # Una lista con 3 strings de 'vegentales' -print (groceries [0]) # El puntero va con corchetes y parte de 0, imprime "tomato" -print (numbers [3]) # Es una COLECCION, imprime todos los elementos -print (len(groceries)) # Conocer el largo de la la lista con len, devuelve 3 +groceries = ["tomato", "carrot", "letuce"] # Una lista con 3 str de 'vegetales' +print (groceries [0]) # El índice va con [] y parte en 0, imprime "tomato" +print (numbers [3]) # Es 'la' COLECCION, imprime todos sus elementos +print (len(groceries)) # LEN devuelve el largo de la lista con len, retorna 3 # Ejemplo 3 -lastname = "cordova" # Variable de tipo string, contiene "cordova" -mix_of_data_types_list = [1, "Jota", lastname, 2+5, 1-3j, 3.14] # Lista con distintos tipos de var -print ("'mix_of_data_types_list' es del tipo-", type(mix_of_data_types_list)) #devuelve 'list' -#podemos almacenar un mix de datos +lastname = "Cordova" # Variable de tipo string, contiene "Cordova" +mix_of_data_types_list = [1, "Jota", lastname, 2+5, 1-3j, 3.14] # Lista con distintos tipos de var +print ("'mix_of_data_types_list' es del tipo-", type(mix_of_data_types_list)) # devuelve un 'list' + +# Podemos almacenar cualquier 'mix' de datos u objetos, en Python TODO es un objeto # Ejemplo 4 -listadeletras = [] # Crea un objeto list llamado listadeletras -for unaletra in "paralelepipedo": # Define una variable 'unaletra' y recorre el string "paralelepípedo" +listadeletras = [] # Crea un objeto list llamado listadeletras vacío +for unaletra in "paralelepipedo": # Define una var 'unaletra' y recorre el string "paralelepípedo" listadeletras.append(unaletra)# Agrega cada caracter del string a 'listadeletras' usando el método 'append' print (listadeletras) # Imprime los valores de la lista que son los caracteres de la palabra 'paralelepípedo'', lo que sea - # Salida esperada ['p', 'a', 'r', 'a', 'l', 'e', 'l', 'e', 'p', 'i', 'p', 'e', 'd', 'o'] + # Salida esperada ['p', 'a', 'r', 'a', 'l', 'e', 'l', 'e', 'p', 'í', 'p', 'e', 'd', 'o'] # Ejemplo 5 -# Crear una lista de 4 elementos y, para cada elemento, calcularle la potencia de 2, usando -# el método tradicional, eso seria así: +# Crear una lista de 4 elementos y, para cada elemento, calcularle su potencia de 2, usando +# el método tradicional, eso seria así, luego veremos con expresiones o por comprensión: # Alternativa 1 lista_potencias = [] # Crea una lista llamada "lista_potencias" for i in range(4): # Ciclo for para recorrer lista de 4 elementos, va de 0 a 3, el índice lo llamamos "i" @@ -53,24 +53,24 @@ print(lista_potencias) # Imprime los 4 valores almacendaos en la lista [0, 1, 4, 9] # Ejemplo 6 -# Entonces el ejemplo anterior usando listas de comprensión, eso seria así: -lista_potencias2 = [i**2 for i in range(4)] # Usa un for +# El ejemplo 5, usando listas por comprensión (es decir, fórmulas o expresiones), seria así: +lista_potencias2 = [i**2 for i in range(4)] # Usa un FOR print ("Esta es la lista de potencias Nr2", lista_potencias2) # Imprime [0, 1, 4, 9] # Ejemplo 7 # Lista con las potencias de 2 de los primeros 10 números, método tradicional: # Alternativa 1 lista1_pot10_2 = [] # Creamos un objeto lista vacio [] -for num in range (0, 11): # Incluye el primero y no el últimmo. Usando un ciclo FOR usando la var "num" en el tramo de 0-10, ambos incluidos +for num in range (0, 11): # Incluye el 1ro, pero no el últimmo. Recorremos el rangoUsando un ciclo FOR usando la var "num" en el tramo de 0-10, ambos incluidos lista1_pot10_2.append (num**2) # Llenamos la lista con potencias PARTIENDO DE 0, a 10 (11-1) print(lista1_pot10_2) # Salida por pantalla [0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100] # Alternativa 2 -#Entonces el ejemplo anterior usando listas de comprensión, eso seria así: -#lista2_pot10_2 = [num2**2 for num2 in range(0, 11)] #Creamos la lista con los valores según condición -#print("Este es el método 3-2, para crear la lista de 10 números y sus potencias",lista2_pot10_2) -#[0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100] -#De este código anterior usted puede aprender que es posible modificar al vuelo los elementos los cuales van a formar la lista. +# Usando listas por comprensión, seria así: +lista2_pot10_2 = [num2**2 for num2 in range(0, 11)] #Creamos la lista con los valores según condición +print("Aquí usamos una expresión para crear la lista de 10 nros. y sus potencias",lista2_pot10_2) +# R=> Aquí usamos una expresión para crear la lista de 10 nros. y sus potencias [0, 1, 4, 9, 16, 25, 36, 49, 64, 81, 100] +# Con este método, es más simple modificar los elementos que van a la lista. # Ejemplo 8 # Este ejemplo muestra como operan las posiciones en una lista (cada elemento es una posX) @@ -85,7 +85,7 @@ print("7° Mostrar 'lista[::-1]', significa mostrar todos los elementos de la lista en orden inverso\n",lista[::-1]) # tomamos desde el final hasta el principip (orden inverso) # Ejemplo 9 -# Con este ejemplo usamos un truco para controlar la salida, un método de print llamado end +# Usamos un truco para controlar la salida, un método de print llamado end # for i in range (15): if i < 14: @@ -94,80 +94,305 @@ print (i) # Ejemplo 10 -# Mismo ejemplo sin controlar la salida, cada linea se ejecuta y se apilan. +# Mismo ejemplo sin controlar la salida, cada linea se ejecuta y se apila. for i in range (15): - print (i) + print (i) # No agregué el print por espacio ...se ve muy feo # Ejemplo 11 -# Revisar otra formas de ordenar listas +# Revisar otra formas de ordenar listas (pero en este archivo van muchas) lista_desordenada = [5,7,2,8,3,6] -lista_desordenada.sort() +lista_desordenada.sort() # Usamos el método SORT print ("Resultado esperado 2,3,5,6,7,8, lista generada :", lista_desordenada) -print (type(lista_desordenada)) +print (type(lista_desordenada)) # Verifico, como medida extra, el tipo de dato generado # Ejemplo 12 # Lista negada = los inversos y lista doble = multiplicadas por algo +# Hay que acostumbrarse a usar 'trucos' para resolver la lógica de los problemas lista = [10, 20, 30] -lista_negada = [ -e for e in lista ] # Los inversos de los elementos -lista_doble = [ e*2 for e in lista] # Los elementos multiplicados por 2 -print(lista_negada) -print(lista_doble) +lista_negada = [ -e for e in lista ] # Es por comprensión. Genera los inversos de los elementos +lista_doble = [ e*2 for e in lista] # Esta genera los elementos multiplicados por 2 +print(lista_negada) # Todos negativos +print(lista_doble) # Todos x 2 # Ejemplo 13 -# Una lista de valores float, no se pueden negar strings -lista2 = [True, True, False, 5, 2-3j] -lista_negada2 = [ -e for e in lista2] # Los inversos de los elementos numéricos -lista_doble2 = [ e*2 for e in lista2] # Los elementos multiplicados por 2 +# Ojo!! No se pueden negar valores float o strings. +lista2 = [True, True, False, 5, 2-3j] # Ojo con los BOOLEANOS +lista_negada2 = [ -e for e in lista2] # Los inversos de los elementos numéricos +lista_doble2 = [ e*2 for e in lista2] # Los elementos multiplicados por 2 print(lista_negada2) # Nótese la salida [-1, -1, 0, -5, (-2+3j)], los booleanos los tomo como 1 y 0 print(lista_doble2) # Nótese la salida [2, 2, 0, 10, (4-6j)], fijarse en los booleanos # Ejemplo 14 -# Con un ciclo for, alimenta dos listas dependiendo de una condición y muestra la información horizontal. +# Usando 1 ciclo FOR, poblar 2 listas dependiendo de una condición y mostrar la información horizontal. lista_i = [] lista_p = [] -for i in range (1,21): +for i in range (1,11): n=(i%2) if n==1: lista_i.append (i) elif n==0: lista_p.append (i) -print ("Los números impares entre 1 y 20 son ", lista_i) -print ("Los números pares entre 1 y 20 son ", lista_p) +print ("Los números impares entre 1 y 10 son ", lista_i) +print ("Los números pares entre 1 y 10 son ", lista_p) # Ejemplo 15 # Usos de 'enumerate' en listas, tuplas, diccionarios, cadenas -for i, val in enumerate(['A', 'B', 'C']): +for i, val in enumerate(['A', 'B', 'C']): # ENUMERATE recorre la lista y su ÍNDICE print(i, val) -""" -0 A -1 B -2 C -""" - -# En este caso imprime la posición o puntero, y el contenido de la posición, vertical +# 0 A +# 1 B +# 2 C +# En este caso imprime la posición, índice, o puntero, y el contenido de la posición, verticamente +# Cómo o haría para mostrarlo horizontalmente? +# # Ejemplo 16 for i, val in enumerate(['A', 'B', 'C'], start=5): # Mismo anterior, pero cambia el valor del puntero que parte en 5 print(i, val) -""" -5 A -6 B -7 C -""" -# La salida va de 5 a 7 +# 5 A +# 6 B +# 7 C La salida va de 5 a 7 + # Ejemplo 17 -# En este caso va de 5 a 14, se salta 3, y el puntero inicia en 1 +# En este caso va de 5 a 14, se salta de a 3, y el puntero inicia en 1 for i, val in enumerate(range(5, 15, 3), start=1): print(f'Pos: {i} -> {val}') -""" -Pos: 1 -> 5 -Pos: 2 -> 8 -Pos: 3 -> 11 -Pos: 4 -> 14 -""" # La salida va con los textos 'Pos: ' y '->' +# Pos: 1 -> 5 +# Pos: 2 -> 8 +# Pos: 3 -> 11 +# Pos: 4 -> 14 print ("") -# Ejemplo \ No newline at end of file +# Ejemplo 18 +# Iterar 2 listas usando un FOR y ZIP +a = [1, 2] +b = ["Uno", "Dos"] +c = zip(a, b) +for numero, texto in zip(a, b): + print("Número", numero, "Letra", texto) + print(type(numero), type(texto)) +# Número 1 Letra Uno +# +# Número 2 Letra Dos +# + +# Ejemplo 19) zip() con n argumentos - Ejemplo con varias listas +# Como ZIP está definida como, zip(*iterables) o cualquier iterable, +# es posible pasar un número arbitrario de iterables como entrada. +# Es importante notar, que todas tienen la misma longitud, dos. +# Es necesario experimentar para tener una 'idea' cuando toque + +numeros = [1, 2] +espanol = ["Uno", "Dos"] +ingles = ["One", "Two"] +frances = ["Un", "Deux"] +c = zip(numeros, espanol, ingles, frances) +for n, e, i, f in zip(numeros, espanol, ingles, frances): + print(n, e, i, f) +# Note la forma en que organiza la salida de los datos en pares +# 1 Uno One Un +# 2 Dos Two Deux + +# Ejemplo 20 - Caso: Hacer zip() con listas de diferentes longitudes +# Podemos usar zip con iterables de diferentes longitudes. +# En este caso, el iterador se detiene, cuando la lista más pequeña se acaba. + +numeros = [1, 2, 3, 4, 5] +espanol = ["Uno", "Dos"] +for n, e in zip(numeros, espanol): + print(n, e) +# Ojo!, sólo completa los dos primeros pares +# 1 Uno +# 2 Dos + +# Ejemplo 21 - Caso: zip() con un argumento +# Por definición, se puede hacer, porque ZIP está definido para un 'n' arbitrario +# de listas, ergo, también es posible usar un único valor. +# El resultado son tuplas de un elemento...raras, pero se puede. + +numeros = [1, 2, 3, 4, 5] +zz = zip(numeros) # ZIP de si mismo +print (list(zz)) # R=> [(1,), (2,), (3,), (4,), (5,)] + +# Ejemplo 22 - Caso: zip() con diccionarios +# Lo común es usar ZIP con listas, pero al estar definida para cualquier clase iterable. +# Podemos usarla con DICCIONARIOS. + +# Por ejemplo, si (a,b) toman los valores de las key del diccionario, no parece muy interesante. + +esp = {'1': 'Uno', '2': 'Dos', '3': 'Tres'} +eng = {'1': 'One', '2': 'Two', '3': 'Three'} + +for a, b in zip(esp, eng): + print(a, b) +# 1 1 +# 2 2 +# 3 3 + +# Sin embargo, si usamos la función items del tipo DICT, podemos acceder +# al key y al value de cada elemento. +# Se puede facilitar para modificar valores usando, e.g casteo de dict a list y viceversa +esp = {'1': 'Uno', '2': 'Dos', '3': 'Tres'} +eng = {'1': 'One', '2': 'Two', '3': 'Three'} + +for (k1, v1), (k2, v2) in zip(esp.items(), eng.items()): + print(k1, v1, v2) +# Nótese que en este caso ambas key k1 y k2 son iguales. +# 1 Uno One +# 2 Dos Two +# 3 Tres Three + +# Ejemplo 23 - Caso: Deshacer el zip() +# Es posible deshacer un zip, en una sola línea de código. +# Supongamos que hemos usado zip para obtener 'c'. + +a = [1, 2, 3] +b = ["One", "Two", "Three"] +c = zip(a, b) + +print (list(c)) # R=> [(1, 'One'), (2, 'Two'), (3, 'Three')] +# ¿Es posible obtener a y b desde c? Sí, tan sencillo como: +c = [(1, 'One'), (2, 'Two'), (3, 'Three')] +a, b = zip(*c) +print(a) # (1, 2, 3) +print(b) # ('One', 'Two', 'Three') + +# Uso de STRIP Ejemplo 24 - STRIP eliminar espacios, cadenas de texto, incluso comparar +# Este ejemplo es como un "A inter B" +colores = ['yellow', 'wine', 'blue', 'green', 'red', 'brown', 'red'] +sec_colr = ['blue', 'green', 'red'] + +strColores = str(colores).strip("[]") +strSec_colr = str(sec_colr).strip("[]") + +if strSec_colr in strColores: + print("Si") +else: + print("No") + +# Ejemplo 24 - Usar listas como PILAS +# Los métodos de lista, facilitan usar una lista como una pila (stack), donde el +# último elemento añadido es el primer elemento retirado (LIFO). Para agregar un +# elemento a la cima de la pila, utilizamos APPEND(). Para retirar un elemento de la +# cima de la pila, se utiliza POP() sin un índice explícito. Por ejemplo: + +mi_pila = [3, 4, 5] +mi_pila.append(6) +mi_pila.append(7) +print (mi_pila) # R=> [3, 4, 5, 6, 7] +mi_pila.pop() # R=> Elimina el 7, y lo guarda en memoria hasta que lo ocupe otro +print (mi_pila) # Chequeamos si está el 7 y no está en la lista R=> [3, 4, 5, 6] +mi_pila.pop() # El siguiente elemento eliminado será el 6. R=> 6 +mi_pila.pop() # Ahora elimina el 5, R=> 5 +print (mi_pila) # verificamos y vemos que se han borrado los elementos. R=> [3, 4] + +# Ejemplo 25 - Usar listas como COLAS +# También es posible usar una lista como una cola, donde el primer elemento añadido +# es el primer elemento retirado (FIFO); sin embargo, las listas no son eficientes +# para este propósito. Agregar y sacar del final de la lista es rápido, pero +# insertar o sacar del comienzo de una lista es lento (porque todos los otros +# elementos tienen que ser desplazados en uno). +# Para implementar una cola, utiliza 'COLLECTIONS.DEQUE', el cual fue diseñado para +# añadir y quitar de ambas puntas de forma rápida. Por ejemplo: + +from collections import deque + +mi_Cola = deque(["Pedro", "Juan", "Diego"]) # Están Pedro, Juan y Diego en la cola +mi_Cola.append("Luis") # Llega Luis +print (mi_Cola) # R=> (['Pedro', 'Juan', 'Diego', 'Luis']) +mi_Cola.append("Jorge") # Llega Jorge +print (mi_Cola) # R=> (['Pedro', 'Juan', 'Diego', 'Luis', 'Jorge']) +print(mi_Cola.popleft()) # El primero en llegar se va => Pedro +print(mi_Cola) # R=> ('Juan', 'Diego', 'Luis', 'Jorge']) +print(mi_Cola.popleft()) # Ahora se va el segundo en llegar R=> Juan +print(mi_Cola) # R=> ('Diego', 'Luis', 'Jorge']) + # La lista restante en orden de llegada + +# Ejemplo 26 - Comprensión de listas . MUY IMPORTANTE ENTENDERLO BIEN !! +# Permite usar expresiones y condiciones para poblar una lista. +# Sus usos comunes son para hacer nuevas colecciones donde cada elemento es el resultado +# de algunas operaciones aplicadas a cada miembro de otra secuencia o iterable, o +# para crear un segmento de la secuencia de esos elementos para satisfacer una +# condición determinada ==> Es muy parecido a EXRESIONES REGULARES (import re), +# que son fundamentales en ciencia de datos. + +# Por ejemplo, queremos crear una lista de cuadrados, como: + +cuadrados1 = [] +for x in range(10): + cuadrados1.append(x**2) # Agrega los cuadrados en el rango 0-10, a lista cuadrados +print (cuadrados1) # => [0, 1, 4, 9, 16, 25, 36, 49, 64, 81] + +# Nótese que esto crea (o sobreescribe) una variable llamada x que sigue existiendo +# luego de que el bucle haya terminado. sin embargo, podemos aplicar listas por +# COMPRENSIÓN, poblando la lista de cuadrados sin efecto secundario haciendo: + +cuadrados2 = list(map(lambda x: x**2, range(10))) # Usamos una función lambda y map +cuadrados3 = [x**2 for x in range(10)] # otra expresión equivalente sería: + # lo cual es más conciso y legible. + +# Una lista por comprensión, consta de corchetes rodeando una expresión seguida de la +# declaración FOR, y luego 0 o más declaraciones FOR o IF. El resultado será una +# nueva lista que sale de evaluar la expresión, en el contexto de los FOR o IF que le +# siguen. Por ejemplo, esta lista de comprensión combina los elementos de 2 listas +# si no son iguales: + +# Ejemplo 27 Lista Distintos +# +[(x, y) for x in [1,2,3] for y in [3,1,4] if x != y] # R=> [(1, 3), (1, 4), (2, 3), + # (2, 1), (2, 4), (3, 1), (3, 4)] + +# y es equivalente a: + +combinar_listaDistintos = [] +for x in [1,2,3]: + for y in [3,1,4]: + if x != y: + combinar_listaDistintos.append((x, y)) +print (combinar_listaDistintos) # R=> [(1, 3), (1, 4), (2, 3), (2, 1), (2, 4), (3, 1), + # (3, 4)] +# Nótese como el orden de los for e if es el mismo en ambos pedacitos de código. +# Si la expresión es una tupla (como el (x, y) en el ejemplo anterior), debe estar entre paréntesis. + +# Ejemplo 28 - Operaciones con vectores +vector1 = [-4, -2, 0, 2, 4] # Crear un nueva lista con los valores *2 +vector2 = [x*2 for x in vector1] # Llenamos la lista, usando una expresión que calcula x^2 +print ("La lista de los x^2, del Vector 1 es ", vector2) # Comprobamos el resultado imprimiento la lista, OK! R=> [-8, -4, 0, 4, 8] +# Filtrar la lista para excluir los valores negativos +vector3 = [x for x in vector2 if x >= 0] # Esta expresión, llena la lista, separando positivos de negativos. +print (vector3) # Comprobamos el resultado imprimiento la lista, OK! R=> [0, 2, 4] +# Creamos una nueva lista, aplicado una función de valor absoluto (abs) a todos los elementos del vector1 +vector4 = [abs(x) for x in vector1] # Llenamos vector 4 con el resultado +print (vector4) # Comprobamos el resultado imprimiento la lista, OK! R=> [4, 2, 0, 2, 4] + +# Ejemplo 29 Limpiar datos usando STRIP +# También usamos expresiones para tareas repetitivas. +# En este ejemplo se usa la función STRIP para recortar los espacios en blanco + +fruta_fresca = [' banana', ' mora ', 'kiwi '] # Nótese que el 'raw data', viene con espacios a ambos lados del str +[cortar_espacios.strip() for cortar_espacios in fruta_fresca] # Al aplicar la función STRIP, se recortan los espacios +# La lista resultante queda R=> ['banana', 'mora', 'kiwi'] + +# Ejemplo 30 - Crear una lista de 2 tuplas como (número, su_cuadrado) +# +lista_cuad = [(x, x**2) for x in range(6)] # Recordar, va de 0 a 5, excluye el lim_sup del intervalo +print ('La lista de pares (x, x^2), es ', lista_cuad) +# La lista de pares (x, x^2), es [(0, 0), (1, 1), (2, 4), (3, 9), (4, 16), (5, 25)] +# La expresión a comparar (x, x**2), debe estar entre paréntesis, de lo contrario se genera un error + +# Ejemplo 31 - Aplanar una lista usando listas compuestas (listcomp) con dos 'FOR' + +vec = [[1,2,3], [4,5,6], [7,8,9]] # vec es un arreglo de listas y queremos ponerlas en una sola lista +flat_vec= [num for elem in vec for num in elem] # Nótese que en este caso no uso paréntesis, no es comparación o formula +print ("La lista 'aplanada' es ", flat_vec) # La lista esperada R=>[1, 2, 3, 4, 5, 6, 7, 8, 9] + +# Ejemplo 32 - Listas anidades con expresiones complejas +# Las listas por comprensión pueden contener expresiones complejas y funciones anidadas: + +from math import pi # Importamos una librería "MATH" que nos permite hacer cálculos científicos y usar constantes +pi_evol= [str(round(pi, i)) for i in range(1, 6)] # Creamos una lista con incrementales de pi +print ('Los valores incrementales de pi, son ', pi_evol) +# R=> Los valores incrementales de pi, son ['3.1', '3.14', '3.142', '3.1416', '3.14159'] \ No newline at end of file diff --git a/Workbench/Taller/pruebaerror.ipynb b/Workbench/Taller/pruebaerror.ipynb new file mode 100644 index 000000000..a4c670a96 --- /dev/null +++ b/Workbench/Taller/pruebaerror.ipynb @@ -0,0 +1,586 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "class Clase:\n", + " atributo_clase = \"Hola\" # Accesible desde el exterior\n", + " __atributo_clase = \"Hola\" # No accesible\n", + "\n", + " # No accesible desde el exterior usando guión bajo\n", + " def __mi_metodo(self):\n", + " print(\"Haz algo\")\n", + " self.__variable = 0\n", + "\n", + " # Este código es accesible desde el exterior\n", + " def metodo_normal(self):\n", + " # El método si es accesible desde el interior\n", + " self.__mi_metodo()\n", + "\n", + "mi_clase = Clase()\n", + "#mi_clase.__atributo_clase # Error! El atributo no es accesible\n", + "#mi_clase.__mi_metodo() # Error! El método no es accesible\n", + "mi_clase.atributo_clase # Ok!\n", + "mi_clase.metodo_normal() # Ok!\n", + "print (mi_clase._Clase__atributo_clase)\n", + "# 'Hola'\n", + "mi_clase._Clase__mi_metodo()\n", + "# 'Haz algo'" + ] + }, + { + "cell_type": "code", + "execution_count": 6, + "metadata": {}, + "outputs": [], + "source": [ + "class Vehiculo:\n", + " def __init__(self, color, tipo, cilindrada):\n", + " self.color = color\n", + " self.tipo = tipo\n", + " self.cilindrada = cilindrada\n", + " self.velocidad = 0 # Aquí creamos el atributo velocidad, no se requieren 2\n", + " self.direccion = 0 # Aquí creamos el atributo velocidad\n", + "\n", + " def Acelerar(self, vel): # Recibe un parámetro velocidad\n", + " self.velocidad += vel # Este es método que modifica el atributo velocidad\n", + "\n", + " def Frenar(self, vel): # Recibe un parámetro velocidad, es sólo un valor\n", + " self.velocidad -= vel # Calcula la nueva velocidad\n", + " \n", + " def Doblar(self, grados): # Recibe la cantidad de grados de l giro (0-360)\n", + " self.direccion += grados # Calcula la nueva dirección\n", + " \n", + " def Estado(self):\n", + " print('La velocidad actual es :', self.velocidad, '- y su rumbo es:', self.direccion, 'grados')\n", + "\n", + " def Detalle(self):\n", + " print('Soy del tipo ', self.tipo, 'de color', self.color, 'y mi cilindrada es de', self.cilindrada, 'litros')\n", + "\n", + "# 3) Instanciar 3 objetos de la clase vehículo y ejecutar sus métodos, probar luego\n", + "# el resultado\n", + "\n", + "a1 = Vehiculo ('rojo', 'auto', 2)\n", + "a2 = Vehiculo ('blanco', 'camioneta', 3.6)\n", + "a3 = Vehiculo ('negro', 'moto', 1)\n", + "\n", + "#a1.Acelerar(40)\n", + "a2.Acelerar(60)\n", + "a3.Acelerar(30)\n", + "#a1.Doblar(30)\n", + "a3.Doblar(30)\n", + "a2.Frenar(50)\n", + "a1.Doblar(100)" + ] + }, + { + "cell_type": "code", + "execution_count": 8, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "blanco 10 3.6\n", + "Soy del tipo auto de color rojo y mi cilindrada es de 2 litros\n", + "La velocidad actual es : 0 - y su rumbo es: 0 grados\n" + ] + } + ], + "source": [ + "print (a2. color, a2.velocidad, a2.cilindrada)\n", + "a1 = Vehiculo('rojo', 'auto', 2)\n", + "a1.Detalle()\n", + "a1.Estado()\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "print (a1.velocidad) # Tenía 0, le sume 40, queda en 40\n", + "print (a2.velocidad) # Tenía 0, le sume 40, queda en 60\n", + "print (a3.velocidad) # Tenía 0, le sume 40, queda en 30\n", + "print (a1.direccion) # Tenía 0 grados, queda en 30\n", + "print (a3.direccion) # Tenía 0 grados, queda en -30\n", + "print (a2.velocidad) # Frena y DISMINUYE (resta -50), debe quedar en 10" + ] + }, + { + "cell_type": "code", + "execution_count": 21, + "metadata": {}, + "outputs": [], + "source": [ + "class Operacion:\n", + "\n", + " def __init__(self):\n", + " self.valor1=int(input(\"Ingrese primer valor:\"))\n", + " self.valor2=int(input(\"Ingrese segundo valor:\"))\n", + " self.sumar()\n", + " self.restar()\n", + " self.multiplicar()\n", + " self.dividir()\n", + "\n", + " def sumar(self):\n", + " suma=self.valor1+self.valor2\n", + " print(\"La suma es\",suma)\n", + "\n", + " def restar(self):\n", + " resta=self.valor1-self.valor2\n", + " print(\"La rersta es\",resta)\n", + "\n", + " def multiplicar(self):\n", + " multi=self.valor1*self.valor2\n", + " print(\"El producto es\",multi)\n", + "\n", + " def dividir(self):\n", + " divi=self.valor1/self.valor2\n", + " print(\"La division es\",divi)\n", + "\n", + "\n", + "# bloque principal\n", + "\n", + "#operacion1=Operacion5\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "\n", + "for n in range(1,11): #Incluye el primero y excluye el último\n", + " print(n,(')'))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "n = 1\n", + "while (n < 11):\n", + " print(n)\n", + " n = n + 1" + ] + }, + { + "cell_type": "code", + "execution_count": 25, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "['Azul', 'Amarillo', 'Naranja', 'Violeta', 'Verde']\n" + ] + } + ], + "source": [ + "mi_lista = ['Rojo','Azul','Amarillo','Naranja','Violeta','Verde'] # Lista de 6 elementos\n", + "\n", + "print(mi_lista[1:]) # Imprime la lista desde la posición 1, hasta el final, \n", + "#" + ] + }, + { + "cell_type": "code", + "execution_count": 49, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "['Rojo', 'Azul', 'Amarillo', 'Negro', 'Naranja', 'Violeta', 'Verde']\n" + ] + } + ], + "source": [ + "#mi_lista.insert(3,'Negro')\n", + "print(mi_lista)\n", + "#print(type(mi_lista.index('Azul')))\n", + "#print(mi_lista[1])\n", + "#mi_lista.insert(3,'Negro')\n", + "\n", + "#n = 1\n", + "#while (n < 11):\n", + "# mi_lista.remove('Negro')\n", + "# n = n + 1\n", + "#mi_lista.remove('Blanco')\n", + " \n", + " " + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# ultimo = mi_lista.pop() # Remueve el último elemento de la lista,\n", + "# print (mi_lista) # Falta el 'Verde'\n", + "#ultimo = mi_lista.pop()\n", + "#print(ultimo) #Conserva el último elemento eliminado con POP, si ejecuto otra vez, elimina violeta." + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "mi_tupla = ('Rojo','Azul','Amarillo','Naranja','Rojo','Violeta','Rojo','Verde')\n", + "mi_tupla.count('Rojo')" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "mi_tupla='Gaspar', 5, 8, 1999\n", + "#print (type(mi_tupla[3]))\n", + "nombre, dia, mes, año = mi_tupla\n", + "print (mi_tupla)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "nombre = 'Darío' # Inicializo var nombre con el str 'Darío'\n", + "edad = 39 # Inicilizo var edad con el int 39\n", + "print(nombre, edad) # Imprimo el contenido de las variables.\n", + "print(\"Mi nombre es\", nombre, \". Mi edad es\", edad, \"años\")\n", + "print(\"Mi nombre es {}. Mi edad es {} años\". format(nombre, edad))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "mi_diccionario = { 'Colores Primarios': ['Rojo','Azul','Amarillo'], # Crear con {key:Elm, key:Elm...}\n", + " 'Colores secundarios': ['Naranja','Violeta','Verde'], # Elm= Cualquier cosa, mutable\n", + " 'Clave3': 10, # Key= Hasheable, inmutable\n", + " 'Clave4': False}\n", + "#print (mi_diccionario['Colores secundarios']) # Lo puedo acceder por sus claves o índices y retorna los VALORES\n", + "# R=> ['Naranja', 'Violeta', 'Verde'] # Para la clave dad, retorno los elementos respectivos\n", + "\n", + "mi_diccionario2 = {'Clave1':'Valor1', 'Clave2':{'numeros':[1,2,3,4,5]}} # Dic key1=str y val1=str, key2=str, val2=lista\n", + "print (mi_diccionario2.keys()) # Retorna R=> dict_keys(['Clave1', 'Clave2'])\n", + "print(mi_diccionario2.values()) # Retorna R=> dict_values(['Valor1', {'numeros': [1, 2, 3, 4, 5]}])\n", + "len (mi_diccionario) # Retorna el número de pares R=>2\n", + "print(mi_diccionario2)\n", + "print(type(mi_diccionario2.keys[1]))\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "edad = 60\n", + "edad_compa = 50\n", + "if (edad < edad_compa):\n", + " print(edad)\n", + " if (edad < 100):\n", + " print(edad + 100)\n", + " else:\n", + " print(edad - 100)\n", + "else:\n", + " print(edad_compa)\n", + "# 50\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "primeros_10 = [0,1,2,3,4,5,6,7,8,9]\n", + "# print(primeros_10) # R=> [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]\n", + "outlist = []\n", + "for n in primeros_10: # For 'var' in 'lista/tupla/dict'\n", + " if (n%2 == 0): # Uso la función resto para reconocer los PARES \n", + " outlist.append(n)\n", + " #primeros_10[n]=0\n", + "print ('Los pares son', outlist)\n", + "#print(\"\\va de nuevo....\\n\")\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "outlist = []\n", + "for n in primeros_10: # For 'var' in 'lista/tupla/dict'\n", + " if (n%2 == 0): # Uso la función resto para reconocer los PARES \n", + " outlist.append(n) # Los guardo en una lista para poder mostrarlos horizontalmente \n", + "print ('Los pares son', outlist) " + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "n = 40\n", + "sequence = [0,1]\n", + "for i in range(2,n):\n", + " sequence.append(sequence[i-1]+sequence[i-2])\n", + "print (sequence)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "a = [1, 2]\n", + "b = [\"Uno\", \"Dos\"]\n", + "c = zip(a, b)\n", + "for numero, texto in zip(a, b):\n", + " print(\"Número\", numero, \"Letra\", texto)\n", + " print(type(numero), type(texto))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "colores = ['yellow', 'wine', 'blue', 'green', 'red', 'brown', 'red']\n", + "sec_colr = ['blue', 'green', 'red']\n", + "\n", + "\n", + "strColores = str(colores).strip(\"[]\")\n", + "strSec_colr = str(sec_colr).strip(\"[]\")\n", + "\n", + "if strSec_colr in strColores:\n", + " print(\"Si\")\n", + "else:\n", + " print(\"No\")" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "hola = ' \\t\\t\\n\\tHola \\n '\n", + "print(hola)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "hola_limpio = hola.strip()\n", + "print(type(hola_limpio))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "texto = ' hola mundo hola \\ni'\n", + "print(texto.strip(' oahl'))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "colores = ['yellow', 'wine', 'blue', 'green', 'red', 'brown', 'red']\n", + "sec_colr = ['blue', 'green', 'red']\n", + "\n", + "strColores = str(colores).strip(\"[]\")\n", + "strSec_colr = str(sec_colr).strip(\"[]\")\n", + "\n", + "if strSec_colr in strColores:\n", + " print(\"Si\")\n", + "else:\n", + " print(\"No\")" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "from collections import deque\n", + "\n", + "mi_Cola = deque([\"Pedro\", \"Juan\", \"Diego\"]) # Están Pedro, Juan y Diego en la cola\n", + "mi_Cola.append(\"Luis\") # Llega Luis\n", + "print (mi_Cola) # R=> (['Pedro', 'Juan', 'Diego', 'Luis'])\n", + "mi_Cola.append(\"Jorge\") # Llega Jorge\n", + "print (mi_Cola) # R=> (['Pedro', 'Juan', 'Diego', 'Luis', 'Jorge'])\n", + "print(mi_Cola.popleft()) # El primero en llegar se va => Pedro\n", + "print(mi_Cola) # R=> ('Juan', 'Diego', 'Luis', 'Jorge'])\n", + "print(mi_Cola.popleft()) # Ahora se va el segundo en llegar R=> Juan\n", + "print(mi_Cola) # R=> ('Diego', 'Luis', 'Jorge'])\n", + " # La lista restante en orden de llegada" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "from collections import deque\n", + "\n", + "queue = deque([\"Eric\", \"John\", \"Michael\"])\n", + "queue.append(\"Terry\") # Terry arrives\n", + "print (queue) # (['Eric', 'John', 'Michael', 'Terry'])\n", + "queue.append(\"Graham\") # Graham arrives\n", + "print (queue) # (['Eric', 'John', 'Michael', 'Terry', 'Graham'])\n", + "print(queue.popleft()) # The first to arrive now leaves\n", + "#print(queue.popleft()) # 'Eric'\n", + "print (queue) # (['John', 'Michael', 'Terry', 'Graham'])\n", + "print(queue.popleft()) # The second to arrive now leaves\n", + "print(queue.popleft()) #'John'\n", + "queue # Remaining queue in order of arrival\n", + "deque(['Michael', 'Terry', 'Graham'])" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "n = 40\n", + "sequence = [0,1]\n", + "for i in range(2,n):\n", + " sequence.append(sequence[i-1]+sequence[i-2])\n", + "print (sequence)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "cuadrados1 = []\n", + "for x in range(10):\n", + " cuadrados1.append(x**2) # Agrega los cuadrados en el rango 0-10, a lista cuadrados\n", + "print (cuadrados1) # => [0, 1, 4, 9, 16, 25, 36, 49, 64, 81] \n", + "\n", + "# Nótese que esto crea (o sobreescribe) una variable llamada x que sigue existiendo \n", + "# luego de que el bucle haya terminado. sin embargo, podemos aplicar listas por \n", + "# COMPRENSIÓN, poblando la lista de cuadrados sin efecto secundario haciendo:\n", + "\n", + "cuadrados2 = list(map(lambda x: x**2, range(10))) # Usamos una función lambda y map\n", + "print (cuadrados1)\n", + "cuadrados3 = [x**2 for x in range(10)] # otra equivalente sería:\n", + "print (cuadrados1)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "\n", + "lista_cuad = [(x, x**2) for x in range(6)]\n", + "print ('La lista de pares (x, x^2), es ', lista_cuad)\n", + "#[(0, 0), (1, 1), (2, 4), (3, 9), (4, 16), (5, 25)]" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Ejemplo - aplanar una lista usando un listas compuestas (listcomp) con dos 'FOR'\n", + "\n", + "vec = [[1,2,3], [4,5,6], [7,8,9]] # vec es un arreglo de listas\n", + "flat_vec= [num for elem in vec for num in elem] # Nótese que en este caso no uso paréntesis, no es comparación o formula\n", + "\n", + "print (\"La lista 'aplanada' es \", flat_vec) # La lista esperada R=>[1, 2, 3, 4, 5, 6, 7, 8, 9]" + ] + }, + { + "cell_type": "code", + "execution_count": 148, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Los valores incrementales de pi, son ['3.1', '3.14', '3.142', '3.1416', '3.14159']\n" + ] + } + ], + "source": [ + "from math import pi # Importamos una librería \"MATH\" que nos permite hacer cálculos científicos y usar constantes \n", + "pi_evol= [str(round(pi, i)) for i in range(1, 6)] # Creamos una lista con incrementales de pi\n", + "print ('Los valores incrementales de pi, son ', pi_evol)\n", + "# R=> Los valores incrementales de pi, son ['3.1', '3.14', '3.142', '3.1416', '3.14159']" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.10.6" + }, + "orig_nbformat": 4, + "vscode": { + "interpreter": { + "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" + } + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} From 1b3d34584484f53e76c21e2c0f88502976483b2a Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sat, 28 Jan 2023 03:44:20 -0300 Subject: [PATCH 11/16] 2801230343 Up ejercicios de todo tipo --- Workbench/OrdenaTuplas.py | 19 + Workbench/Taller/AgregarElementosaObj.py | 30 + Workbench/Taller/Clases.py | 57 ++ Workbench/Taller/DesafioProgra.py | 335 +++++++++ Workbench/Taller/Diccionarios.py | 42 +- Workbench/Taller/EjerciciosVarios.py | 50 ++ Workbench/Taller/FuncionFactorial.py | 22 + Workbench/Taller/ListaEnteros.py | 34 + Workbench/Taller/Mix_ejercicios.py | 17 +- Workbench/Taller/NumeroCapicua.py | 36 + Workbench/Taller/OrdenaDic | 55 ++ Workbench/Taller/aritmetica.py | 2 +- Workbench/Taller/listas.py | 12 +- Workbench/Taller/pruebaerror.ipynb | 911 ++++++++++++++++++++++- Workbench/Taller/variables.py | 23 + 15 files changed, 1620 insertions(+), 25 deletions(-) create mode 100644 Workbench/OrdenaTuplas.py create mode 100644 Workbench/Taller/AgregarElementosaObj.py create mode 100644 Workbench/Taller/DesafioProgra.py create mode 100644 Workbench/Taller/EjerciciosVarios.py create mode 100644 Workbench/Taller/FuncionFactorial.py create mode 100644 Workbench/Taller/ListaEnteros.py create mode 100644 Workbench/Taller/NumeroCapicua.py create mode 100644 Workbench/Taller/OrdenaDic diff --git a/Workbench/OrdenaTuplas.py b/Workbench/OrdenaTuplas.py new file mode 100644 index 000000000..34db83f4f --- /dev/null +++ b/Workbench/OrdenaTuplas.py @@ -0,0 +1,19 @@ +# +# Ordenar una lista de coches almacenados como tuplas +# +tuplas_coches = [('Rojo', '4859-A', 'A'), ('Azul', '2901-Z', 'M'), ('Gris', '1892-B', 'M') + ] +# Ordenar los coches por matrícula +ordenados = sorted(tuplas_coches, key=lambda coche : coche[1]) +print (ordenados) +#[('Gris', '1892-B', 'M'), ('Azul', '2901-Z', 'M'), ('Rojo', '4859-A', 'A')] +# Ordenar una lista de coches almacenados como diccionarios +diccionarios_coches = [ + {'color': 'Rojo', 'matricula': '4859-A', 'cambio': 'A'}, + {'color': 'Azul', 'matricula': '2901-Z', 'cambio': 'M'}, + {'color': 'Gris', 'matricula': '1892-B', 'cambio': 'M'} +] +ordenados = sorted(diccionarios_coches, key=lambda coche : coche['matricula']) +print (ordenados) + +#[{'color': 'Gris', 'matricula': '1892-B', 'cambio': 'M'}, {'color': 'Azul', 'matricula': '2901-Z', 'cambio': 'M'}, {'color': 'Rojo', 'matricula': '4859-A', 'cambio': 'A'}] \ No newline at end of file diff --git a/Workbench/Taller/AgregarElementosaObj.py b/Workbench/Taller/AgregarElementosaObj.py new file mode 100644 index 000000000..7765b0f21 --- /dev/null +++ b/Workbench/Taller/AgregarElementosaObj.py @@ -0,0 +1,30 @@ +# Ejercicio 442: Agregar elementos a un objeto conjunto con el método de instancia add(). + +lenguajes = set() + +print(len(lenguajes)) +print(lenguajes) + +print() + +lenguajes.add('Python') +print(len(lenguajes)) +print(lenguajes) + +print() + +lenguajes.add('Java') +print(len(lenguajes)) +print(lenguajes) + +print() + +lenguajes.add('Java') +print(len(lenguajes)) +print(lenguajes) + +print() + +lenguajes.add('java') +print(len(lenguajes)) +print(lenguajes) \ No newline at end of file diff --git a/Workbench/Taller/Clases.py b/Workbench/Taller/Clases.py index d071497fb..1bf3669b9 100644 --- a/Workbench/Taller/Clases.py +++ b/Workbench/Taller/Clases.py @@ -207,3 +207,60 @@ def hablar(self): # Guau! # Miau! +# Ejercicio 8 - Crear clase Persona + +class Persona(): + + def __init__(self,nombre="",edad=0,dni=""): + self.nombre=nombre + self.edad=edad + self.dni=dni + + @property + def nombre(self): + return self.__nombre + + @property + def edad(self): + return self.__edad + + @property + def dni(self): + return self.__dni + + @nombre.setter + def nombre(self,nombre): + self.__nombre=nombre + + def validar_dni(self): + letras = "TRWAGMYFPDXBNJZSQVHLCKE" + if len(self.__dni)!=9: + print("DNI incorrecto") + self.__dni = "" + else: + letra = self.__dni[8] + num = int(self.__dni[:8]) + if letra.upper() != letras[num % 23]: + print("DNI incorrecto") + self.__dni = "" + + @dni.setter + def dni(self,dni): + self.__dni=dni + self.validar_dni() + + @edad.setter + def edad(self,edad): + if edad < 0: + print("Edad incorrecta") + self.__edad=0 + else: + self.__edad=edad + + + def mostrar(self): + return "Nombre:"+self.nombre+" - Edad:"+str(self.edad)+" - DNI:"+self.dni + + def esMayorDeEdad(self): + return self.edad>=18 + diff --git a/Workbench/Taller/DesafioProgra.py b/Workbench/Taller/DesafioProgra.py new file mode 100644 index 000000000..80a644552 --- /dev/null +++ b/Workbench/Taller/DesafioProgra.py @@ -0,0 +1,335 @@ +#******************************************************************* +#* * +#* SIMULACRO HENRY CHALLENGE * +#* * +#******************************************************************* + +def ListaDivisibles(numero, tope): + ''' + Esta función devuelve una lista ordenada de menor a mayor con los números divisibles + por el parámetro número entre uno (1) y el valor del parámetro "tope" + Recibe dos argumentos: + numero: Numero entero divisor + tope: Máximo valor a evaluar a partir de uno (1) + Ej: + ListaDivisibles(6,30) debe retornar [6,12,18,24] + ListaDivisibles(10,5) debe retornar [] + ListaDivisibles(7,50) debe retornar [7,14,21,28,35,42,49] + ''' + #Tu código aca: + lista=[] + for i in range((tope)): + if (i+1)%numero==0: + lista.append(i+1) + + return lista + +def Exponente(numero, exponente): + ''' + Esta función devuelve el resultado de elevar el parámetro "numero" al parámetro "exponente" + Recibe dos argumentos: + numero: El número base en la operación exponencial + exponente: El número exponente en la operación exponencial + Ej: + Exponente(10,3) debe retornar 1000 + ''' + #Tu código aca: + exp=numero**exponente + return exp + +def ListaDeListas(lista): + ''' + Esta función recibe una lista, que puede contener elementos que a su vez sean listas y + devuelve esos elementos por separado en una lista única. + En caso de que el parámetro no sea de tipo lista, debe retornar nulo. + Recibe un argumento: + lista: La lista que puede contener otras listas y se convierte a una + lista de elementos únicos o no iterables. + Ej: + ListaDeListas([1,2,['a','b'],[10]]) debe retornar [1,2,'a','b',10] + ListaDeListas(108) debe retornar el valor nulo. + ListaDeListas([[1,2,[3]],[4]]) debe retornar [1,2,3,4] + ''' + #Tu código aca: + if type(lista) != list: + return None + else: + lista_final=[] + for elem in lista: + if isinstance(elem, list): + lista_final.extend(ListaDeListas(elem)) + else: + lista_final.append(elem) + return lista_final + + + + #return 'Funcion incompleta' + +def Factorial(numero): + ''' + Esta función devuelve el factorial del número pasado como parámetro. + En caso de que no sea de tipo entero y/o sea menor que 0, debe retornar nulo. + Recibe un argumento: + numero: Será el número con el que se calcule el factorial + Ej: + Factorial(4) debe retornar 24 + Factorial(-2) debe retornar nulo + Factorial(0) debe retornar 1 + ''' + #Tu código aca: + if (type(numero) != int): + return None + if (numero < 0): + return None + factorial = 1 + for n in range(1, (numero)+1): + factorial = factorial * n + return factorial + #return 'Funcion incompleta' + +def ListaPrimos(desde, hasta): + ''' + Esta función devuelve una lista con los números primos entre los valores "desde" y "hasta" + pasados como parámetro, siendo ambos inclusivos. + En caso de que alguno de los parámetros no sea de tipo entero y/o no sea mayor a cero, debe retornar nulo. + En caso de que el segundo parámetro sea mayor al primero, pero ambos mayores que cero, + debe retornar una lista vacía. + Recibe un argumento: + desde: Será el número a partir del cual se toma el rango + hasta: Será el número hasta el cual se tome el rango + Ej: + ListaPrimos(7,15) debe retornar [7,11,13] + ListaPrimos(100,99) debe retornar [] + ListaPrimos(1,7) debe retonan [1,2,3,5,7] + ''' + #Tu código aca: + lista=[] + if (type(desde) != int or type(hasta) != int): + return None + if (desde < 0 or hasta < 0): + return None + if (desde > hasta): + return lista + def esPrimo(num): + if num==2: + return True + for n in range (2,num): + if(num%n!=0): + continue + else: + return False + return True + for i in range(desde,(hasta+1)): + if esPrimo(i): + lista.append(i) + + return lista + + +def ListaRepetidos(lista): + ''' + Esta función recibe como parámetro una lista y devuelve una lista de tuplas donde cada + tupla contiene un valor de la lista original y las veces que se repite. Los valores + de la lista original no deben estar repetidos. + Debe respetarse el orden original en el que aparecen los elementos. + En caso de que el parámetro no sea de tipo lista debe retornar nulo. + Recibe un argumento: + lista: Será la lista que se va a evaluar. + Ej: + ListaRepetidos([]) debe retornar [] + ListaRepetidos(['hola', 'mundo', 'hola', 13, 14]) + debe retornar [('hola',2),('mundo',1),(13,1),(14,1)] + ListaRepetidos([1,2,2,4]) debe retornar [(1,1),(2,1),(4,1)] + ''' + #Tu código aca: + l=[] + if type(lista) != list: + return None + while len(lista)>0: + elemento=lista[0] + cuenta=lista.count(lista[0]) + l.append((elemento,cuenta)) + for i in range(lista.count(lista[0])): + lista.remove(elemento) + continue + return l + +def ClaseVehiculo(tipo, color): + ''' + Esta función devuelve un objeto instanciado de la clase Vehiculo, + la cual debe tener los siguientes atributos: + Tipo: Un valor dentro de los valores posibles: ['auto','camioneta','moto'] + Color: Un valor de tipo de dato string. + Velocidad: Un valor de tipo de dato float, que debe inicializarse en cero. + y debe tener el siguiente método: + Acelerar(): Este método recibe un parámetro con el valor que debe incrementar a la + propiedad Velocidad y luego retornarla. + Si la propiedad Velocidad cobra un valor menor a cero, debe quedar en cero. + Si la propiedad Velocidad cobra un valor mayor a cien, debe quedar en cien. + Recibe dos argumento: + tipo: Dato que se asignará al atributo Tipo del objeto de la clase Vehiculo + color: Dato que se asignará al atributo Color del objeto de la clase Vehiculo + Ej: + a = ClaseVehículo('auto','gris') + a.Acelerar(10) -> debe devolver 10 + a.Acelerar(15) -> debe devolver 25 + a.Acelerar(-10) -> debe devolver 15 + ''' + #Tu código aca: + class Vehiculo: + def __init__(self, tipo, color): + if (tipo=='auto' or tipo =='camioneta' or tipo=='moto'): + self.Tipo = tipo + else: + raise TypeError ('el tipo de vehículo tiene que ser auto, camioneta o moto') + self.Color = color + self.Velocidad = 0 + + def Acelerar(self, acel): + self.Velocidad += acel + if self.Velocidad < 0: + self.Velocidad=0 + if self.Velocidad>100: + self.Velocidad=100 + return self.Velocidad + + a = Vehiculo(tipo, color) + return a + + +def OrdenarDiccionario(diccionario_par, clave, descendente=True): + ''' + Esta función recibe como parámetro un diccionario, cuyas listas de valores tienen el mismo + tamaño y sus elementos enésimos están asociados. Y otros dos parámetros que indican + la clave por la cual debe ordenarse y si es descendente o ascendente. + La función debe devolver el diccionario ordenado, teniendo en cuenta de no perder la + relación entre los elementos enésimos. + Recibe tres argumentos: + diccionario: Diccionario a ordenar. + clave: Clave del diccionario recibido, por la cual ordenar. + descendente: Un valor booleano, que al ser verdadero indica ordenamiento descendente y + ascendente si es falso. + Debe tratarse de un parámetro por defecto en True. + Si el parámetro diccionario no es un tipo de dato diccionario ó el parámetro clave no + se encuentra dentro de las claves del diccionario, debe devolver nulo. + Ej: + dicc = {'clave1':['c','a','b'], + 'clave2':['casa','auto','barco'], + 'clave3':[3,1,2]} + OrdenarDiccionario(dicc, 'clave1') debe retornar {'clave1':['a','b','c'], + 'clave2':['auto','barco','casa'], + 'clave3':[1,2,3]} + OrdenarDiccionario(dicc, 'clave3', False) debe retornar {'clave1':['c','b','a'], + 'clave2':['casa','barco','auto'], + 'clave3':[3,2,1]} + ''' + #Tu código aca: + if type(diccionario_par) != dict: + return None + diccion_lista=[] + diccion_lista=list(diccionario_par.keys()) + if clave not in diccion_lista: + return None + for key, value in diccionario_par.items(): + value.sort(reverse=descendente) + + return diccionario_par + +def Factorial(numero): + ''' + Esta función devuelve el factorial del número pasado como parámetro. + En caso de que no sea de tipo entero y/o sea menor que 1, debe retornar nulo. + Recibe un argumento: + numero: Será el número con el que se calcule el factorial + Ej: + Factorial(4) debe retornar 24 + Factorial(-2) debe retornar nulo + ''' + #Tu código aca: + if (type(numero) != int): + return None + if (numero < 1): + return None + factorial = 1 + while(numero > 1): + factorial = factorial * numero + numero -= 1 + return factorial + +def EsPrimo(valor): + ''' + Esta función devuelve el valor booleano True si el número reibido como parámetro es primo, de lo + contrario devuelve False.. + En caso de que el parámetro no sea de tipo entero debe retornar nulo. + Recibe un argumento: + valor: Será el número a evaluar + Ej: + EsPrimo(7) debe retornar True + EsPrimo(8) debe retornar False + ''' + #Tu código aca: + if (type(valor) != int): + return None + for i in range(2, (int(valor / 2) + 1)): + if valor % i == 0: + return False + return True + +def ClaseAnimal(especie, color): + ''' + Esta función devuelve un objeto instanciado de la clase Animal, + la cual debe tener los siguientes atributos: + Edad (Un valor de tipo de dato entero, que debe inicializarse en cero) + Especie (Un valor de tipo de dato string) + Color (Un valor de tipo de dato string) + y debe tener el siguiente método: + CumplirAnios (este método debe sumar uno al atributo Edad y debe devolver ese valor) + Recibe dos argumento: + especie: Dato que se asignará al atributo Especie del objeto de la clase Animal + color: Dato que se asignará al atributo Color del objeto de la clase Animal + Ej: + a = ClaseAnimal('perro','blanco') + a.CumpliAnios() -> debe devolver 1 + a.CumpliAnios() -> debe devolver 2 + a.CumpliAnios() -> debe devolver 3 + ''' + #Tu código aca: + class Animal: + def __init__(self, especie, color): + self.Especie = especie + self.Color = color + self.Edad = 0 + + def CumplirAnios(self): + self.Edad += 1 + return self.Edad + + a = Animal(especie, color) + return a + + +# Caso 1 +# El constructor de la clase Emprendedor recibe nombre (str), apellido (str), +# libros (lista), mascotas (lista). + +# a) Inicializar la clase con sus atributos + +class Emprendedor: + """En esta clase se crean emprenderes""" + mascotas = [] # Acumulará las mascotas del Emprendedor + libros = [] # Es una lista de libros del Emprendedor + def __init__(self, nombre, apellido, libros, mascotas): + self.nombre = nombre + self.apellido = apellido + self.libros = libros + self.mascotas = mascotas + +# b) Crear un Método que agregue una mascota (mascota) a la lista, no debe +# retornar nada. Mascotas es una lista +# + + def addMascotas (self, newPet): + self.mascotas.add() + + \ No newline at end of file diff --git a/Workbench/Taller/Diccionarios.py b/Workbench/Taller/Diccionarios.py index 3479a15af..54d32aecc 100644 --- a/Workbench/Taller/Diccionarios.py +++ b/Workbench/Taller/Diccionarios.py @@ -116,7 +116,7 @@ # Ejemplo 7 # Consultar a un dicc, si una clase existe => retorna un booleano TRUE o FALSE -# Ojo si preguntas por un valor, puede existir, pero retornará FALSE +# Ojo si preguntas por un VALUE, puede que existe la KEY, pero retornará FALSE # Si quiero preguntar por un valor, agrego el método .value() print ("") @@ -134,6 +134,44 @@ restaurant = {"Hamburguesa": 100, "Pizza": 50, "Jugo": 30} if "Hamburguesa" in restaurant: print ("SI está") + print() else: print ("NO está") -print (restaurant) \ No newline at end of file + print() +print (restaurant) +print() + +# Ejemplo 8 - Unir dos diccionarios + +def unirDics (dic1, dic2): + temp=dic1.copy() + temp.update(dic2) + return temp +miDic1={'manzana':10.50, 'pera':12.8} +miDic2={'durazno':11.10, 'ciruela':23.8} + +dicUni2= unirDics (miDic1, miDic2) +print (dicUni2) +print() + +# Ejemplo 9 - Unir dos diccionarios +# Unir dos LISTAS y crear un Diccionario +# necesitamos una lsta que provea las llaves y otra que provea los values + +def lisADicc (liskey, lisval): + return dict(zip(liskey, lisval)) +newkeys = ['enero', 'febrero', 'marzo', 'abril'] +newval = [10, 50,12, 9, 11, 10, 23, 8] + +d=lisADicc (newkeys, newval) +print (d) +#print() + +# Ejemplo 9 - Encontrar el elemento más frecuente de una lista o MODA +# +def moda (lista): + return print (max(lista, key= lista.count)) +print() +lista = [3,1,3,2,1,5,2,3,2,1,5,4,3,3,3] +moda (lista) + diff --git a/Workbench/Taller/EjerciciosVarios.py b/Workbench/Taller/EjerciciosVarios.py new file mode 100644 index 000000000..c7d89db4a --- /dev/null +++ b/Workbench/Taller/EjerciciosVarios.py @@ -0,0 +1,50 @@ +# Ejercicio 1 - Obtener la inversa de un string +# Invertir cualquier cadena de caracteres + +cadena1 = "cebolla" # R=> allobec +cadena2 = "somos" # R=> 'somos', es palíndroma + +for i in range(len(cadena1) -1, -1, -1): + print (cadena1[i], end="") + +print() + +# Ejercicio 2 - Palabra inversa, caso PALÍNDROMO (se lee igual al revés) +# Detectar si es palíndromo y mandar un mensaje + +cadena3 = "coco" # R=> ococ +cadena4 = "reconocer" # R=> 'reconocer', es palíndroma +pali = [] +pali2 = [] +for i in range(len(cadena3) -1, -1, -1): + pali.append(cadena3[i]) +for j in range(len(pali)-1, -1, -1): + pali2.append(pali[j]) +#print (pali) # Se puede eliminar, es sólo para controlar la salida y sirven de manejo de errores +#print (pali2) # Se puede eliminar, es sólo para controlar la salida y sirven de manejo de errores +if (pali == pali2): + print ("Felicitaciones", cadena3, "es un palíndromo", end="") +else: + print ("La palabra","'", cadena3,"'", "no es palíndroma e invertida, es", pali, end="") +print() + +# Ejercicio 3 - Palabra inversa usando propiedades del método print - SLICING +print ('') +cadena= 'Pepino' +print (cadena[::-1]) # '::' Indica de 0 hasta el último de los caracteres, + # para variantes, funciona igual que los indices separados + # por ':', con un desde y hasta, finalmente el '-1', le + # indica al método que es en orden inverso. + +# Ejercicio 4 - Ordenar una lista de cadenas de caracteres según el último carácter con la +# función sorted() +# + +# Creamos un diccionario dic_cadenas y que almacena 8 str (ciudades) +# + +dic_cadenas = ['Talca', 'París', 'Londres', 'Bogotá', 'San José', 'Santiago', 'Lima', 'Sao Paulo'] +print (dic_cadenas) + +print() + diff --git a/Workbench/Taller/FuncionFactorial.py b/Workbench/Taller/FuncionFactorial.py new file mode 100644 index 000000000..c004bb55e --- /dev/null +++ b/Workbench/Taller/FuncionFactorial.py @@ -0,0 +1,22 @@ +#def factorizar_numero(numero): +# if (type(numero) != int): +# return None +# if (numero < 0): +# return None +# factorial = 1 +# for n in range(1, (numero)+1): +# factorial = factorial * n +# return factorial + +#factorizar_numero() +def factorial(n): + if (n <1): + return None + if n==0 or n==1: + resultado=1 + elif n>1: + resultado=n*factorial(n-1) + return resultado + +fact=factorial(5) +print (fact) \ No newline at end of file diff --git a/Workbench/Taller/ListaEnteros.py b/Workbench/Taller/ListaEnteros.py new file mode 100644 index 000000000..297be6e85 --- /dev/null +++ b/Workbench/Taller/ListaEnteros.py @@ -0,0 +1,34 @@ +""" def test_ListaEnteros_01(self): + lista_test = ch.ListaEnteros(1, 10) + lista_esperada = [1,2,3,4,5,6,7,8,9,10] + self.assertEqual(lista_test, lista_esperada) + + def test_ListaEnteros_02(self): + lista_test = ch.ListaEnteros(3, 7) + lista_esperada = [3,4,5,6,7,8,9,10] + self.assertEqual(lista_test, lista_esperada) + + def test_ListaEnteros_03(self): + lista_test = ch.ListaEnteros(-2, 4) + lista_esperada = [-2,-1,0,1] + self.assertEqual(lista_test, lista_esperada) + +Esta función devuelve una lista de números enteros +Recibe dos argumentos: + inicio: Numero entero donde inicia la lista + tamanio: Cantidad de números enteros consecutivos + Ej: + ListaEnteros(10,5) debe retornar [10,11,12,13,14] + +""" + +def ListaEnteros (inicio, tamanio): + lista = [] + for i in range(inicio, inicio + tamanio): + lista.append(i) + return lista + +print (ListaEnteros (10,5)) +print (ListaEnteros (1,10)) +print (ListaEnteros (3,7)) +print (ListaEnteros (-2,4)) \ No newline at end of file diff --git a/Workbench/Taller/Mix_ejercicios.py b/Workbench/Taller/Mix_ejercicios.py index 56a8fa9d0..0c0ebdef6 100644 --- a/Workbench/Taller/Mix_ejercicios.py +++ b/Workbench/Taller/Mix_ejercicios.py @@ -1,5 +1,9 @@ -# Variables - +#******************************************************************* +#* * +#* MIX DE EJERCICIOS Y REVISIÓN DE EJEMPLOS * +#* CON COMENTARIOS Y CITAS * +#******************************************************************* +# # Ej 1) Cocatenar cadenas de caracteres, deben ser del mismo tipo (str+str) a = 'Hola ' @@ -334,29 +338,20 @@ def test_suma_dos_negativos(self): #Caja de Cristal import unittest - def es_mayor_de_edad(edad): if edad >= 18: return True else: return False - class PruebaDeCristalTest(unittest.TestCase): - def test_es_mayor_de_edad(self): edad = 20 - resultado = es_mayor_de_edad(edad) - self.assertEqual(resultado, True) - def test_es_menor_de_edad(self): edad = 15 - resultado = es_mayor_de_edad(edad) - self.assertEqual(resultado, False) - unittest.main(argv=[''], verbosity=2, exit=False) """ diff --git a/Workbench/Taller/NumeroCapicua.py b/Workbench/Taller/NumeroCapicua.py new file mode 100644 index 000000000..112932398 --- /dev/null +++ b/Workbench/Taller/NumeroCapicua.py @@ -0,0 +1,36 @@ +def NumeroCapicua(numero): + ''' + En matemáticas, la palabra capicúa (del catalán cap i cua, 'cabeza y cola')​ + se refiere a cualquier número que se lee igual de izquierda a derecha que + de derecha a izquierda. Se denominan también números palíndromos. + Esta función devuelve el valor booleano True si el número es capicúa, de lo contrario + devuelve el valor booleano False + En caso de que el parámetro no sea de tipo entero, debe retornar nulo. + Recibe un argumento: + numero: Será el número sobre el que se evaluará si es capicúa o no lo es. + Ej: + NumeroCapicua(787) debe retornar True + NumeroCapicua(108) debe retornar False + ''' + cadena3 = str(numero) + pali = [] + pali2 = [] + if type(numero) == int: + for i in range(len(cadena3) -1, -1, -1): + pali.append(cadena3[i]) + for j in range(len(pali)-1, -1, -1): + pali2.append(pali[j]) + if (pali == pali2): + return True + else: + return False + else: + return None + + +# Probar +numeros = [11, 20, 123, 9889, 2811, 1801, 777, 12321, ] + +for num in numeros: + es_capicua = NumeroCapicua(num) + print(f"El número {num} es capicúa? {es_capicua}") \ No newline at end of file diff --git a/Workbench/Taller/OrdenaDic b/Workbench/Taller/OrdenaDic new file mode 100644 index 000000000..06e30b663 --- /dev/null +++ b/Workbench/Taller/OrdenaDic @@ -0,0 +1,55 @@ +dicc ={ +'clave1':['c', 'a', 'b'], +'clave2':['casa', 'auto', 'barco'], +'clave3':[3,2,1]} +# 1) Convertir este dic de listas en una lista de dicts +# 2) verificar que no pasan datos nulos o que no cumplen las condciones a) calaves no vacías y que el dic, sea un DICT +# No se puede perder la hilación, or eso tarbajamos con listas. +# Crequear condiciones +clave='clave1' + +# def ordenaDic (dicc_rec, clave): +newArr=[] # Va a recibir mi lista de diccionarios originales convertidos a listas +newArrSorted=[] # Va a recibir los diccionarios ordenados por la clave ingresada +res = [] +cantidadValores = 0 +numKeys = 0 # Recibe la cantidad de elementos del tipo llave que tiene el diccionario DICC, para ejecutar los ciclos. +if not (type(dicc) is dict): #dict_rec= Debería ser el DICC recibido + pass #return 'Null' #None +if not (clave in dicc.keys()): #clave=clave del parámetro + pass #return 'Null' + # definir variables a usar, incluye nuevas listas + # Convertimos el dicc de list a list de dict + # print (len(dicc_rec[list(dicc_par.keys())[0]])) + # chequeamos qué valor estamos reciendo + # print() +print (len(dicc[list(dicc.keys())[0]])) +if len(dicc[list(dicc.keys())[0]])>0: # convertimos el diccionario de listas, a una lista de diccionarios: + cantidadValores = len(dicc[list(dicc.keys())[0]]) + print (cantidadValores) + for i in range(0, cantidadValores): + newObj={} + for key in dicc: + newObj[key]=dicc[key][i] + newArr.append(newObj) #print(newArr) #aquí se generó una lista de diccionarios + newArrSorted = sorted(newArr, key=lambda d: d[clave], reverse=not) # (descendente) Ahora ordenemos + #print (newArrSorted) #verificar contenido del nuevo arreglo + # Convertimos la lista de diccionarios, en un diccionario de listas: + for key in dicc: + newArr2 = [] + for i in range(0, cantidadValores): + newArr2.append(newArrSorted[i][key]) + res[key] = newArr2 + #Si no tienen valores devolvemos el mismo diccionario: +else: + #return dicc_par + print (dicc) + print (res) + +#dicc ={ +#'clave1':['c', 'a', 'b'], +#'clave2':['casa', 'auto', 'barco'], +#'clave3':[3,2,1]} +# print (OrdenarDiccionario(dicc,"clave3",false)) + +# ordenaDic (dicc, 'clave1') \ No newline at end of file diff --git a/Workbench/Taller/aritmetica.py b/Workbench/Taller/aritmetica.py index 7fd04e8f3..ef449849a 100644 --- a/Workbench/Taller/aritmetica.py +++ b/Workbench/Taller/aritmetica.py @@ -1,4 +1,4 @@ -#print (3.5 // 4) +print (3.5 // 3) #print ("7"+"0") #print (int("7"+"0")/2) #Este es un ejemplo de casteo #print ( 2**1 / 12) diff --git a/Workbench/Taller/listas.py b/Workbench/Taller/listas.py index 964da9bd3..c50e047bf 100644 --- a/Workbench/Taller/listas.py +++ b/Workbench/Taller/listas.py @@ -209,8 +209,8 @@ # 2 Dos # Ejemplo 21 - Caso: zip() con un argumento -# Por definición, se puede hacer, porque ZIP está definido para un 'n' arbitrario -# de listas, ergo, también es posible usar un único valor. +# Por definición, se puede hacer, porque ZIP está definido para un 'n' +# arbitrario de listas, ergo, también es posible usar un único valor. # El resultado son tuplas de un elemento...raras, pero se puede. numeros = [1, 2, 3, 4, 5] @@ -218,10 +218,12 @@ print (list(zz)) # R=> [(1,), (2,), (3,), (4,), (5,)] # Ejemplo 22 - Caso: zip() con diccionarios -# Lo común es usar ZIP con listas, pero al estar definida para cualquier clase iterable. +# Lo común es usar ZIP con listas, pero al estar definida para cualquier +# clase iterable. # Podemos usarla con DICCIONARIOS. -# Por ejemplo, si (a,b) toman los valores de las key del diccionario, no parece muy interesante. +# Por ejemplo, si (a,b) toman los valores de las key del diccionario, no parece +# muy interesante. esp = {'1': 'Uno', '2': 'Dos', '3': 'Tres'} eng = {'1': 'One', '2': 'Two', '3': 'Three'} @@ -311,7 +313,7 @@ print(mi_Cola) # R=> ('Diego', 'Luis', 'Jorge']) # La lista restante en orden de llegada -# Ejemplo 26 - Comprensión de listas . MUY IMPORTANTE ENTENDERLO BIEN !! +# Ejemplo 26 - Listas por Comprensión . MUY IMPORTANTE ENTENDERLO BIEN !! # Permite usar expresiones y condiciones para poblar una lista. # Sus usos comunes son para hacer nuevas colecciones donde cada elemento es el resultado # de algunas operaciones aplicadas a cada miembro de otra secuencia o iterable, o diff --git a/Workbench/Taller/pruebaerror.ipynb b/Workbench/Taller/pruebaerror.ipynb index a4c670a96..3c875a91e 100644 --- a/Workbench/Taller/pruebaerror.ipynb +++ b/Workbench/Taller/pruebaerror.ipynb @@ -537,22 +537,921 @@ }, { "cell_type": "code", - "execution_count": 148, + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "from math import pi # Importamos una librería \"MATH\" que nos permite hacer cálculos científicos y usar constantes \n", + "pi_evol= [str(round(pi, i)) for i in range(1, 6)] # Creamos una lista con incrementales de pi\n", + "print ('Los valores incrementales de pi, son ', pi_evol)\n", + "# R=> Los valores incrementales de pi, son ['3.1', '3.14', '3.142', '3.1416', '3.14159']" + ] + }, + { + "cell_type": "code", + "execution_count": 149, + "metadata": {}, + "outputs": [], + "source": [ + "class Persona():\n", + "\n", + " def __init__(self,nombre=\"\",edad=0,dni=\"\"):\n", + " self.nombre=nombre\n", + " self.edad=edad\n", + " self.dni=dni\n", + " \n", + " @property\n", + " def nombre(self):\n", + " return self.__nombre\n", + "\n", + " @property\n", + " def edad(self):\n", + " return self.__edad\n", + "\n", + " @property\n", + " def dni(self):\n", + " return self.__dni\n", + " \n", + " @nombre.setter\n", + " def nombre(self,nombre):\n", + " self.__nombre=nombre\n", + "\n", + " def validar_dni(self):\n", + " letras = \"TRWAGMYFPDXBNJZSQVHLCKE\"\n", + " if len(self.__dni)!=9:\n", + " print(\"DNI incorrecto\")\n", + " self.__dni = \"\"\n", + " else:\n", + " letra = self.__dni[8]\n", + " num = int(self.__dni[:8])\n", + " if letra.upper() != letras[num % 23]:\n", + " print(\"DNI incorrecto\")\n", + " self.__dni = \"\"\n", + "\n", + " @dni.setter\n", + " def dni(self,dni):\n", + " self.__dni=dni\n", + " self.validar_dni()\n", + " \n", + " @edad.setter\n", + " def edad(self,edad):\n", + " if edad < 0:\n", + " print(\"Edad incorrecta\")\n", + " self.__edad=0\n", + " else:\n", + " self.__edad=edad\n", + " \n", + " \n", + " def mostrar(self):\n", + " return \"Nombre:\"+self.nombre+\" - Edad:\"+str(self.edad)+\" - DNI:\"+self.dni\n", + "\n", + " def esMayorDeEdad(self):\n", + " return self.edad>=18\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "def swap(a,b):\n", + " c=a\n", + " a=b\n", + " b=c\n", + " return (a,b)\n", + "\n", + "x = ['ab', 'cd','ef',5]\n", + "y = 4\n", + "print (x,y)\n", + "x,y= swap(x,y)\n", + "print (x,y)\n", + "print ()\n", + "\n", + "# caso 2) Directo y,x = x,y, propiedades de Python\n", + "# \n", + "x= 'diez'\n", + "y= True\n", + "print (x,y)\n", + "x,y=y,x\n", + "print (x,y)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "class Complex:\n", + " def __init__(self, realpart, imagpart):\n", + " self.r = realpart\n", + " self.i = imagpart\n", + "\n", + "x = Complex(3.0, -4.5)\n", + "x.r, x.i\n", + "print (type (x.r))\n", + "3.0, -4.5" + ] + }, + { + "cell_type": "code", + "execution_count": 171, + "metadata": {}, + "outputs": [], + "source": [ + "class Emprendedor:\n", + " \"\"\"En esta clase se crean emprendedores\n", + " Recibe: str (nombre), str (apellido), list (libros), list (mascotas) \n", + " \"\"\"\n", + " mascotas = [] # Lista que acumulará las mascotas del Emprendedor\n", + " libros = [] # Lista que colectará los libros del Emprendedor\n", + " \n", + " def __init__(self, nombre, apellido, libros, mascotas):\n", + " self.nombre = nombre\n", + " self.apellido = apellido\n", + " self.libros = libros\n", + " self.mascotas = mascotas\n", + "\n", + "# b) Crear un Método que agregue una mascota (mascota) a la lista, no debe \n", + "# retornar nada. Mascotas es una lista\n", + "# \n", + "\n", + " def addMascotas (self, newPet): # Si el Empredendor tiene perro y gato, agregué una tortuga\n", + " self.mascotas.append(newPet) #\n", + "\n", + " def getmascotas (self): #\n", + " pass #\n", + "\n", + " def addBook (self, book, newautor): # El método addBook, recibe un str (book) y un str (autor)\n", + " self.libros.append(book) # Debe agregar un objeto DICT que recibe y guarda los parámetros\n", + " pass # dic = {nombre:book, autor:autor} \n", + " # No retorna nada\n", + "\n", + " def getCase (self): # Retorna qtty de mascotas que tiene el emprendedor\n", + " pass # Ej. Si tiene 2 mascotas, debe retornar 2\n", + " # Como es una lista, puedo hacer list.len(self.mascotas)\n", + "\n", + " def getBooks (self): # Debe retornar sólo los nombres de los libros\n", + " pass # Debería devolver ['El Señor de las Moscas', 'Fundación']\n", + "\n", + " \n" + ] + }, + { + "cell_type": "code", + "execution_count": 401, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ - "Los valores incrementales de pi, son ['3.1', '3.14', '3.142', '3.1416', '3.14159']\n" + "la lista de primos es [5, 7, 11, 13]\n" ] } ], "source": [ - "from math import pi # Importamos una librería \"MATH\" que nos permite hacer cálculos científicos y usar constantes \n", - "pi_evol= [str(round(pi, i)) for i in range(1, 6)] # Creamos una lista con incrementales de pi\n", - "print ('Los valores incrementales de pi, son ', pi_evol)\n", - "# R=> Los valores incrementales de pi, son ['3.1', '3.14', '3.142', '3.1416', '3.14159']" + "# LISTA PRIMOS\n", + "\n", + "def ListaPrimos(desde, hasta):\n", + " List_pri=[]\n", + " tope=hasta\n", + " n=desde\n", + " primo = True\n", + " if(type(n) != int):\n", + " return None\n", + " if(type(tope)!= int):\n", + " return None\n", + " while (n<=tope):\n", + " for div in range(2,n):\n", + " if(n%div==0):\n", + " primo=False\n", + " if (primo):\n", + " List_pri.insert(n-1,n)\n", + " else:\n", + " primo = True\n", + " n +=1\n", + " return List_pri\n", + "\n", + "imprime=ListaPrimos (5, 15)\n", + "print ('la lista de primos es',imprime)\n" + ] + }, + { + "cell_type": "code", + "execution_count": 252, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "{'clave1': ['c', 'b', 'a'],\n", + " 'clave2': ['casa', 'barco', 'auto'],\n", + " 'clave3': [3, 2, 1]}" + ] + }, + "execution_count": 252, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "\n", + "# Esta función recibe como parámetro un diccionario, cuyas listas de valores tienen el mismo\n", + "# tamaño y sus elementos enésimos están asociados. Y otros dos parámetros que indican\n", + "# la clave por la cual debe ordenarse y si es descendente o ascendente.\n", + "# La función debe devolver el diccionario ordenado, teniendo en cuenta de no perder la\n", + "# relación entre los elementos enésimos.\n", + "# Recibe tres argumentos:\n", + "#\n", + "# diccionario: Diccionario a ordenar.\n", + "# clave: Clave del diccionario recibido, por la cual ordenar.\n", + "# descendente: Un valor booleano, que al ser verdadero indica ordenamiento ascendente y \n", + "# descendente si es falso. \n", + "# Debe tratarse de un parámetro por defecto en True.\n", + "# Si el parámetro diccionario no es un tipo de dato diccionario ó el parámetro clave no \n", + "# se encuentra dentro de las claves del diccionario, debe devolver nulo.\n", + "# Ej:\n", + "# dicc = {'clave1':['c','a','b'],\n", + "# 'clave2':['casa','auto','barco'],\n", + "# 'clave3':[1,2,3]}\n", + "#\n", + "# OrdenarDiccionario(dicc, 'clave1') debe retornar {'clave1':['a','b','c'],\n", + "# 'clave2':['auto','barco','casa'],\n", + "# 'clave3':[2,3,1]}\n", + "# OrdenarDiccionario(dicc, 'clave3', False) debe retornar {'clave1':['b','a','c'],\n", + "# 'clave2':['barco','auto','casa'],\n", + "# 'clave3':[3,2,1]}\n", + "#debe retornar\n", + "\n", + "# {'clave1':['b','a','c'], 'clave2':['barco','auto','casa'],'clave3':[3,2,1]}\n", + "# \n", + "dicc = {'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]}\n", + "\n", + "def OrdenarDiccionario(diccionario_par, clave, descendente=True):\n", + " listet = list(diccionario_par.keys())\n", + " #print = (listet)\n", + " for i in diccionario_par:\n", + " if i == clave:\n", + " for j in diccionario_par:\n", + " diccionario_par[j].sort()\n", + " if descendente == True:\n", + " diccionario_par[j].reverse()\n", + " \n", + " return diccionario_par\n", + " #return(print (listet))\n", + "\n", + "# print (dicc)\n", + "OrdenarDiccionario(dicc, 'clave1') \n", + "\n", + "#OrdenarDiccionario(dicc, 'clave3', False)\n", + "\n", + "\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# Sin embargo, si usamos la función items del tipo DICT, podemos acceder\n", + "# al key y al value de cada elemento.\n", + "# Se puede facilitar para modificar valores usando, e.g casteo de dict a list y viceversa\n", + "#esp = {'1': 'Uno', '2': 'Dos', '3': 'Tres'}\n", + "#eng = {'1': 'One', '2': 'Two', '3': 'Three'}\n", + "\n", + "#for (k1, v1), (k2, v2) in zip(esp.items(), eng.items()):\n", + "# print(k1, v1, v2)\n", + "# Nótese que en este caso ambas key k1 y k2 son iguales.\n", + "# 1 Uno One\n", + "# 2 Dos Two\n", + "# 3 Tres Three\n", + "dicc = {'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]}\n", + "dicc_list = dicc.items()\n", + "dicc_list = list (dicc_list)\n", + "#print (dicc_items[1:3]) \n", + "k0 = ['clave1', 'clave2', 'clave3']\n", + "v1 = ['c', 'b', 'a']\n", + "v2 = ['casa', 'barco', 'auto']\n", + "v3 = [3, 2, 1]\n", + "i=1\n", + "#print(k0[0], v1[0], v2[0], v3[0])\n", + "#keyword=\n", + "#for i (k[i], v1), (k[i], v2), (k[i],v3) in dicc.items():\n", + "for i in dicc_list:\n", + " print(dicc_list(i), dicc_items.values(i), dicc_items.values(i), dicc_items.values(3))\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "valor=777\n", + "print (valor)\n", + "print ()\n", + "cadena=str(valor)\n", + "indice=-1\n", + "iguales=0\n", + "for x in range(0,len(cadena)/2):\n", + " if cadena[x]==cadena[indice]:\n", + " iguales=iguales+1\n", + " indice=indice-1\n", + "if iguales==(len(cadena)/2):\n", + " print ('Es capicua')\n", + "else:\n", + " print ('No es capicua')" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "'''\n", + " En matemáticas, la palabra capicúa (del catalán cap i cua, 'cabeza y cola')​ \n", + " se refiere a cualquier número que se lee igual de izquierda a derecha que \n", + " de derecha a izquierda. Se denominan también números palíndromos.\n", + " Esta función devuelve el valor booleano True si el número es capicúa, de lo contrario\n", + " devuelve el valor booleano False \n", + " En caso de que el parámetro no sea de tipo entero, debe retornar nulo.\n", + " Recibe un argumento:\n", + " numero: Será el número sobre el que se evaluará si es capicúa o no lo es.\n", + " Ej:\n", + " NumeroCapicua(787) debe retornar True\n", + " NumeroCapicua(108) debe retornar False\n", + "'''\n", + "def NumeroCapicua(numero):\n", + " cadena3 = str(numero)\n", + " pali = []\n", + " pali2 = []\n", + " if type(numero) == int:\n", + " for i in range(len(cadena3) -1, -1, -1):\n", + " pali.append(cadena3[i])\n", + " for j in range(len(pali)-1, -1, -1):\n", + " pali2.append(pali[j])\n", + " if (pali == pali2):\n", + " return True\n", + " else:\n", + " return False\n", + " else:\n", + " return None\n", + " \n", + " \n", + "print (NumeroCapicua(92529))" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "# factorizar_numero(5)\n", + "# valor_esperado = [[5],[1]]\n", + "# \n", + "# factorizar_numero(1428)\n", + "# valor_esperado = [[2,3,7,17], [2,1,1,1]]\n", + "# \n", + "# factorizar_numero('cinco')\n", + "# valor_esperado = None\n", + "# \n", + "\n", + "def factorizar_numero(numero):\n", + " '''\n", + " Esta función recibe como parámetro un número entero mayor a cero y devuelva dos listas, \n", + " una con cada factor común y otra con su exponente, \n", + " esas dos listas tienen que estar contenidas en otra lista.\n", + " En caso de que el parámetro no sea de tipo entero y/ó mayor a cero debe retornar nulo.\n", + " Recibe un argumento:\n", + " numero: Será el número sobre el que se hará la factorización.\n", + " Ej:\n", + "\n", + " factorizar_numero(12) debe retornar [[2,3],[2,1]]\n", + " factorizar_numero(13) debe retornar [[13],[1]]\n", + " factorizar_numero(14) debe retornar [[2,7],[1,1]]\n", + " '''\n", + " lista_factores = []\n", + " lista_exponentes = []\n", + " if type(numero) == int:\n", + " #i= \n", + " while numero%2 != 1:\n", + " n=(i%2)\n", + " if n==1:\n", + " lista_i.append (i)\n", + " elif n==0:\n", + " lista_p.append (i)\n", + " print (\"Los números impares entre 1 y 10 son \", lista_i)\n", + " print (\"Los números pares entre 1 y 10 son \", lista_p)\n" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "def factoriza(n):\n", + " l = []\n", + " i = 2\n", + " while (i * i) <= n:\n", + " while (n % i) == 0:\n", + " l.append(i)\n", + " n = n / i\n", + " i = i + 1\n", + " if n != 1:\n", + " l.append(n)\n", + " return l\n", + "factoriza (10)" + ] + }, + { + "cell_type": "code", + "execution_count": 414, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "2\n" + ] + } + ], + "source": [ + "print (27%5)" + ] + }, + { + "cell_type": "code", + "execution_count": 406, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "1\n", + "3\n", + "17\n", + "51\n" + ] + } + ], + "source": [ + "#def divisores ():\n", + "num = int (input ('Escribe un entero'))\n", + "listaFC = []\n", + "i=1\n", + "while i<=num:\n", + " if num%i==0:\n", + " listaFC.append(num//i)\n", + " listaFC.sort()\n", + " i+=1\n", + "for f in listaFC:\n", + " print (f)\n", + " #, end=',')\n", + "\n" + ] + }, + { + "cell_type": "code", + "execution_count": 376, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "La palabra ' 777 ' no es palíndroma e invertida, es []\n" + ] + } + ], + "source": [ + "num = input ('Ingrese número _')\n", + "cadena3 = str(num)\n", + "cadena4 = \"reconocer\" # R=> 'reconocer', es palíndroma\n", + "pali = []\n", + "pali2 = []\n", + "if (num!=int):\n", + " print (\"La palabra\",\"'\", cadena3,\"'\", \"no es palíndroma e invertida, es\", pali, end=\"\") \n", + " \n", + "elif (nun>0):\n", + " for i in range(len(cadena3) -1, -1, -1):\n", + " pali.append(cadena3[i])\n", + " for j in range(len(pali)-1, -1, -1):\n", + " pali2.append(pali[j])\n", + " if (pali == pali2):\n", + " #return True\n", + " print(\"es palíndromo\")\n", + "else:\n", + " #return False\n", + " print (\"La palabra\",\"'\", cadena3,\"'\", \"no es palíndroma e invertida, es\", pali, end=\"\")\n", + "print()" + ] + }, + { + "cell_type": "code", + "execution_count": 353, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "[('Rojo', '4859-A', 'A'), ('Gris', '1892-B', 'M'), ('Azul', '2901-Z', 'M')]" + ] + }, + "execution_count": 353, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "tuplas_coches = [\n", + " ('Rojo', '4859-A', 'A'),\n", + " ('Azul', '2901-Z', 'M'),\n", + " ('Gris', '1892-B', 'M')\n", + "]\n", + "ordenarpor='0'\n", + "\n", + "if ordenarpor == 0:\n", + "\n", + "sorted(tuplas_coches, key=itemgetter(2, 1))\n", + "#[('Rojo', '4859-A', 'A'), ('Gris', '1892-B', 'M'), ('Azul', '2901-Z', 'M')]" + ] + }, + { + "cell_type": "code", + "execution_count": 335, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "['c', 'a', 'b']\n" + ] + } + ], + "source": [ + "from operator import itemgetter\n", + "def OrdenarDiccionario(diccionario_par, clave, descendente=True):\n", + " dicc = {'clave1':['c','a','b'], 'clave2':['casa','auto','barco'], 'clave3':[1,2,3]}\n", + "\n", + " for n in sorted(dicc), str(\"clave1\"):\n", + " return n\n", + "\n", + "def ordenardiccionario2(self):\n", + " dicc = ['c','a','b']\n", + " for x in sorted(dicc, str(\"clave1\"), True):\n", + " return None\n", + " \n", + "def ordenardiccionario3(self): \n", + " dicc = {'clave1':['c','a','b'], 'clave2':['casa','auto','barco'], 'clave3':[3,1,2]}\n", + " for j in sorted(dicc, str(\"clave3\"), False):\n", + " return j\n", + "\n", + "OrdenarDiccionario(dicc, 'clave3') \n", + "print(dicc.get('clave1')) #Sara" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "dicc = {\n", + " 'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]\n", + " }\n", + "bykey=dicc.keys () # Guardo las llaves en una var\n", + "keyord='clave1' # Guardo la la clave por la que quiero ordenar\n", + "# sorted_bykey={}\n", + "# print (bykey)\n", + "# sorted_bykey=sorted(bykey)\n", + "# print (sorted_bykey)\n", + "# sorted_bykey={}\n", + "#for\n", + "dic_ord_by_key = sorted(dicc, key=keyord)\n", + "print (\"Ordenada por calificación ascendente: \")\n", + "for algo in dic_ord_by_key:\n", + " print (keyword)" + ] + }, + { + "cell_type": "code", + "execution_count": 275, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "{'clave1': ['c', 'a', 'b'], 'clave2': ['casa', 'auto', 'barco'], 'clave3': [1, 2, 3]}\n" + ] + } + ], + "source": [ + "dicc = {\n", + " 'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]\n", + " }\n", + "\n", + "#for x in dicc:\n", + "# print(dicc[x])\n", + "# ['c', 'a', 'b']\n", + "# ['casa', 'auto', 'barco']\n", + "# [1, 2, 3]\n", + "print(dicc)\n" + ] + }, + { + "cell_type": "code", + "execution_count": 325, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "{'clave1': ['c', 'a', 'b'], 'clave2': ['casa', 'auto', 'barco'], 'clave3': [1, 2, 3]}\n" + ] + } + ], + "source": [ + "key_list = ['clave1', 'clave2', 'clave3']\n", + "value_list1 = [['c', 'a', 'b'], ['casa', 'auto', 'barco'], [1, 2, 3]]\n", + "\n", + "# ['c', 'a', 'b']\n", + "# ['casa', 'auto', 'barco']\n", + "# [1, 2, 3]\n", + "dict_from_list = dict(zip(key_list, value_list1))\n", + "print(dict_from_list)\n", + "# {'clave1':['b','a','c'], 'clave2':['barco','auto','casa'],'clave3':[3,2,1]}" + ] + }, + { + "cell_type": "code", + "execution_count": 330, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "{'nombre': 'Juan', 'edad': '27', 'ciudad': 'Nueva York'}\n" + ] + } + ], + "source": [ + "key_list = ['clave1', 'clave2', 'clave3']\n", + "value_list = ['Juan', '27', 'Nueva York']\n", + "\n", + "dict_from_list = {k: v for k, v in zip(key_list, value_list)}\n", + "print(dict_from_list)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "def sum (a,b):\n", + " return 'Null'\n", + " \n", + "sum (2,3)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "\n", + "dicc = {\n", + " 'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]\n", + " }\n", + "varkeys=len()\n", + "\n", + "if len(varkeys[list(dicc.keys()]>0) \n", + "\tvalores=len(dicc_par[list(dicc_par.keys())[0]])\n", + "# convertimos el diccionario de listas, a una lista de diccionarios:\t\n", + "\tfor i in range(0, valores):\n", + "\t\tnewObj[key] = dicc_par[key][i]\n", + "\tnewArr.append(newObj)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "dicc ={\n", + "'clave1':['c', 'a', 'b'],\n", + "'clave2':['casa', 'auto', 'barco'],\n", + "'clave3':[3,2,1]}\n", + "dicc_swp= {} # Recibe dic transitorios no ordenados, ver si es lista o no\n", + "dicc_ord= {} # Recibe el nuevo dic ordenado \n", + "listkeys =list(dicc.keys())\n", + "listvalues = list(dicc.values())\n", + "print (listvalues)\n", + "print (type(listkeys))\n", + "print (len(listkeys)) # List horz de las keys\n", + "print (listkeys) # Ahora sabemos cuantos elementos tiene\n", + "for k in listkeys:\n", + " print (k)\n", + "for v in listvalues:\n", + " print (v)\n", + "\n" + ] + }, + { + "cell_type": "code", + "execution_count": 324, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "Ord1= [('Gris', '1892-B', 'M'), ('Azul', '2901-Z', 'M'), ('Rojo', '4859-A', 'A')]\n", + "Ord2= [{'color': 'Gris', 'matricula': '1892-B', 'cambio': 'M'}, {'color': 'Azul', 'matricula': '2901-Z', 'cambio': 'M'}, {'color': 'Rojo', 'matricula': '4859-A', 'cambio': 'A'}]\n" + ] + } + ], + "source": [ + "# Ordenar una lista de coches almacenados como tuplas\n", + "tuplas_coches = [\n", + " ('Rojo', '4859-A', 'A'),\n", + " ('Azul', '2901-Z', 'M'),\n", + " ('Gris', '1892-B', 'M')\n", + " ]\n", + "\n", + "# Ordenar los coches por matrícula\n", + "ordenados1 = sorted(tuplas_coches, key=lambda coche : coche[1])\n", + "print ('Ord1=', ordenados1)\n", + "# [('Gris', '1892-B', 'M'), ('Azul', '2901-Z', 'M'), ('Rojo', '4859-A', 'A')]\n", + "\n", + "# Ordenar una lista de coches almacenados como diccionarios\n", + "diccionarios_coches = [\n", + " {'color': 'Rojo', 'matricula': '4859-A', 'cambio': 'A'},\n", + " {'color': 'Azul', 'matricula': '2901-Z', 'cambio': 'M'},\n", + " {'color': 'Gris', 'matricula': '1892-B', 'cambio': 'M'}\n", + "]\n", + "ordenados2 = sorted (diccionarios_coches, key=lambda coche : coche['matricula'])\n", + "print ('Ord2=', ordenados2)\n", + "# [{'color': 'Gris', 'matricula': '1892-B', 'cambio': 'M'}, \n", + "# {'color': 'Azul', 'matricula': '2901-Z', 'cambio': 'M'}, \n", + "# {'color': 'Rojo', 'matricula': '4859-A', 'cambio': 'A'}]" + ] + }, + { + "cell_type": "code", + "execution_count": 281, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "este es el dicc ordenado por la clave X {'clave1': ['b', 'a', 'c'], 'clave2': ['barco', 'auto', 'casa'], 'clave3': [3, 2, 1]}\n" + ] + } + ], + "source": [ + "dicc={'midic':('a',b'')}\n", + "if type(diccionario_pa) != dict:\n", + " if type(get)\n", + " return None\n", + "dicc2={'clave1':['b','a','c'], 'clave2':['barco','auto','casa'],'clave3':[3,2,1]}\n", + "print ('este es el dicc ordenado por la clave X', dicc2)" + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "juegos = [\n", + " {\n", + " \"nombre\": \"Resident Evil 2\",\n", + " \"calificacion\": 99,\n", + " },\n", + " {\n", + " \"nombre\": \"Crash Bandicoot N. Sane Trilogy\",\n", + " \"calificacion\": 76,\n", + " },\n", + "\n", + " {\n", + " \"nombre\": \"Cuphead\",\n", + " \"calificacion\": 100,\n", + " },\n", + " {\n", + " \"nombre\": \"Minecraft\",\n", + " \"calificacion\": 80,\n", + " },\n", + " {\n", + " \"nombre\": \"Bioshock\",\n", + " \"calificacion\": 95,\n", + " },\n", + "]\n", + "def funcion_que_devuelve_clave(juego):\n", + " # Vamos a ordenar basándonos en su calificación, y como se nos\n", + " # va a pasar un diccionario, devolvemos el elemento \"calificacion\"\n", + " return juego[\"calificacion\"]\n", + "\n", + "# La ordenamos\n", + "juegos_ordenados = sorted(juegos, key=funcion_que_devuelve_clave)\n", + "print(\"Ordenada por calificación ascendente: \")\n", + "for juego in juegos_ordenados:\n", + " print(juego)\n", + "# También se puede en orden inverso\n", + "juegos_ordenados = sorted(juegos, key=funcion_que_devuelve_clave, reverse=True)\n", + "print(\"Ordenada por calificación descendente: \")\n", + "\n", + "for juego in juegos_ordenados:\n", + " print(juego)" + ] + }, + { + "cell_type": "code", + "execution_count": 250, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "nuemero e claves 6\n", + "{'clave1': 1.97, 'clave2': 8.49, 'clave3': 9.79, 'clave4': 1.2, 'clave5': 0.43, 'clave6': ['a', 'b', 'c']}\n" + ] + } + ], + "source": [ + "clients = {'clave1': 1.97,\n", + " 'clave2': 8.49,\n", + " 'clave3': 9.79,\n", + " 'clave4': 8.53,\n", + " 'clave5': 0.43}\n", + "\n", + "dicc = {'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]}\n", + "\n", + "clients ['clave1']\n", + "clients ['clave4'] = 1.20\n", + "clients ['clave6'] = ['a', 'b', 'c']\n", + "# print (clients)\n", + "#for idx in enumerate (clients): # Creo una variable cualquiera\n", + "# print (idx[0], 'ha gastado', clients[idx[1]]) # \"algo\" para recorrer clients\n", + "#clients_sort=sorted(clients)\n", + "orden = len (clients.keys())\n", + "print ('nuemero e claves', orden)\n", + "print (clients) #\n", + " \n", + " \n" + ] + }, + { + "cell_type": "code", + "execution_count": 232, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "{'clave1': 1.97, 'clave2': 8.49, 'clave3': 9.79, 'clave4': 8.53, 'clave5': 0.43}\n", + "{'clave1': 1.97, 'clave2': 8.49, 'clave3': 9.79, 'clave4': 8.53, 'clave5': 0.43, 'clave6': ['a', 'b', 'c']}\n" + ] + } + ], + "source": [ + "clients = {'clave1': 1.97,\n", + " 'clave2': 8.49,\n", + " 'clave3': 9.79,\n", + " 'clave4': 8.53,\n", + " 'clave5': 0.43}\n", + "print (clients)\n", + "clients ['clave6']= ['a','b','c']\n", + "print (clients)\n" ] } ], diff --git a/Workbench/Taller/variables.py b/Workbench/Taller/variables.py index bfd2c9c5b..feb9d0f3f 100644 --- a/Workbench/Taller/variables.py +++ b/Workbench/Taller/variables.py @@ -9,3 +9,26 @@ print (a+b) total =2+4 print (total) +# Ejemplo 10 - SWAP de variable - Deben ser del mismo tipo (INT) +# caso 1) Creamos una Función + +def swap(a,b): + c=a + a=b + b=c + return a,b + +x = 5 +y = 4 +print (x,y) +x,y= swap(x,y) +print (x,y) +print () + +# caso 2) Directo y,x = x,y, propiedades de Python +# +x=10 +y=20 +print (x,y) +x,y=y,x +print (x,y) \ No newline at end of file From 02a9c8789d6da70f66a8ab6384442057d8757728 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sat, 28 Jan 2023 13:58:51 -0300 Subject: [PATCH 12/16] 28011358-Prueba Sync --- Workbench/Taller/EjMix_DicLis.py | 446 +++++++++++++++++++++++++++++ Workbench/Taller/HC280123.ipynb | 302 +++++++++++++++++++ Workbench/Taller/pruebaerror.ipynb | 291 ++++++++----------- 3 files changed, 872 insertions(+), 167 deletions(-) create mode 100644 Workbench/Taller/EjMix_DicLis.py create mode 100644 Workbench/Taller/HC280123.ipynb diff --git a/Workbench/Taller/EjMix_DicLis.py b/Workbench/Taller/EjMix_DicLis.py new file mode 100644 index 000000000..e3ff8a747 --- /dev/null +++ b/Workbench/Taller/EjMix_DicLis.py @@ -0,0 +1,446 @@ +# Importante: No modificar ni el nombre ni los argumetos que reciben las funciones, sólo deben escribir +# código dentro de las funciones ya definidas. + +def ListaDivisibles(numero, tope): + ''' + Esta función devuelve una lista ordenada de menor a mayor con los números divisibles + por el parámetro número entre uno (1) y el valor del parámetro "tope" + Recibe dos argumentos: + numero: Numero entero divisor + tope: Máximo valor a evaluar a partir de uno (1) + Ej: + ListaDivisibles(6,30) debe retornar [6,12,18,24,30] + ListaDivisibles(10,5) debe retornar [] + ListaDivisibles(7,50) debe retornar [7,14,21,28,35,42,49] + ''' + #Tu código aca: + lista_rango = list(range(numero,tope+1)) + lista_num_divisibles = [] + + if numero > tope: + print(lista_num_divisibles) + return lista_num_divisibles + if numero <= 0: + print(str(numero) + ', que corresponde a ser el divisor, NO puede ser = 0.') + return None + + for i in lista_rango: + if (i % numero) == 0: + lista_num_divisibles.append(i) + lista_num_divisibles.sort(reverse=False) + print(lista_num_divisibles) + return lista_num_divisibles + +#ListaDivisibles(6,30) +#ListaDivisibles(10,5) +#ListaDivisibles(7,50) + +#O.K. - Revisado y testeado! + + +def Exponente(numero, exponente): + ''' + Esta función devuelve el resultado de elevar el parámetro "numero" al parámetro "exponente" + Recibe dos argumentos: + numero: El número base en la operación exponencial + exponente: El número exponente en la operación exponencial + Ej: + Exponente(10,3) debe retornar 1000 + ''' + #Tu código aca: + exponente = numero**exponente + print(exponente) + return exponente + +#Exponente(10,3) + +#O.K. - Revisado y testeado! + + +def ListaDeListas(lista): + ''' + Esta función recibe una lista, que puede contener elementos que a su vez sean listas y + devuelve esos elementos por separado en una lista única. + En caso de que el parámetro no sea de tipo lista, debe retornar nulo. Listo! + Recibe un argumento: + lista: La lista que puede contener otras listas y se convierte a una + lista de elementos únicos o no iterables. + Ej: + ListaDeListas([1,2,['a','b'],[10]]) debe retornar [1,2,'a','b',10] + ListaDeListas(108) debe retornar el valor nulo. + ListaDeListas([[1,2,[3]],[4]]) debe retornar [1,2,3,4] + ''' + #Tu código aca: + listaplana = list() + + if type(lista) != list: + print('No es una lista.') + return None + + for elemento in lista: + if type(elemento) != list: + listaplana.append(elemento) + if type(elemento) == list: + for elemento2 in list(elemento): + if type(elemento2) != list: + listaplana.append(elemento2) + if type(elemento2) == list: + listaplana.extend(ListaDeListas(elemento2)) + + + + print(listaplana) + return listaplana + + +#ListaDeListas([1,2,['a','b'],[10]]) +#ListaDeListas(108) +#ListaDeListas([[1,2,[3]],[4]]) +#ListaDeListas([[1,2,[3,[6,6,6,[7,[['iri'],8,9,[11]],],6,6]]],[4]]) #extra prueba + + +def Factorial(numero): + ''' + Esta función devuelve el factorial del número pasado como parámetro. + En caso de que no sea de tipo entero y/o sea menor que 0, debe retornar nulo. ok + Recibe un argumento: + numero: Será el número con el que se calcule el factorial + Ej: + Factorial(4) debe retornar 24 + Factorial(-2) debe retornar nulo + Factorial(0) debe retornar 1 + ''' + #Tu código aca: + if (type(numero) != int) or (numero < 0): + print('El numero no pertence a los enteros positivos.') + return None + + import math + + factorial = math.factorial(numero) + print(factorial) + return factorial + +#Factorial(9) +#Factorial(4) +#Factorial(-2) +#Factorial(0) + +# O.K. tested & ok + + +def ListaPrimos(desde, hasta): + ''' + Esta función devuelve una lista con los números primos entre los valores "desde" y "hasta" + pasados como parámetro, siendo ambos inclusivos. + + En caso de que alguno de los parámetros no sea de tipo entero y/o no sea mayor a cero, + debe retornar nulo. ok + + En caso de que el segundo parámetro sea mayor al primero, pero ambos mayores que cero, + debe retornar una lista vacía. ok + + Recibe un argumento: + desde: Será el número a partir del cual se toma el rango + hasta: Será el número hasta el cual se tome el rango + + Ej: + ListaPrimos(7,15) debe retornar [7,11,13] + ListaPrimos(100,99) debe retornar [] + ListaPrimos(1,7) debe retonan [1,2,3,5,7] + ''' + #Tu código aca: + + # 1. En caso de que alguno de los parámetros no sea de tipo entero y/o no sea mayor a cero, + # debe retornar nulo. + + if(type(desde or hasta) != int) or ((desde or hasta) < 0): + print('Valores no son enteros reales positivos.') + return None + + # 2. En caso de que el segundo parámetro sea mayor al primero, pero ambos mayores que cero, + # debe retornar una lista vacía. + # entiendo que hay un error en la consigna, si no deberíamos utilizar valores absolutos ya que la cuenta seria regresiva en -1, -2, -3 etc + # y supongo que lo que no quiere es que hagamos esto. obtener un desplazamiento negatico coodenada final(hasta) menos inicial(desde).. + + if desde > hasta: + print('Parametros incorrectos.El valor "desde" debe ser menor que "hasta".') + return [] + + + # 3. Esta función devuelve una lista con los números primos entre los valores "desde" y "hasta" + # pasados como parámetro, siendo ambos inclusivos. + + # 3.1 Desde" y "hasta" pasados como parámetro, siendo ambos inclusivos. + + lista_a_analizar = range(desde,hasta+1) + lista_ya_analizados = [] + es_primo = True + lista_primos = [] + import math + + for elemento in lista_a_analizar: + for i in range(2,elemento): + if (elemento % i == 0): + es_primo = False + break + else: + es_primo = True + lista_primos.append(elemento) + break + + print(lista_primos) + return lista_primos + +#ListaPrimos(7,15) +#ListaPrimos(100,99) +#ListaPrimos(1,7) +#ListaPrimos(4,150) #prueba extra + +# O.K. tested & Chequed! + + + + + +def ListaRepetidos(lista): + ''' + Esta función recibe como parámetro una lista y devuelve una lista de tuplas donde cada + tupla contiene un valor de la lista original y las veces que se repite. Los valores + de la lista original no deben estar repetidos. + Debe respetarse el orden original en el que aparecen los elementos. + + En caso de que el parámetro no sea de tipo lista debe retornar nulo. ok + + Recibe un argumento: + lista: Será la lista que se va a evaluar. + Ej: + ListaRepetidos([]) debe retornar [] + ListaRepetidos(['hola', 'mundo', 'hola', 13, 14]) + debe retornar [('hola',2),('mundo',1),(13,1),(14,1)] + ListaRepetidos([1,2,2,4]) debe retornar [(1,1),(2,2),(4,1)] + ''' + #Tu código aca: + + # 1. Esta función recibe como parámetro una lista ; En caso de que el parámetro no sea de tipo lista debe retornar nulo. ok + if type(lista) != list: + print('El parámetro ingresado no es una Lista.') + return None + + # 2. Devuelve una lista de tuplas donde cada + # tupla contiene un valor de la lista original y las veces que se repite. + # Los valores de la lista original no deben estar repetidos. + # Debe respetarse el orden original en el que aparecen los elementos. + lista_ya_analizados = list() + for elemento in lista: + if (type(elemento) != list): + + if (elemento not in lista_ya_analizados): + lista_ya_analizados.append(elemento) + else: + pass + + if type(elemento) == list: + ListaRepetidos(elemento) + print('Lista de elementos unicos encontrados:') + print(lista_ya_analizados) + + lista_cant_de_repeticiones = [] + + for elemento2 in lista_ya_analizados: + cantidad_de_repes_del_elemento2 = lista.count(elemento2) + lista_cant_de_repeticiones.append(cantidad_de_repes_del_elemento2) + + print(lista_cant_de_repeticiones) + + #conversion a tupla + respuesta = list(zip (lista_ya_analizados,lista_cant_de_repeticiones)) + print(respuesta) + return respuesta + + +#ListaRepetidos([]) +#ListaRepetidos(['hola', 'mundo', 'hola', 13, 14]) +#ListaRepetidos([1,2,2,4]) +#ListaRepetidos(ListaDeListas([1,[2,3,4,2,['l','k','j'],1,'q','w',],2,2,4,])) #extra prueba + +# O.K. Tested ok chequed + + + +def ClaseVehiculo(tipo, color): + ''' + Esta función devuelve un objeto instanciado de la clase Vehiculo, + la cual debe tener los siguientes atributos: + + Tipo: Un valor dentro de los valores posibles: ['auto','camioneta','moto'] + Color: Un valor de tipo de dato string. + Velocidad: Un valor de tipo de dato float, que debe inicializarse en cero. + + y debe tener el siguiente método: + + Acelerar(): Este método recibe un parámetro con el valor que debe incrementar a la + propiedad Velocidad y luego retornarla. + Si la propiedad Velocidad cobra un valor menor a cero, debe quedar en cero. + Si la propiedad Velocidad cobra un valor mayor a cien, debe quedar en cien. + + Recibe dos argumento: + tipo: Dato que se asignará al atributo Tipo del objeto de la clase Vehiculo + color: Dato que se asignará al atributo Color del objeto de la clase Vehiculo + + Ej: + a = ClaseVehículo('auto','gris') + a.Acelerar(10) -> debe devolver 10 + a.Acelerar(15) -> debe devolver 25 + a.Acelerar(-10) -> debe devolver 15 + ''' + #Tu código aca: + lista_tipos_permitidos = ['auto','camioneta','moto'] + + # Validaciones al crear la CLASE: + + if tipo not in lista_tipos_permitidos: + print('Error al crear la clase, este tipo de vehiculo no se permite crear, solo estos se pueden: ("auto", "camioneta", "moto").') + print('Error al crear vehiculo.') + return None + + if type(color) != str: + print('El dato "color" no es un str.') + print('Error al crear vehiculo.') + return None + + tipo = tipo + color = color + + # Creando un vehiculo + # Para ello debe existir primero la clase dentro de la funcion. + # de manera que siempre exista dentro del paquete de la funcion si esta se exporta. + class Vehicle: + ''' + Clase Veiculos dentro de funcion crear vehiculo. + ''' + def __init__(self,tipo,color,velocidad = float(0)): + + self.tipo = tipo + self.color = color + self.velocidad = float() + self.incremento_velocidad = float(0) + + def Acelerar(self,incremento_velocidad = float(0)): + """ + Este método recibe un parámetro con el valor que debe incrementar a la + propiedad Velocidad y luego retornarla. + + Si la propiedad Velocidad cobra un valor menor a cero, debe quedar en cero. + + Si la propiedad Velocidad cobra un valor mayor a cien, debe quedar en cien. + """ + velocidad_inicial = self.velocidad + velocidad_final = velocidad_inicial + incremento_velocidad + + if velocidad_final > 100: + velocidad_final = 100 + self.velocidad = velocidad_final + return self.velocidad + elif velocidad_final < 0: + velocidad_final = 0 + self.velocidad = velocidad_final + return self.velocidad + else: + self.velocidad = velocidad_final + return self.velocidad + + def PropiedadesDelVehiculo(self,tipo,color,velocidad): + print(tipo) + print(color) + print(velocidad) + return tipo , color, velocidad + + vehiculo_creado = Vehicle(tipo,color) + return vehiculo_creado + +#a = ClaseVehiculo('auto','gris') +#print(a) +#print(a.Acelerar(10)) +#print(a.Acelerar(15)) +#print(a.Acelerar(-10)) + +# O.K. tested ok checked + + + +def OrdenarDiccionario(diccionario_par, clave, descendente=bool(True)): + ''' + Esta función recibe como parámetro un diccionario, + cuyas listas de valores tienen el mismo tamaño y + sus elementos enésimos están asociados. + + Y otros dos parámetros que indicanla clave por la cual debe ordenarse y si es descendente o ascendente. + + La función debe devolver el diccionario ordenado, teniendo en cuenta de no perder la + relación entre los elementos enésimos. + + Recibe tres argumentos: + diccionario: Diccionario a ordenar. + clave: Clave del diccionario recibido, por la cual ordenar. + descendente: Un valor booleano, que al ser verdadero indica ordenamiento ascendente y + descendente si es falso. + Debe tratarse de un parámetro por defecto en True. + + Si el parámetro diccionario no es un tipo de dato diccionario ok + ó el parámetro clave no se encuentra dentro de las claves del diccionario, debe devolver nulo. ok + + Ej: + + dicc = {'clave1':['c','a','b'], + 'clave2':['casa','auto','barco'], + 'clave3':[1,2,3]} + OrdenarDiccionario(dicc, 'clave1') debe retornar {'clave1':['a','b','c'], + 'clave2':['auto','barco','casa'], + 'clave3':[2,3,1]} + OrdenarDiccionario(dicc, 'clave3', False) debe retornar {'clave1':['b','a','c'], + 'clave2':['barco','auto','casa'], + 'clave3':[3,2,1]} + ''' + #Tu código aca: + + + # Si el parámetro diccionario no es un tipo de dato diccionario + # ó el parámetro clave no se encuentra dentro de las claves del diccionario, debe devolver nulo. + + if (type(diccionario_par) != dict) | (clave not in diccionario_par): + print('El parámetro recibido como diccionario, no lo es en cuanto a tipo de dato.') + print('O la clave ingresada no se encuentra dentro de las claves posivbles del diccionario.') + return None + + # valido longitud en ambas deirecciones de la matriz diccionario: + #cantidadd de claves como de elementos, a su vez, dentro de las claves.') + + """ + dicc = { 'clave1': ['c','a','b'], + 'clave2': ['casa','auto','barco'], + 'clave3': [1,2,3]} + + OrdenarDiccionario(dicc, 'clave1') + """ + + + for i in diccionario_par: + if i == clave: + for j in diccionario_par: + if descendente == False: + diccionario_par[j].sort() + if descendente == True: + diccionario_par[j].sort(reverse=True) + + + print(diccionario_par) + return diccionario_par + + +# OrdenarDiccionario(dicc, 'clave3',True) +# OrdenarDiccionario(dicc, 'clave3',False) +# OrdenarDiccionario(dicc, 'clave1',True) +#OrdenarDiccionario(dicc, 'clave4',False) + +#checked OK. tested OK. \ No newline at end of file diff --git a/Workbench/Taller/HC280123.ipynb b/Workbench/Taller/HC280123.ipynb new file mode 100644 index 000000000..552712320 --- /dev/null +++ b/Workbench/Taller/HC280123.ipynb @@ -0,0 +1,302 @@ +{ + "cells": [ + { + "cell_type": "code", + "execution_count": 1, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "[3, 6, 9]\n" + ] + } + ], + "source": [ + "# LISTA DIVISIBLES\n", + "\n", + "# ListaDivisibles(12, 10)\n", + "# lista_esperada = []\n", + "\n", + "# ListaDivisibles(12, 100)\n", + "# lista_esperada = [12,24,36,48,60,72,84,96]\n", + "\n", + "# ListaDivisibles(3, 9)\n", + "# lista_esperada = [3,6,9]\n", + "\n", + "def ListaDivisibles(numero, tope):\n", + " '''\n", + " Esta función devuelve una lista ordenada de menor a mayor con los números divisibles \n", + " por el parámetro número entre uno (1) y el valor del parámetro \"tope\"\n", + " Recibe dos argumentos:\n", + " numero: Numero entero divisor\n", + " tope: Máximo valor a evaluar a partir de uno (1)\n", + " Ej:\n", + " ListaDivisibles(6,30) debe retornar [6,12,18,24,30]\n", + " ListaDivisibles(10,5) debe retornar []\n", + " ListaDivisibles(7,50) debe retornar [7,14,21,28,35,42,49]\n", + " '''\n", + " #Tu código aca:\n", + " lint = list(range(numero,tope+1))\n", + " ldiv = []\n", + " \n", + " if numero > tope:\n", + " print(ldiv)\n", + " return ldiv\n", + " if numero <= 0:\n", + " print(str(numero) + ', que corresponde a ser el divisor, NO puede ser = 0.')\n", + " return None\n", + " for i in lint:\n", + " if (i % numero) == 0:\n", + " ldiv.append(i)\n", + " ldiv.sort(reverse=False)\n", + " print(ldiv) \n", + " return ldiv\n", + " \n", + "lista_divisible=ListaDivisibles(3, 9)\n", + " # 12, 10 []\n", + " # 12. 100 [12,24,36,48,60,72,84,96]\n", + " # 3, 9 [3,6,9]\n", + "\n", + "# Test OK!" + ] + }, + { + "cell_type": "code", + "execution_count": 9, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "1000" + ] + }, + "execution_count": 9, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "# Exponente(10, 2)\n", + "# valor_esperado = 100\n", + "# Exponente(49, 0.5)\n", + "# valor_esperado = 7\n", + "# Exponente(3, 0)\n", + "# valor_esperado = 1\n", + " \n", + "def Exponente(numero, exponente):\n", + " '''\n", + " Esta función devuelve el resultado de elevar el parámetro \"numero\" al parámetro \"exponente\"\n", + " Recibe dos argumentos:\n", + " numero: El número base en la operación exponencial\n", + " exponente: El número exponente en la operación exponencial\n", + " Ej:\n", + " Exponente(10,3) debe retornar 1000\n", + " '''\n", + " #Tu código aca:\n", + " res=numero**exponente\n", + " return res\n", + "Exponente(10,3)\n", + "\n", + "# Test OK!" + ] + }, + { + "cell_type": "code", + "execution_count": 15, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "[1, 2, 3]" + ] + }, + "execution_count": 15, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "#\n", + "def ListaDeListas(lista):\n", + " '''\n", + " Esta función recibe una lista, que puede contener elementos que a su vez sean listas y\n", + " devuelve esos elementos por separado en una lista única. \n", + " En caso de que el parámetro no sea de tipo lista, debe retornar nulo.\n", + " Recibe un argumento:\n", + " lista: La lista que puede contener otras listas y se convierte a una \n", + " lista de elementos únicos o no iterables.\n", + " Ej:\n", + " ListaDeListas([1,2,['a','b'],[10]]) debe retornar [1,2,'a','b',10]\n", + " ListaDeListas(108) debe retornar el valor nulo.\n", + " ListaDeListas([[1,2,[3]],[4]]) debe retornar [1,2,3,4]\n", + " '''\n", + " #Tu código aca:\n", + " if type(lista) != list:\n", + " return None\n", + " else:\n", + " lista_final=[]\n", + " for elem in lista:\n", + " if isinstance(elem, list):\n", + " lista_final.extend(ListaDeListas(elem))\n", + " else:\n", + " lista_final.append(elem)\n", + " return lista_final\n", + "ListaDeListas ([[[1]],2,[[[[3]]]]])\n", + "# ListaDeListas(100)\n", + "# lista_esperada = None\n", + "# # ListaDeListas([1,[2,3],[[4,5],6],[[7]]])\n", + "# lista_esperada = [1,2,3,4,5,6,7]\n", + "# # ListaDeListas(['a','b',1,2,['a1','b3'],[['a'],2]])\n", + "# lista_esperada = ['a','b',1,2,'a1','b3','a',2]\n", + "# # ListaDeListas([[[1]],2,[[[[3]]]]])\n", + "# lista_esperada = [1,2,3] \n", + "# Test OK!" + ] + }, + { + "cell_type": "code", + "execution_count": 22, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "362880" + ] + }, + "execution_count": 22, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "def Factorial(numero):\n", + " '''\n", + " Esta función devuelve el factorial del número pasado como parámetro.\n", + " En caso de que no sea de tipo entero y/o sea menor que 0, debe retornar nulo.\n", + " Recibe un argumento:\n", + " numero: Será el número con el que se calcule el factorial\n", + " Ej:\n", + " Factorial(4) debe retornar 24\n", + " Factorial(-2) debe retornar nulo\n", + " Factorial(0) debe retornar 1\n", + " '''\n", + " #Tu código aca:\n", + " if (numero <1):\n", + " return None\n", + " if numero==0 or numero==1:\n", + " resultado=1\n", + " elif numero>1:\n", + " resultado=numero*Factorial(numero-1)\n", + " return resultado\n", + "\n", + "Factorial(9)\n", + "# Test 1 Factorial(5) OK\n", + "# valor_esperado = 120\n", + "# Test 2 Factorial(1) OK\n", + "# valor_esperado = 1 \n", + "# Test 3 Factorial(0) OK\n", + "# valor_esperado = 1\n", + "# Test 4 Factorial(9) OK\n", + "# valor_esperado = 362880" + ] + }, + { + "cell_type": "code", + "execution_count": 29, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "[67, 71, 73]" + ] + }, + "execution_count": 29, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "def ListaPrimos(desde, hasta):\n", + " '''\n", + " Esta función devuelve una lista con los números primos entre los valores \"desde\" y \"hasta\"\n", + " pasados como parámetro, siendo ambos inclusivos.\n", + " En caso de que alguno de los parámetros no sea de tipo entero y/o no sea mayor a cero, debe retornar nulo.\n", + " En caso de que el segundo parámetro sea menor al primero, pero ambos mayores que cero,\n", + " debe retornar una lista vacía.\n", + " Recibe un argumento:\n", + " desde: Será el número a partir del cual se toma el rango\n", + " hasta: Será el número hasta el cual se tome el rango\n", + " Ej:\n", + " ListaPrimos(7,15) debe retornar [7,11,13]\n", + " ListaPrimos(100,99) debe retornar []\n", + " ListaPrimos(1,7) debe retonan [1,2,3,5,7]\n", + " '''\n", + " #Tu código aca:\n", + " lp=[]\n", + " # Ciclos 'if' Validar las variables de entrada\n", + " if (type(desde) != int or type(hasta) != int):\n", + " return None\n", + " if (desde < 0 or hasta < 0):\n", + " return None\n", + " if (desde > hasta):\n", + " return lp \n", + " def calculaPrimo(num):\n", + " if num==2:\n", + " return True\n", + " for n in range (2,num):\n", + " if(num%n!=0):\n", + " continue\n", + " else:\n", + " return False\n", + " return True\n", + " for i in range(desde,(hasta+1)):\n", + " if calculaPrimo(i):\n", + " lp.append(i)\n", + " return lp\n", + "\n", + "ListaPrimos(66,77)\n", + "# Test_01 ListaPrimos(1,11)\n", + "# Lista_esperada = [1,2,3,5,7,11] OK!\n", + "# Test_02 ListaPrimos('0',0)\n", + "# Lista_esperada = None OK!\n", + "# Test_03 ListaPrimos(66,77)\n", + "# Lista_esperada = [67, 71, 73] OK!\n", + "# Test__04 ListaPrimos(0,'66')\n", + "# Lista_esperada = None\n" + ] + } + ], + "metadata": { + "kernelspec": { + "display_name": "Python 3", + "language": "python", + "name": "python3" + }, + "language_info": { + "codemirror_mode": { + "name": "ipython", + "version": 3 + }, + "file_extension": ".py", + "mimetype": "text/x-python", + "name": "python", + "nbconvert_exporter": "python", + "pygments_lexer": "ipython3", + "version": "3.10.6" + }, + "orig_nbformat": 4, + "vscode": { + "interpreter": { + "hash": "d3777ed8f5fe800f0d3d1926318eb186c93d9a88e13881725c87e5bdd2f1dd1d" + } + } + }, + "nbformat": 4, + "nbformat_minor": 2 +} diff --git a/Workbench/Taller/pruebaerror.ipynb b/Workbench/Taller/pruebaerror.ipynb index 3c875a91e..635127dd4 100644 --- a/Workbench/Taller/pruebaerror.ipynb +++ b/Workbench/Taller/pruebaerror.ipynb @@ -76,6 +76,66 @@ "a1.Doblar(100)" ] }, + { + "cell_type": "code", + "execution_count": 10, + "metadata": {}, + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "[3, 6, 9]\n" + ] + } + ], + "source": [ + "# LISTA DIVISIBLES\n", + "\n", + "# ListaDivisibles(12, 10)\n", + "# lista_esperada = []\n", + "\n", + "# ListaDivisibles(12, 100)\n", + "# lista_esperada = [12,24,36,48,60,72,84,96]\n", + "\n", + "# ListaDivisibles(3, 9)\n", + "# lista_esperada = [3,6,9]\n", + "\n", + "def ListaDivisibles(numero, tope):\n", + " '''\n", + " Esta función devuelve una lista ordenada de menor a mayor con los números divisibles \n", + " por el parámetro número entre uno (1) y el valor del parámetro \"tope\"\n", + " Recibe dos argumentos:\n", + " numero: Numero entero divisor\n", + " tope: Máximo valor a evaluar a partir de uno (1)\n", + " Ej:\n", + " ListaDivisibles(6,30) debe retornar [6,12,18,24,30]\n", + " ListaDivisibles(10,5) debe retornar []\n", + " ListaDivisibles(7,50) debe retornar [7,14,21,28,35,42,49]\n", + " '''\n", + " #Tu código aca:\n", + " lint = list(range(numero,tope+1))\n", + " ldiv = []\n", + " \n", + " if numero > tope:\n", + " print(ldiv)\n", + " return ldiv\n", + " if numero <= 0:\n", + " print(str(numero) + ', que corresponde a ser el divisor, NO puede ser = 0.')\n", + " return None\n", + " for i in lint:\n", + " if (i % numero) == 0:\n", + " ldiv.append(i)\n", + " ldiv.sort(reverse=False)\n", + " print(ldiv) \n", + " return ldiv\n", + " \n", + "lista_divisible=ListaDivisibles(3, 9)\n", + " # 12, 10 []\n", + " # 12. 100 [12,24,36,48,60,72,84,96]\n", + " # 3, 9 [3,6,9]" + ] + }, { "cell_type": "code", "execution_count": 8, @@ -850,31 +910,17 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 4, "metadata": {}, - "outputs": [], - "source": [ - "valor=777\n", - "print (valor)\n", - "print ()\n", - "cadena=str(valor)\n", - "indice=-1\n", - "iguales=0\n", - "for x in range(0,len(cadena)/2):\n", - " if cadena[x]==cadena[indice]:\n", - " iguales=iguales+1\n", - " indice=indice-1\n", - "if iguales==(len(cadena)/2):\n", - " print ('Es capicua')\n", - "else:\n", - " print ('No es capicua')" - ] - }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], + "outputs": [ + { + "name": "stdout", + "output_type": "stream", + "text": [ + "True\n" + ] + } + ], "source": [ "'''\n", " En matemáticas, la palabra capicúa (del catalán cap i cua, 'cabeza y cola')​ \n", @@ -975,43 +1021,15 @@ }, { "cell_type": "code", - "execution_count": 414, - "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "2\n" - ] - } - ], - "source": [ - "print (27%5)" - ] - }, - { - "cell_type": "code", - "execution_count": 406, + "execution_count": 415, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "1\n", - "3\n", - "17\n", - "51\n" - ] - } - ], + "outputs": [], "source": [ "#def divisores ():\n", - "num = int (input ('Escribe un entero'))\n", + "num = 10 #int (input ('Escribe un entero'))\n", "listaFC = []\n", - "i=1\n", - "while i<=num:\n", + "i=2\n", + "while num/c) !=1:\n", " if num%i==0:\n", " listaFC.append(num//i)\n", " listaFC.sort()\n", @@ -1090,17 +1108,9 @@ }, { "cell_type": "code", - "execution_count": 335, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "['c', 'a', 'b']\n" - ] - } - ], + "outputs": [], "source": [ "from operator import itemgetter\n", "def OrdenarDiccionario(diccionario_par, clave, descendente=True):\n", @@ -1150,17 +1160,9 @@ }, { "cell_type": "code", - "execution_count": 275, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "{'clave1': ['c', 'a', 'b'], 'clave2': ['casa', 'auto', 'barco'], 'clave3': [1, 2, 3]}\n" - ] - } - ], + "outputs": [], "source": [ "dicc = {\n", " 'clave1':['c','a','b'],\n", @@ -1178,17 +1180,9 @@ }, { "cell_type": "code", - "execution_count": 325, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "{'clave1': ['c', 'a', 'b'], 'clave2': ['casa', 'auto', 'barco'], 'clave3': [1, 2, 3]}\n" - ] - } - ], + "outputs": [], "source": [ "key_list = ['clave1', 'clave2', 'clave3']\n", "value_list1 = [['c', 'a', 'b'], ['casa', 'auto', 'barco'], [1, 2, 3]]\n", @@ -1203,18 +1197,19 @@ }, { "cell_type": "code", - "execution_count": 330, + "execution_count": 6, "metadata": {}, "outputs": [ { "name": "stdout", "output_type": "stream", "text": [ - "{'nombre': 'Juan', 'edad': '27', 'ciudad': 'Nueva York'}\n" + "{'clave1': 'Juan', 'clave2': '27', 'clave3': 'Nueva York'}\n" ] } ], "source": [ + "# Une dos listas en un dict\n", "key_list = ['clave1', 'clave2', 'clave3']\n", "value_list = ['Juan', '27', 'Nueva York']\n", "\n", @@ -1222,18 +1217,6 @@ "print(dict_from_list)" ] }, - { - "cell_type": "code", - "execution_count": null, - "metadata": {}, - "outputs": [], - "source": [ - "def sum (a,b):\n", - " return 'Null'\n", - " \n", - "sum (2,3)" - ] - }, { "cell_type": "code", "execution_count": null, @@ -1283,18 +1266,9 @@ }, { "cell_type": "code", - "execution_count": 324, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "Ord1= [('Gris', '1892-B', 'M'), ('Azul', '2901-Z', 'M'), ('Rojo', '4859-A', 'A')]\n", - "Ord2= [{'color': 'Gris', 'matricula': '1892-B', 'cambio': 'M'}, {'color': 'Azul', 'matricula': '2901-Z', 'cambio': 'M'}, {'color': 'Rojo', 'matricula': '4859-A', 'cambio': 'A'}]\n" - ] - } - ], + "outputs": [], "source": [ "# Ordenar una lista de coches almacenados como tuplas\n", "tuplas_coches = [\n", @@ -1323,7 +1297,7 @@ }, { "cell_type": "code", - "execution_count": 281, + "execution_count": 11, "metadata": {}, "outputs": [ { @@ -1335,10 +1309,10 @@ } ], "source": [ - "dicc={'midic':('a',b'')}\n", - "if type(diccionario_pa) != dict:\n", - " if type(get)\n", - " return None\n", + "dicc={'midic':('a','b')}\n", + "if type(dicc) != dict:\n", + " if type(getattr(dicc)!= False):\n", + " pass #return None\n", "dicc2={'clave1':['b','a','c'], 'clave2':['barco','auto','casa'],'clave3':[3,2,1]}\n", "print ('este es el dicc ordenado por la clave X', dicc2)" ] @@ -1349,34 +1323,22 @@ "metadata": {}, "outputs": [], "source": [ + "dicc ={\n", + "'clave1':['c', 'a', 'b'],\n", + "'clave2':['casa', 'auto', 'barco'],\n", + "'clave3':[3,2,1]}\n", + "\n", "juegos = [\n", - " {\n", - " \"nombre\": \"Resident Evil 2\",\n", - " \"calificacion\": 99,\n", - " },\n", - " {\n", - " \"nombre\": \"Crash Bandicoot N. Sane Trilogy\",\n", - " \"calificacion\": 76,\n", - " },\n", - "\n", - " {\n", - " \"nombre\": \"Cuphead\",\n", - " \"calificacion\": 100,\n", - " },\n", - " {\n", - " \"nombre\": \"Minecraft\",\n", - " \"calificacion\": 80,\n", - " },\n", - " {\n", - " \"nombre\": \"Bioshock\",\n", - " \"calificacion\": 95,\n", - " },\n", - "]\n", + "{\"nombre\": \"Resident Evil 2\", \"calificacion\": 99,},\n", + "{\"nombre\": \"Crash Bandicoot\", \"calificacion\": 76,},\n", + "{\"nombre\": \"Cuphead\", \"calificacion\": 100,},\n", + "{\"nombre\": \"Minecraft\", \"calificacion\": 80,},\n", + "{\"nombre\": \"Bioshock\", \"calificacion\": 95,},]\n", + "\n", "def funcion_que_devuelve_clave(juego):\n", " # Vamos a ordenar basándonos en su calificación, y como se nos\n", " # va a pasar un diccionario, devolvemos el elemento \"calificacion\"\n", - " return juego[\"calificacion\"]\n", - "\n", + " return juego[\"nombre\"]\n", "# La ordenamos\n", "juegos_ordenados = sorted(juegos, key=funcion_que_devuelve_clave)\n", "print(\"Ordenada por calificación ascendente: \")\n", @@ -1385,25 +1347,15 @@ "# También se puede en orden inverso\n", "juegos_ordenados = sorted(juegos, key=funcion_que_devuelve_clave, reverse=True)\n", "print(\"Ordenada por calificación descendente: \")\n", - "\n", "for juego in juegos_ordenados:\n", " print(juego)" ] }, { "cell_type": "code", - "execution_count": 250, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "nuemero e claves 6\n", - "{'clave1': 1.97, 'clave2': 8.49, 'clave3': 9.79, 'clave4': 1.2, 'clave5': 0.43, 'clave6': ['a', 'b', 'c']}\n" - ] - } - ], + "outputs": [], "source": [ "clients = {'clave1': 1.97,\n", " 'clave2': 8.49,\n", @@ -1423,26 +1375,16 @@ "# print (idx[0], 'ha gastado', clients[idx[1]]) # \"algo\" para recorrer clients\n", "#clients_sort=sorted(clients)\n", "orden = len (clients.keys())\n", - "print ('nuemero e claves', orden)\n", - "print (clients) #\n", - " \n", + "print ('Número de claves', orden)\n", + "print (clients) \n", " \n" ] }, { "cell_type": "code", - "execution_count": 232, + "execution_count": null, "metadata": {}, - "outputs": [ - { - "name": "stdout", - "output_type": "stream", - "text": [ - "{'clave1': 1.97, 'clave2': 8.49, 'clave3': 9.79, 'clave4': 8.53, 'clave5': 0.43}\n", - "{'clave1': 1.97, 'clave2': 8.49, 'clave3': 9.79, 'clave4': 8.53, 'clave5': 0.43, 'clave6': ['a', 'b', 'c']}\n" - ] - } - ], + "outputs": [], "source": [ "clients = {'clave1': 1.97,\n", " 'clave2': 8.49,\n", @@ -1453,6 +1395,21 @@ "clients ['clave6']= ['a','b','c']\n", "print (clients)\n" ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "lisdic=[]\n", + "for i in range (3):\n", + " for j in range (3):\n", + " for k in range (3):\n", + " lisdic=print(i,j,k)\n", + "\n", + "print (lisdic, end=\", \")" + ] } ], "metadata": { From 95a65e6bafc5cbb921dccc53b557228523dd9fac Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sat, 28 Jan 2023 14:58:15 -0300 Subject: [PATCH 13/16] Up 1457 --- Workbench/Taller/HC280123.ipynb | 66 ++++++++++++++++++++++++++++++--- 1 file changed, 60 insertions(+), 6 deletions(-) diff --git a/Workbench/Taller/HC280123.ipynb b/Workbench/Taller/HC280123.ipynb index 552712320..eb07e7368 100644 --- a/Workbench/Taller/HC280123.ipynb +++ b/Workbench/Taller/HC280123.ipynb @@ -105,7 +105,7 @@ }, { "cell_type": "code", - "execution_count": 15, + "execution_count": 30, "metadata": {}, "outputs": [ { @@ -114,7 +114,7 @@ "[1, 2, 3]" ] }, - "execution_count": 15, + "execution_count": 30, "metadata": {}, "output_type": "execute_result" } @@ -138,13 +138,13 @@ " if type(lista) != list:\n", " return None\n", " else:\n", - " lista_final=[]\n", + " guardaLdeL=[]\n", " for elem in lista:\n", " if isinstance(elem, list):\n", - " lista_final.extend(ListaDeListas(elem))\n", + " guardaLdeL.extend(ListaDeListas(elem))\n", " else:\n", - " lista_final.append(elem)\n", - " return lista_final\n", + " guardaLdeL.append(elem)\n", + " return guardaLdeL\n", "ListaDeListas ([[[1]],2,[[[[3]]]]])\n", "# ListaDeListas(100)\n", "# lista_esperada = None\n", @@ -270,6 +270,60 @@ "# Test__04 ListaPrimos(0,'66')\n", "# Lista_esperada = None\n" ] + }, + { + "cell_type": "code", + "execution_count": 38, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "[('hola', 2), ('mundo', 1)]" + ] + }, + "execution_count": 38, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "def ListaRepetidos(lista):\n", + " '''\n", + " Esta función recibe como parámetro una lista y devuelve una lista de tuplas donde cada \n", + " tupla contiene un valor de la lista original y las veces que se repite. Los valores \n", + " de la lista original no deben estar repetidos. \n", + " Debe respetarse el orden original en el que aparecen los elementos.\n", + " En caso de que el parámetro no sea de tipo lista debe retornar nulo.\n", + " Recibe un argumento:\n", + " lista: Será la lista que se va a evaluar.\n", + " Ej:\n", + " ListaRepetidos([]) debe retornar []\n", + " ListaRepetidos(['hola', 'mundo', 'hola', 13, 14]) \n", + " debe retornar [('hola',2),('mundo',1),(13,1),(14,1)]\n", + " ListaRepetidos([1,2,2,4]) debe retornar [(1,1),(2,1),(4,1)]\n", + " '''\n", + " #Tu código aca:\n", + " swap=[]\n", + " if type(lista) != list:\n", + " return None\n", + " while len(lista)>0:\n", + " eleTup=lista[0]\n", + " contador=lista.count(lista[0])\n", + " swap.append((eleTup,contador))\n", + " for i in range(lista.count(lista[0])):\n", + " lista.remove(eleTup)\n", + " continue\n", + " return swap\n", + "\n", + "ListaRepetidos(['hola', 'mundo', 'hola'])\n", + "# Test_01 ListaRepetidos (['hola', 'mundo', 'hola'])\n", + "# Lista_esperada = [('hola',2),('mundo',1)]\n", + "# Test_02 ListaRepetidos ([10,11,11,12,15,17,20,20])\n", + "# Lista_esperada = [(10,1),(11,2),(12,1),(15,1),(17,1),(20,2)]\n", + "# Test_03 ListaRepetidos ((1,2,3,3))\n", + "# Lista_esperada = None" + ] } ], "metadata": { From a6213bb9a11985901a9086410ccdc11c84b66fd5 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sat, 28 Jan 2023 19:23:20 -0300 Subject: [PATCH 14/16] Up Hasta Ej ClassAuto, 24 pts acumulados, resta 1 --- Workbench/Taller/FuncionFactorial.py | 6 +- Workbench/Taller/HC280123.ipynb | 223 +++++++++++++++++++++++++-- 2 files changed, 212 insertions(+), 17 deletions(-) diff --git a/Workbench/Taller/FuncionFactorial.py b/Workbench/Taller/FuncionFactorial.py index c004bb55e..33750e301 100644 --- a/Workbench/Taller/FuncionFactorial.py +++ b/Workbench/Taller/FuncionFactorial.py @@ -12,11 +12,11 @@ def factorial(n): if (n <1): return None - if n==0 or n==1: + elif n==0 or n==1: resultado=1 - elif n>1: + if n>1: resultado=n*factorial(n-1) return resultado -fact=factorial(5) +fact=factorial(0) print (fact) \ No newline at end of file diff --git a/Workbench/Taller/HC280123.ipynb b/Workbench/Taller/HC280123.ipynb index eb07e7368..ef10b0d74 100644 --- a/Workbench/Taller/HC280123.ipynb +++ b/Workbench/Taller/HC280123.ipynb @@ -159,16 +159,16 @@ }, { "cell_type": "code", - "execution_count": 22, + "execution_count": 56, "metadata": {}, "outputs": [ { "data": { "text/plain": [ - "362880" + "1" ] }, - "execution_count": 22, + "execution_count": 56, "metadata": {}, "output_type": "execute_result" } @@ -186,15 +186,17 @@ " Factorial(0) debe retornar 1\n", " '''\n", " #Tu código aca:\n", - " if (numero <1):\n", + " if (type(numero) != int):\n", " return None\n", - " if numero==0 or numero==1:\n", - " resultado=1\n", - " elif numero>1:\n", - " resultado=numero*Factorial(numero-1)\n", - " return resultado\n", + " if (numero < 0):\n", + " return None\n", + " factorial = 1\n", + " for n in range(1, (numero)+1):\n", + " factorial = factorial * n\n", + " return factorial\n", + " \n", + "Factorial(1)\n", "\n", - "Factorial(9)\n", "# Test 1 Factorial(5) OK\n", "# valor_esperado = 120\n", "# Test 2 Factorial(1) OK\n", @@ -205,6 +207,36 @@ "# valor_esperado = 362880" ] }, + { + "cell_type": "code", + "execution_count": 60, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "120" + ] + }, + "execution_count": 60, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "def Factorial(numero):\n", + " if (type(numero) != int):\n", + " return None\n", + " if (numero < 0):\n", + " return None\n", + " f = 1\n", + " for n in range(1, (numero)+1):\n", + " f = f * n\n", + " return f\n", + "\n", + "Factorial(5)" + ] + }, { "cell_type": "code", "execution_count": 29, @@ -273,16 +305,16 @@ }, { "cell_type": "code", - "execution_count": 38, + "execution_count": 40, "metadata": {}, "outputs": [ { "data": { "text/plain": [ - "[('hola', 2), ('mundo', 1)]" + "[(1, 1), (2, 2), (4, 1)]" ] }, - "execution_count": 38, + "execution_count": 40, "metadata": {}, "output_type": "execute_result" } @@ -316,7 +348,7 @@ " continue\n", " return swap\n", "\n", - "ListaRepetidos(['hola', 'mundo', 'hola'])\n", + "ListaRepetidos([1,2,2,4])\n", "# Test_01 ListaRepetidos (['hola', 'mundo', 'hola'])\n", "# Lista_esperada = [('hola',2),('mundo',1)]\n", "# Test_02 ListaRepetidos ([10,11,11,12,15,17,20,20])\n", @@ -324,6 +356,169 @@ "# Test_03 ListaRepetidos ((1,2,3,3))\n", "# Lista_esperada = None" ] + }, + { + "cell_type": "code", + "execution_count": 71, + "metadata": {}, + "outputs": [ + { + "data": { + "text/plain": [ + "15" + ] + }, + "execution_count": 71, + "metadata": {}, + "output_type": "execute_result" + } + ], + "source": [ + "def ClaseVehiculo(tipo, color):\n", + " '''\n", + " Esta función devuelve un objeto instanciado de la clase Vehiculo, \n", + " la cual debe tener los siguientes atributos:\n", + " Tipo: Un valor dentro de los valores posibles: ['auto','camioneta','moto']\n", + " Color: Un valor de tipo de dato string.\n", + " Velocidad: Un valor de tipo de dato float, que debe inicializarse en cero.\n", + " y debe tener el siguiente método:\n", + " Acelerar(): Este método recibe un parámetro con el valor que debe incrementar a la\n", + " propiedad Velocidad y luego retornarla.\n", + " Si la propiedad Velocidad cobra un valor menor a cero, debe quedar en cero.\n", + " Si la propiedad Velocidad cobra un valor mayor a cien, debe quedar en cien.\n", + " Recibe dos argumento:\n", + " tipo: Dato que se asignará al atributo Tipo del objeto de la clase Vehiculo\n", + " color: Dato que se asignará al atributo Color del objeto de la clase Vehiculo\n", + " Ej:\n", + " a = ClaseVehículo('auto','gris')\n", + " a.Acelerar(10) -> debe devolver 10\n", + " a.Acelerar(15) -> debe devolver 25\n", + " a.Acelerar(-10) -> debe devolver 15\n", + " '''\n", + " #Tu código aca:\n", + " class Vehiculo:\n", + " def __init__(self, tipo, color):\n", + " if (tipo=='auto' or tipo =='camioneta' or tipo=='moto'):\n", + " self.Tipo = tipo\n", + " else:\n", + " raise TypeError ('el tipo de vehículo tiene que ser auto, camioneta o moto')\n", + " self.Color = color\n", + " self.Velocidad = 0\n", + "\n", + " def Acelerar(self, acel):\n", + " self.Velocidad += acel\n", + " if self.Velocidad < 0:\n", + " self.Velocidad=0\n", + " if self.Velocidad>100:\n", + " self.Velocidad=100\n", + " return self.Velocidad\n", + " \n", + " a = Vehiculo(tipo, color) \n", + " return a\n", + "\n", + "# Test_01 ClaseVehiculo('auto','verde')\n", + "# valor_test = a.Acelerar(10)\n", + "# valor_test = a.Acelerar(100)\n", + "# valor_test = a.Acelerar(-20)\n", + "# valor_esperado = 80\n", + "# self.assertEqual(valor_test, valor_esperado)\n", + "# Test_02 ClaseVehiculo('camioneta','azul')\n", + "# valor_test = a.Acelerar(20)\n", + "# valor_test = a.Acelerar(-30)\n", + "# valor_esperado = 0\n", + "# Test_03 ClaseVehiculo('moto','negra')\n", + "# valor_test = a.Acelerar(10)\n", + "# valor_test = a.Acelerar(100)\n", + "# valor_esperado = 100\n", + "\n", + "a= ClaseVehiculo ('auto','verde')\n", + "\n", + "a.Acelerar(10) #debe devolver 10\n", + "a.Acelerar(15) #debe devolver 25\n", + "a.Acelerar(-10) " + ] + }, + { + "cell_type": "code", + "execution_count": null, + "metadata": {}, + "outputs": [], + "source": [ + "dicc = {\n", + " 'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]\n", + " }\n", + "def OrdenarDiccionario(diccionario_par, clave, descendente=True):\n", + " '''\n", + " Esta función recibe como parámetro un diccionario, cuyas listas de valores tienen el mismo\n", + " tamaño y sus elementos enésimos están asociados. Y otros dos parámetros que indican\n", + " la clave por la cual debe ordenarse y si es descendente o ascendente.\n", + " La función debe devolver el diccionario ordenado, teniendo en cuenta de no perder la\n", + " relación entre los elementos enésimos.\n", + " Recibe tres argumentos:\n", + " diccionario: Diccionario a ordenar.\n", + " clave: Clave del diccionario recibido, por la cual ordenar.\n", + " descendente: Un valor booleano, que al ser verdadero indica ordenamiento ascendente y \n", + " descendente si es falso. \n", + " Debe tratarse de un parámetro por defecto en True.\n", + " Si el parámetro diccionario no es un tipo de dato diccionario ó el parámetro clave no \n", + " se encuentra dentro de las claves del diccionario, debe devolver nulo.\n", + " Ej:\n", + " dicc = {'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]}\n", + " OrdenarDiccionario(dicc, 'clave1') debe retornar {'clave1':['a','b','c'],\n", + " 'clave2':['auto','barco','casa'],\n", + " 'clave3':[2,3,1]}\n", + " OrdenarDiccionario(dicc, 'clave3', False) debe retornar {'clave1':['b','a','c'],\n", + " 'clave2':['barco','auto','casa'],\n", + " 'clave3':[3,2,1]}\n", + " '''\n", + " #Tu código aca:\n", + " # Variables a usar, incluye nuevas listas auxiliares para hacer los arreglos de swap, sin perder la hilación.\n", + " cantidadValores=0 # Recibe valores del diccionario en el proceso de pasarlo a Lista de diccs\n", + " numKeys=0 # Recibe n elementos del tipo llave que tiene el diccionario DICC, para ejecutar los ciclos. \n", + " newArr=[] \t\t # Va a recibir mi lista de diccionarios originales convertidos a listas\n", + " newArrSorted=[] # Va a recibir los diccionarios ordenados por la clave ingresada\n", + " res =[]\n", + " if not (type(diccionario_par) is dict): # diccionario_par= Parámetro que recibe un DICT\n", + "\t return 'Null' # Si el parámetro, no es de tipo diccionario, retorna 'null'\n", + " if not (clave in diccionario_par.keys()): # Si la clave recibiba como parámetro no existe, retorna null\n", + "\t return 'Null' # descendente=True ==> Orden ASCENDENTE, es al revés, FALSE==> DESCENDENTE \n", + " \n", + " # Este es un problema de Un diccionario de listas que debe ser transformado en una lista de diccionarios para poder\n", + " # ser maniplado con los métodos de 'list'. Al final, se debe convertir a DICT nuevamente.\n", + " # Convertimos el dicc de list a list de dict\n", + "\n", + " #print (len(diccionario_par[list(diccionario_par.keys())[0]]))\n", + " # chequeamos qué valor estamos reciendo\n", + " print()\n", + " if len(diccionario_par[list(diccionario_par.keys())[0]])>0: \n", + " cantidadValores=len(diccionario_par[list(diccionario_par.keys())[0]])\n", + " # convertimos el diccionario de listas, a una lista de diccionarios:\t\n", + " for i in range(0, cantidadValores):\n", + " newObj={}\n", + " for key in diccionario_par:\n", + " newObj[key]=diccionario_par[key][i]\n", + " newArr.append(newObj)\n", + " #print(newArr) Aquí se generó una lista de diccionarios\n", + " # Ahora ordenemos\n", + " newArrSorted = sorted(newArr, key=lambda d: d[clave], reverse=not (descendente))\n", + " print (newArrSorted) #verificar contenido del nuevo arreglo\n", + " # Convertimos la lista de diccionarios, en un diccionario de listas:\n", + " for key in diccionario_par:\n", + " newArr2 = []\n", + " for i in range(0, cantidadValores):\n", + " newArr2.append(newArrSorted[i][key])\n", + " res[key] = newArr2\n", + " #Si no tienen valores devolvemos el mismo diccionario:\n", + " else:\n", + " return diccionario_par\n", + " return res\n", + "\n", + "OrdenarDiccionario(dicc, 'clave1') " + ] } ], "metadata": { From daaf40958d86509fc8b1c85a8084ae8b3ba42d96 Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sat, 28 Jan 2023 21:46:18 -0300 Subject: [PATCH 15/16] Up2143, todos OK, 1 falla, error en test --- Workbench/Taller/HC280123.ipynb | 53 ++++++++++++++++---------- Workbench/Taller/OrdenarDiccionario.py | 34 +++++++++++++++++ 2 files changed, 67 insertions(+), 20 deletions(-) create mode 100644 Workbench/Taller/OrdenarDiccionario.py diff --git a/Workbench/Taller/HC280123.ipynb b/Workbench/Taller/HC280123.ipynb index ef10b0d74..13ff5fa94 100644 --- a/Workbench/Taller/HC280123.ipynb +++ b/Workbench/Taller/HC280123.ipynb @@ -440,15 +440,23 @@ }, { "cell_type": "code", - "execution_count": null, + "execution_count": 76, "metadata": {}, - "outputs": [], + "outputs": [ + { + "ename": "TypeError", + "evalue": "list indices must be integers or slices, not str", + "output_type": "error", + "traceback": [ + "\u001b[1;31m---------------------------------------------------------------------------\u001b[0m", + "\u001b[1;31mTypeError\u001b[0m Traceback (most recent call last)", + "Cell \u001b[1;32mIn[76], line 74\u001b[0m\n\u001b[0;32m 71\u001b[0m \u001b[39mreturn\u001b[39;00m diccionario_par\n\u001b[0;32m 72\u001b[0m \u001b[39mreturn\u001b[39;00m res\n\u001b[1;32m---> 74\u001b[0m OrdenarDiccionario(dicc, \u001b[39m'\u001b[39;49m\u001b[39mclave1\u001b[39;49m\u001b[39m'\u001b[39;49m) \n", + "Cell \u001b[1;32mIn[76], line 68\u001b[0m, in \u001b[0;36mOrdenarDiccionario\u001b[1;34m(diccionario_par, clave, descendente)\u001b[0m\n\u001b[0;32m 66\u001b[0m \u001b[39mfor\u001b[39;00m i \u001b[39min\u001b[39;00m \u001b[39mrange\u001b[39m(\u001b[39m0\u001b[39m, cantidadValores):\n\u001b[0;32m 67\u001b[0m newArr2\u001b[39m.\u001b[39mappend(newArrSorted[i][key])\n\u001b[1;32m---> 68\u001b[0m res[key] \u001b[39m=\u001b[39m newArr2\n\u001b[0;32m 69\u001b[0m \u001b[39m#Si no tienen valores devolvemos el mismo diccionario:\u001b[39;00m\n\u001b[0;32m 70\u001b[0m \u001b[39melse\u001b[39;00m:\n\u001b[0;32m 71\u001b[0m \u001b[39mreturn\u001b[39;00m diccionario_par\n", + "\u001b[1;31mTypeError\u001b[0m: list indices must be integers or slices, not str" + ] + } + ], "source": [ - "dicc = {\n", - " 'clave1':['c','a','b'],\n", - " 'clave2':['casa','auto','barco'],\n", - " 'clave3':[1,2,3]\n", - " }\n", "def OrdenarDiccionario(diccionario_par, clave, descendente=True):\n", " '''\n", " Esta función recibe como parámetro un diccionario, cuyas listas de valores tienen el mismo\n", @@ -493,7 +501,7 @@ "\n", " #print (len(diccionario_par[list(diccionario_par.keys())[0]]))\n", " # chequeamos qué valor estamos reciendo\n", - " print()\n", + " #print()\n", " if len(diccionario_par[list(diccionario_par.keys())[0]])>0: \n", " cantidadValores=len(diccionario_par[list(diccionario_par.keys())[0]])\n", " # convertimos el diccionario de listas, a una lista de diccionarios:\t\n", @@ -502,21 +510,26 @@ " for key in diccionario_par:\n", " newObj[key]=diccionario_par[key][i]\n", " newArr.append(newObj)\n", - " #print(newArr) Aquí se generó una lista de diccionarios\n", - " # Ahora ordenemos\n", - " newArrSorted = sorted(newArr, key=lambda d: d[clave], reverse=not (descendente))\n", - " print (newArrSorted) #verificar contenido del nuevo arreglo\n", - " # Convertimos la lista de diccionarios, en un diccionario de listas:\n", - " for key in diccionario_par:\n", - " newArr2 = []\n", - " for i in range(0, cantidadValores):\n", - " newArr2.append(newArrSorted[i][key])\n", - " res[key] = newArr2\n", + " #print(newArr) Aquí se generó una lista de diccionarios\n", + " # Ahora ordenemos\n", + " newArrSorted = sorted(newArr, key=lambda d: d[clave], reverse=not (descendente))\n", + " # print (newArrSorted) #verificar contenido del nuevo arreglo\n", + " # Convertimos la lista de diccionarios, en un diccionario de listas:\n", + " for key in diccionario_par:\n", + " newArr2 = []\n", + " for i in range(0, cantidadValores):\n", + " newArr2.append(newArrSorted[i][key])\n", + " res[key] = newArr2\n", " #Si no tienen valores devolvemos el mismo diccionario:\n", " else:\n", - " return diccionario_par\n", + " return diccionario_par\n", + " \n", " return res\n", - "\n", + "dicc = {\n", + " 'clave1':['c','a','b'],\n", + " 'clave2':['casa','auto','barco'],\n", + " 'clave3':[1,2,3]\n", + " }\n", "OrdenarDiccionario(dicc, 'clave1') " ] } diff --git a/Workbench/Taller/OrdenarDiccionario.py b/Workbench/Taller/OrdenarDiccionario.py new file mode 100644 index 000000000..12f5352d4 --- /dev/null +++ b/Workbench/Taller/OrdenarDiccionario.py @@ -0,0 +1,34 @@ +def OrdenarDiccionario(diccionario_par, clave, descendente=True): + cantidadValores=0 + newArr=[] + newArrSorted=[] + res ={} + if not (type(diccionario_par) is dict): + return None + if not (clave in diccionario_par.keys()): + return None + if len(diccionario_par[list(diccionario_par.keys())[0]])>0: + cantidadValores=len(diccionario_par[list(diccionario_par.keys())[0]]) + for i in range(0, cantidadValores): + newObj={} + for key in diccionario_par: + newObj[key]=diccionario_par[key][i] + newArr.append(newObj) + newArrSorted = sorted(newArr, key=lambda d: d[clave], reverse=not (descendente)) + for key in diccionario_par: + newArr2 = [] + for i in range(0, cantidadValores): + newArr2.append(newArrSorted[i][key]) + res[key] = newArr2 + else: + return diccionario_par + + return res + +dicc = { + 'clave1':['c','a','b'], + 'clave2':['casa','auto','barco'], + 'clave3':[1,2,3] + } + +print (OrdenarDiccionario(dicc,"clave1")) From a3ebd8ab0009e9bfd664716cc5be689d03afde6f Mon Sep 17 00:00:00 2001 From: Jorge Cordova <55065873+jcordovaj@users.noreply.github.com> Date: Sun, 29 Jan 2023 03:31:47 -0300 Subject: [PATCH 16/16] Up2901230327, PruebasDiccListas --- Workbench/Taller/HC280123.ipynb | 2 +- Workbench/Taller/pruebaerror.ipynb | 2 +- 2 files changed, 2 insertions(+), 2 deletions(-) diff --git a/Workbench/Taller/HC280123.ipynb b/Workbench/Taller/HC280123.ipynb index 13ff5fa94..2091cee27 100644 --- a/Workbench/Taller/HC280123.ipynb +++ b/Workbench/Taller/HC280123.ipynb @@ -550,7 +550,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.10.6" + "version": "3.10.6 (tags/v3.10.6:9c7b4bd, Aug 1 2022, 21:53:49) [MSC v.1932 64 bit (AMD64)]" }, "orig_nbformat": 4, "vscode": { diff --git a/Workbench/Taller/pruebaerror.ipynb b/Workbench/Taller/pruebaerror.ipynb index 635127dd4..11e97c9d6 100644 --- a/Workbench/Taller/pruebaerror.ipynb +++ b/Workbench/Taller/pruebaerror.ipynb @@ -1428,7 +1428,7 @@ "name": "python", "nbconvert_exporter": "python", "pygments_lexer": "ipython3", - "version": "3.10.6" + "version": "3.10.6 (tags/v3.10.6:9c7b4bd, Aug 1 2022, 21:53:49) [MSC v.1932 64 bit (AMD64)]" }, "orig_nbformat": 4, "vscode": {