diff --git a/.devcontainer/devcontainer.json b/.devcontainer/devcontainer.json
new file mode 100644
index 00000000..72c9a221
--- /dev/null
+++ b/.devcontainer/devcontainer.json
@@ -0,0 +1,42 @@
+
+// For format details, see https://aka.ms/devcontainer.json. For config options, see the
+// README at: https://github.com/devcontainers/templates/tree/main/src/python
+{
+	"name": "Python 3",
+	// Or use a Dockerfile or Docker Compose file. More info: https://containers.dev/guide/dockerfile
+	"image": "mcr.microsoft.com/devcontainers/python:0-3.10",
+	"features": {
+		"ghcr.io/devcontainers/features/node:1": {
+			"nodeGypDependencies": true,
+			"version": "16"
+		}
+	},
+	"customizations": {
+		"vscode": {
+			"settings": {
+				"editor.defaultFormatter": "esbenp.prettier-vscode",
+				"workbench.editorAssociations": {   
+					"*.md": "vscode.markdown.preview.editor"
+				}
+			},
+			"extensions": ["learn-pack.learnpack-vscode"]
+		}
+	},
+	"onCreateCommand": "pip3 install pytest==6.2.5 pytest-testdox mock && npm i @learnpack/learnpack@5.0.13 -g && learnpack plugins:install @learnpack/python@1.0.6"
+
+	// Features to add to the dev container. More info: https://containers.dev/features.
+	// "features": {},
+
+	// Use 'forwardPorts' to make a list of ports inside the container available locally.
+	// "forwardPorts": [],
+
+	// Use 'postCreateCommand' to run commands after the container is created.
+	// "postCreateCommand": "pip3 install --user -r requirements.txt",
+
+	// Configure tool-specific properties.
+	// "customizations": {},
+
+	// Uncomment to connect as root instead. More info: https://aka.ms/dev-containers-non-root.
+	// "remoteUser": "root"
+}
+
diff --git a/.github/workflows/learnpack-audit.yml b/.github/workflows/learnpack-audit.yml
index 70f416ee..95814c2a 100644
--- a/.github/workflows/learnpack-audit.yml
+++ b/.github/workflows/learnpack-audit.yml
@@ -5,9 +5,9 @@ name: Learnpack audit
 
 on:
   push:
-    branches: [ master ]
+    branches: [ main ]
   pull_request:
-    branches: [ master ]
+    branches: [ main ]
 
 jobs:
   build:
@@ -16,7 +16,7 @@ jobs:
 
     strategy:
       matrix:
-        node-version: [14.x]
+        node-version: [20.x]
         # See supported Node.js release schedule at https://nodejs.org/en/about/releases/
 
     steps:
@@ -25,5 +25,5 @@ jobs:
       uses: actions/setup-node@v2
       with:
         node-version: ${{ matrix.node-version }}
-    - run: npm install learnpack -g
+    - run: npm install @learnpack/learnpack@latest -g
     - run: learnpack audit
\ No newline at end of file
diff --git a/.gitignore b/.gitignore
index 8f255a69..00a65322 100644
--- a/.gitignore
+++ b/.gitignore
@@ -7,9 +7,14 @@
 !bc.json
 !learn.json
 !README.md
+!.vscode
 
 !/exercises
 !/exercises/*
+exercises/*/__pycache__/
+*.pyc
+
+.pytest_cache/
 
 !/.learn
 /.learn/**
diff --git a/.gitpod.Dockerfile b/.gitpod.Dockerfile
index cfa43f3c..3de43aa2 100644
--- a/.gitpod.Dockerfile
+++ b/.gitpod.Dockerfile
@@ -1,6 +1,28 @@
 FROM gitpod/workspace-full:latest
 
+SHELL ["/bin/bash", "-c"]
+
+RUN sudo apt-get update \
+    && sudo apt-get update \
+    && sudo apt-get clean \
+    && sudo rm -rf /var/cache/apt/* /var/lib/apt/lists/* /tmp/*
+
+# That Gitpod install pyenv for me? no, thanks
+WORKDIR /home/gitpod/
+RUN rm .pyenv -Rf
+RUN rm .gp_pyenv.d -Rf
+RUN curl https://pyenv.run | bash
+
+
+RUN pyenv update && pyenv install 3.10.7 && pyenv global 3.10.7
+RUN pip install pipenv
+
+# remove PIP_USER environment
 USER gitpod
+RUN if ! grep -q "export PIP_USER=no" "$HOME/.bashrc"; then printf '%s\n' "export PIP_USER=no" >> "$HOME/.bashrc"; fi
+RUN echo "" >> $HOME/.bashrc
+RUN echo "unset DATABASE_URL" >> $HOME/.bashrc
+RUN echo "export DATABASE_URL" >> $HOME/.bashrc
 
-RUN pip3 install pytest==4.4.2 pytest-testdox mock
-RUN npm i learnpack@0.1.19 -g && learnpack plugins:install learnpack-python@0.0.35
+RUN pip3 install pytest==6.2.5 pytest-testdox mock
+RUN npm i @learnpack/learnpack@2.1.56 -g && learnpack plugins:install @learnpack/python@1.0.3
diff --git a/.gitpod.yml b/.gitpod.yml
index b307e19a..1d3e46c5 100644
--- a/.gitpod.yml
+++ b/.gitpod.yml
@@ -7,7 +7,7 @@ ports:
 
 vscode:
   extensions:
-    - learnpack.learnpack-vscode
+    - learn-pack.learnpack-vscode
 
 github:
     prebuilds:
diff --git a/.learn/assets/ex15.2.png b/.learn/assets/ex15.2.png
new file mode 100644
index 00000000..469019c9
Binary files /dev/null and b/.learn/assets/ex15.2.png differ
diff --git a/.vscode/settings.json b/.vscode/settings.json
new file mode 100644
index 00000000..2f5ad94d
--- /dev/null
+++ b/.vscode/settings.json
@@ -0,0 +1,8 @@
+{
+    "files.autoSave": "afterDelay",
+    "files.autoSaveDelay": 700,
+    "editor.minimap.enabled": false,
+    "workbench.editorAssociations": {   
+        "*.md": "vscode.markdown.preview.editor"
+    }
+}
\ No newline at end of file
diff --git a/README.es.md b/README.es.md
index 74a10203..5957e943 100644
--- a/README.es.md
+++ b/README.es.md
@@ -1,85 +1,72 @@
-
-  
-    | - | - - Ejercicios de bucles y listas de Python en 4Geeks Academy- -  -  -  - | 
-
+
+# 🐍 Ejercicios de looping en listas y tuplas de Python
 
-Mi nombre Alejandro Sanchez [@alesanchezr](https://twitter.com/alesanchezr). ¡¡Estamos muy entusiasmados por tenerte aquí!! 🎉 😂
+ -Aprender a programar es dificil ¡necesitas coaching! Envíame un DM en twitter si tienes alguna pregunta.
+> Por [@alesanchezr](https://twitter.com/alesanchezr) y [otros colaboradores](https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/graphs/contributors) en [4Geeks Academy](https://4geeksacademy.co/)
 
-Esta es una selección completa de ejercicios con tests e interactivos en Python para cualquier persona interesada en aprender Python!
+
 
-
 
-Aprender a programar es dificil ¡necesitas coaching! Envíame un DM en twitter si tienes alguna pregunta.
+> Por [@alesanchezr](https://twitter.com/alesanchezr) y [otros colaboradores](https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/graphs/contributors) en [4Geeks Academy](https://4geeksacademy.co/)
 
-Esta es una selección completa de ejercicios con tests e interactivos en Python para cualquier persona interesada en aprender Python!
+
 
-
-  - Python para principiantes-
-  Itera listas y tuplas ← Tú estás aquí ahora-
- Practica  funciones-
- Domina Python (intermedio)-
+Las listas y los bucles son uno de los temas más desafiantes de comprender al aprender a programar. Aprenderás lo siguiente:
 
-Estos ejercicios son colaborativos, ¡te necesitamos!
-Si encuentras algún error o falta de ortografía, por favor contribuye y repórtalo.
++ Todas las formas posibles de realizar bucles en Python.
 
-
-   -
-
++ Iterar sobre listas, tuplas, diccionarios y otras estructuras de datos.
 
-Instalación en un clic:
+Estos ejercicios son colaborativos, ¡te necesitamos! Si encuentras algún error o falta de ortografía, por favor contribuye y repórtalo.
 
-## Comienza practicando ahora mismo en Gitpod:
+
 
-[](https://gitpod.io#https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises.git)
+## Instalación en un clic (recomendado)
 
+Puedes empezar estos ejercicios en pocos segundos haciendo clic en: [Abrir en Codespaces](https://codespaces.new/?repo=4GeeksAcademy/python-lists-loops-programming-exercises) (recomendado) o [Abrir en Gitpod](https://gitpod.io#https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises).
 
-## O instalálo localmente (si no quieres usar Gitpod)
+> Una vez ya tengas abierto VSCode los ejercicios de LearnPack deberían empezar automáticamente, si esto no sucede puedes intentar empezar los ejercicios escribiendo este comando en tu terminal: `$ learnpack start`
 
-### Instalación local:
+## Instalación local:
 
-1. Instala learnpack, el administrador de paquetes para tutoriales de aprendizaje y el complemento del compilador html para learnpack, asegúrate de tener también node.js 12+:
+1. Asegúrate de instalar [LearnPack](https://learnpack.co), node.js version 14+ y Python version 3+. Este es el comando para instalar LearnPack:
 
-```sh
-$ npm i learnpack -g
-$ learnpack plugins:install learnpack-python
+```bash
+$ npm i @learnpack/learnpack@2.1.20 -g && learnpack plugins:install @learnpack/python@1.0.0
 ```
 
-2. Descarga este ejercicio en particular usando learnpack y `cd` para entrar en la carpeta:
+2. Clona o descarga este repositorio en tu ambiente local.
 
-```
-$ learnpack download python-lists-loops-programming-exercises
+```bash
+$ git clone https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises.git
 $ cd python-lists-loops-programming-exercises
 ```
 
-**Nota:** Una vez que termine de descargar, encontrarás la carpeta "exercises" que contiene todos los ejercicios.
+> Nota: Una vez que termine de descargar, encontrarás la carpeta "exercises" que contiene todos los ejercicios.
 
-3. Comienza con los ejercicios ejecutando el siguiente en el mismo nivel que tu archivo learn.json:
+3. Comienza con los ejercicios ejecutando los siguientes comandos en el mismo nivel que tu archivo learn.json:
 
-```sh
-$ pip3 install pytest==4.4.2 pytest-testdox mock
+```bash
+$ pip3 install pytest==6.2.5 pytest-testdox mock
 $ learnpack start
 ```
+
+
+
 ## ¿Cómo están organizados los ejercicios?
 
 Cada ejercicio es un pequeño proyecto en Python que contiene los siguientes archivos:
 
-1. **app.py:** representa el archivo de entrada de python que será ejecutado en el computador.
+1. **app.py:** representa el archivo de entrada de Python que será ejecutado en el computador.
 2. **README.md:** contiene las instrucciones del ejercicio.
 3. **test.py:** no tienes que abrir este archivo. Contiene los scripts de pruebas del ejercicio.
 
-## Colaboradores:
+> Nota: Estos ejercicios tienen calificación automática. Los tests son muy rígidos y estrictos, mi recomendación es que no prestes demasiada atención a los tests y los uses solo como una sugerencia o podrías frustrarte.
+
+## Colaboradores
+ 
+Gracias a estas personas maravillosas ([emoji key](https://github.com/kentcdodds/all-contributors#emoji-key)):
+
+1. [Alejandro Sanchez (alesanchezr)](https://github.com/alesanchezr), contribución: (programador) 💻, (idea) 🤔, (build-tests) ⚠️, (pull-request-review) 👀, (build-tutorial) ✅, (documentación) 📖
 
-Nuestro agradecimiento para estas maravillosas personas ([emoji key](https://github.com/kentcdodds/all-contributors#emoji-key)):
+2. [Paolo (plucodev)](https://github.com/plucodev), contribución: (bug reports) 🐛, (programador), (traducción) 🌎
 
-1. [Alejandro Sanchez (alesanchezr)](https://github.com/alesanchezr), contribución: (coder) :computer: (idea) 🤔, (build-tests) :warning:, (pull-request-review) :eyes: (build-tutorial) :white_check_mark: (documentation) :book:
-2. [Paolo Lucano (plucodev)](https://github.com/plucodev), contribución: (bug reports) :bug:, (translation) :earth_americas:, (build-tests) :warning:
-3. [Marco Gómez (marcogonzalo)](https://github.com/marcogonzalo), contribución: (bug reports) :bug:, (traducción) :earth_africa:
+Este proyecto sigue la especificación [all-contributors](https://github.com/kentcdodds/all-contributors). ¡Todas las contribuciones son bienvenidas!
 
-Este proyecto sigue las especificaciones
-[all-contributors](https://github.com/kentcdodds/all-contributors). 
-¡Todas las contribuciones son bienvenidas!
+Este y otros ejercicios son usados para [aprender a programar](https://4geeksacademy.com/es/aprender-a-programar/aprender-a-programar-desde-cero) por parte de los alumnos de 4Geeks Academy [Coding Bootcamp](https://4geeksacademy.com/us/coding-bootcamp) realizado por [Alejandro Sánchez](https://twitter.com/alesanchezr) y muchos otros contribuyentes. Conoce más sobre nuestros [Cursos de Programación](https://4geeksacademy.com/es/curso-de-programacion-desde-cero?lang=es) para convertirte en [Full Stack Developer](https://4geeksacademy.com/es/coding-bootcamps/desarrollador-full-stack/?lang=es), o nuestro [Data Science Bootcamp](https://4geeksacademy.com/es/coding-bootcamps/curso-datascience-machine-learning).
diff --git a/README.md b/README.md
index b66539fb..84b66013 100644
--- a/README.md
+++ b/README.md
@@ -1,89 +1,87 @@
-
-#  🐍 Python Loops & Lists Tutorial Exercises
+
+# 🐍 Python lists and loops tutorial exercises
 
  -> By [@alesanchezr](https://twitter.com/alesanchezr) and [other contributors](https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/graphs/contributors) at [4Geeks Academy](https://4geeksacademy.co/)
+> By [@alesanchezr](https://twitter.com/alesanchezr) and [otros colaboradores](https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/graphs/contributors) at [4Geeks Academy](https://4geeksacademy.co/)
 
 
 
 [](https://breatheco.de)
 [](https://twitter.com/4geeksacademy)
 
+*Estas instrucciones [están disponibles en 🇪🇸 español](https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/blob/master/README.es.md) :es:*
+
+
+
+Lists and loops are one of the most challenging topics to grasp when learning how to code. You will learn:
 
-Looping is one of the most challenging topics to grasp when learning how to code, learn all the possible ways to loop in python, looping lists, touples, dictionaries and other data-structures. The entire tutorial is 👆 interactive, ✅ auto-graded and with. 📹 video tutorials.
++ All the possible ways to loop in Python.
 
-
 
-> By [@alesanchezr](https://twitter.com/alesanchezr) and [other contributors](https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/graphs/contributors) at [4Geeks Academy](https://4geeksacademy.co/)
+> By [@alesanchezr](https://twitter.com/alesanchezr) and [otros colaboradores](https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/graphs/contributors) at [4Geeks Academy](https://4geeksacademy.co/)
 
 
 
 [](https://breatheco.de)
 [](https://twitter.com/4geeksacademy)
 
+*Estas instrucciones [están disponibles en 🇪🇸 español](https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/blob/master/README.es.md) :es:*
+
+
+
+Lists and loops are one of the most challenging topics to grasp when learning how to code. You will learn:
 
-Looping is one of the most challenging topics to grasp when learning how to code, learn all the possible ways to loop in python, looping lists, touples, dictionaries and other data-structures. The entire tutorial is 👆 interactive, ✅ auto-graded and with. 📹 video tutorials.
++ All the possible ways to loop in Python.
 
-📚 Table of contents:
-
++ Looping lists, tuples, dictionaries and other data structures. 
 
-These exercises were built in collaboration, we need you! If you find any bugs or misspells plese contribute and report them.
+The entire tutorial is 👆 interactive, ✅ auto-graded, and has 📹 video tutorials.
+
+These exercises were built in collaboration, we need you! If you find any bugs or misspellings, please contribute and report them.
+
+
 
 
    
 
 
-One click installation:
+## One click installation (recommended):
 
-[](https://gitpod.io#https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises.git)
+You can open these exercises in just a few seconds by clicking: [Open in Codespaces](https://codespaces.new/?repo=4GeeksAcademy/python-lists-loops-programming-exercises) (recommended) or [Open in Gitpod](https://gitpod.io#https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises).
 
+> Once you have VSCode open, the LearnPack exercises should start automatically. If exercises don't run automatically you can try typing on your terminal: `$ learnpack start`
 
 ## Local Installation
 
-1. Install learnpack, the package manager for learning tutorials and the html compiler plugin for learnpack, make sure you also have node.js 12+:
+Clone the repository in your local environment and follow the steps below:
 
-```
-$ npm i learnpack -g
-$ learnpack plugins:install learnpack-python
+1. Make sure you have [LearnPack](https://learnpack.co) installed, node.js version 14+, and Python version 3+. This is the command to install LearnPack:
+
+```bash
+$ npm i @learnpack/learnpack@2.1.20 -g && learnpack plugins:install @learnpack/python@1.0.0
 ```
 
-2. Download this particular exercise using learnpack and `cd` into the folder:
+2. Clone or download this repository in your local environment.
 
-```
-$ learnpack download python-lists-loops-programming-exercises
+```bash
+$ git clone https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises.git
 $ cd python-lists-loops-programming-exercises
 ```
 
-Note: Once you finish downloading, you will find a "exercises" folder that contains all the exercises within.
+> Note: Once you finish downloading, you will find an "exercises" folder that contains all the exercises within.
 
-3. Start the tutorial/exercises by running the following command at the same level were your bc.json file is:
+3. Start the tutorial/exercises by running the following command at the same level where your learn.json file is:
 
-```sh
-$ $ pip3 install pytest==4.4.2 pytest-testdox mock
+```bash
+$ pip3 install pytest==6.2.5 pytest-testdox mock
 $ learnpack start
 ```
 
-Note: The exercises have automatic grading but its very rigid and string, my recomendation is to ignore the tests and use them only as a recomendation or you can get frustrated.
-```
+
 
 ## How are the exercises organized?
 
-Each exercise is a small python project containing the following files:
+Each exercise is a small Python project containing the following files:
 
-1. **app.py:** represents the entry python file that will be executed by the computer.
+1. **app.py:** represents the entry Python file that will be executed by the computer.
 2. **README.md:** contains exercise instructions.
 3. **test.py:** you don't have to open this file, it contains the testing script for the exercise.
 
+> Note: The exercises have automatic grading, but it's very rigid and strict, my recommendation is to not take the tests too serious and use them only as a suggestion, or you may get frustrated.
+
 ## Contributors
 
 Thanks goes to these wonderful people ([emoji key](https://github.com/kentcdodds/all-contributors#emoji-key)):
 
-1. [Alejandro Sanchez (alesanchezr)](https://github.com/alesanchezr), contribution: (coder) :computer: (idea) 🤔, (build-tests) :warning:, (pull-request-review) :eyes: (build-tutorial) :white_check_mark: (documentation) :book:
-2. [Paolo (plucodev)](https://github.com/plucodev), contribution: (bug reports) :bug:, contribution: (coder), (translation) :earth_americas:
+1. [Alejandro Sanchez (alesanchezr)](https://github.com/alesanchezr), contribution: (coder) 💻,  (idea) 🤔, (build-tests) ⚠️, (pull-request-review) 👀, (build-tutorial) ✅, (documentation) 📖
+
+2. [Paolo (plucodev)](https://github.com/plucodev), contribution: (bug reports) 🐛, (coder) 💻, (translation) 🌎
+
+This project follows the [all-contributors](https://github.com/kentcdodds/all-contributors) specification. Contributions of any kind are welcome!
 
-This project follows the
-[all-contributors](https://github.com/kentcdodds/all-contributors)
-specification. Contributions of any kind are welcome!
+This and many other exercises are built by students as part of the 4Geeks Academy [Coding Bootcamp](https://4geeksacademy.com/us/coding-bootcamp) by [Alejandro Sánchez](https://twitter.com/alesanchezr) and many other contributors. Find out more about our [Full Stack Developer Course](https://4geeksacademy.com/us/coding-bootcamps/part-time-full-stack-developer), and  [Data Science Bootcamp](https://4geeksacademy.com/us/coding-bootcamps/datascience-machine-learning).
diff --git a/exercises/00-welcome/README.es.md b/exercises/00-welcome/README.es.md
index b05817d1..a214fea8 100644
--- a/exercises/00-welcome/README.es.md
+++ b/exercises/00-welcome/README.es.md
@@ -1,8 +1,4 @@
-# Bienvenid@ a las Listas de Python!
-
----
-tutorial: "https://www.youtube.com/watch?v=xMg9d0KsYAk"
----
+# Welcome to Python Lists!
 
 En este curso aprenderás los siguientes conceptos:
 
@@ -20,7 +16,7 @@ En este curso aprenderás los siguientes conceptos:
 
 - Combinar dos listas.
 
-- Cómo combiar y usar todos estos conceptos de diferentes maneras.
+- Cómo combinar y usar todos estos conceptos de diferentes maneras.
 
 Por favor, presiona el botón de `Next →` de arriba a la derecha para ir al primer reto.
 
diff --git a/exercises/00-welcome/README.md b/exercises/00-welcome/README.md
index 95ef199f..53344902 100644
--- a/exercises/00-welcome/README.md
+++ b/exercises/00-welcome/README.md
@@ -4,11 +4,11 @@ tutorial: "https://www.youtube.com/watch?v=xMg9d0KsYAk"
 
 # Welcome to Python Lists!
 
-During this course you will be learning the following concepts:
+During this course, you will be learning the following concepts:
 
 - What is a list.
 
-- What is tuple.
+- What is a tuple.
 
 - Looping a list using `for`.
 
@@ -16,11 +16,11 @@ During this course you will be learning the following concepts:
 
 - Filter a list.
 
-- Creating Matrix.
+- Creating a matrix.
 
 - Merge lists.
 
 - How to combine and use all these concepts in different ways.
 
-Please click on the `Next →` button on the top right to proceed to the first challenge.
+Please click on the `Next →` button on the top right to proceed to the first exercise.
 
diff --git a/exercises/01-hello-world/README.es.md b/exercises/01-hello-world/README.es.md
index 7b17e583..a176239f 100644
--- a/exercises/01-hello-world/README.es.md
+++ b/exercises/01-hello-world/README.es.md
@@ -1,12 +1,10 @@
-# `01` Hola, Mundo
+# `01` Hello World
 
-En Python, usamos `print` para hacer que el computador escriba cualquier cosa que queramos 
-(el contenido de una variable, una cadena de texto dada, etc.)
-en algo llamado `la consola`.
+En Python, usamos `print` para hacer que el computador escriba cualquier cosa que queramos (el contenido de una variable, una cadena de texto dada, etc.) en algo llamado "la consola".
 
-Cada lenguaje tiene una consola, ya que al principio era la única forma de interactuar con los usuarios (antes de que llegaran Windows, Linux o MacOS).
+Cada lenguaje tiene una consola, ya que al principio era la única forma de interactuar con los usuarios (antes de que llegaran Windows, Linux o macOS).
 
-Hoy en día, la impresión en la consola se utiliza, sobre todo, como herramienta de monitorización y depuración, ideal para dejar un rastro del contenido de las variables durante la ejecución del programa.
+Hoy en día, la impresión en la consola se utiliza, sobre todo, como herramienta de monitoreo y depuración, ideal para dejar un rastro del contenido de las variables durante la ejecución del programa.
 
 Este es un ejemplo de cómo usarla:
 
@@ -16,9 +14,8 @@ print("How are you?")
 
 ## 📝 Instrucciones:
 
-1. Usa la función `print()` para escribir "Hello World" en la consola. 
+1. Usa la función `print()` para escribir `Hello World` en la consola. 
  
-
-## :bulb: Pista:
+## 💡 Pista:
 
 + Siéntete libre de intentar otras cosas también.
diff --git a/exercises/01-hello-world/README.md b/exercises/01-hello-world/README.md
index 3390a1ea..14311ff3 100644
--- a/exercises/01-hello-world/README.md
+++ b/exercises/01-hello-world/README.md
@@ -1,12 +1,10 @@
 # `01` Hello World
 
-In Python, we use `print` to make the computer write anything we want (the content of a variable, a given string, etc.)
-in something called `the console`.
+In Python, we use `print` to make the computer write anything we want (the content of a variable, a given string, etc.) in something called "the console".
 
-Every language has a console, as it was the only way to interact with the users at the beginning
-(before the Windows or MacOS arrived). 
+Every language has a console, as it was the only way to interact with the users at the beginning (before Windows, Linux or macOS arrived).
 
-Today, printing in the console is used mostly as a monitoring tool, ideal to leave a trace of the content of variables during the program execution.
+Today, printing in the console is mostly used as a monitoring and debugging tool, ideal for leaving a trace of the content of variables during the program's execution.
 
 This is an example of how to use it:
 
@@ -18,7 +16,7 @@ print("How are you?")
 
 1. Use the `print()` function to print `Hello World` on the console. 
 
-## :bulb: Hint:
+## 💡 Hint:
 
 + Feel free to try other things as well.
 
diff --git a/exercises/01-hello-world/app.py b/exercises/01-hello-world/app.py
index 9e9f9126..fce62c1d 100644
--- a/exercises/01-hello-world/app.py
+++ b/exercises/01-hello-world/app.py
@@ -1 +1 @@
-# On the next line, use Python's print function to say `Hello World` in the console (this exercise is case-sensitive!)
+# Your code here
diff --git a/exercises/01-hello-world/solution.hide.py b/exercises/01-hello-world/solution.hide.py
new file mode 100644
index 00000000..a0337541
--- /dev/null
+++ b/exercises/01-hello-world/solution.hide.py
@@ -0,0 +1,3 @@
+# Your code here
+
+print("Hello World")
diff --git a/exercises/01-hello-world/test.py b/exercises/01-hello-world/test.py
index 3ad81498..876a436e 100644
--- a/exercises/01-hello-world/test.py
+++ b/exercises/01-hello-world/test.py
@@ -1,15 +1,15 @@
 import io, sys, os
 import pytest
 
-@pytest.mark.it("Output 'Hello World' case sensitive")
+@pytest.mark.it("Output 'Hello World' on the console (case sensitive)")
 def test_output(capsys, app):
     app()
     captured = capsys.readouterr()
     assert "Hello World\n" == captured.out
     # convert everything in the buffer to lower case, captured to lower case
 
-@pytest.mark.it("Use print function")
+@pytest.mark.it("Use the print function")
 def test_print():
     f = open(os.path.dirname(os.path.abspath(__file__)) + '/app.py')
     content = f.read()
-    assert content.find("print") > 0
\ No newline at end of file
+    assert content.find("print") > 0
diff --git a/exercises/01.1-Access-and-Retrieve/README.es.md b/exercises/01.1-Access-and-Retrieve/README.es.md
index 583feb2c..6046d4be 100644
--- a/exercises/01.1-Access-and-Retrieve/README.es.md
+++ b/exercises/01.1-Access-and-Retrieve/README.es.md
@@ -1,22 +1,18 @@
-# `01.1` Acceso y obtención
+# `01.1` Access and retrieve
 
-## 📝 Instrucciones:
-
-Las **listas** forman parte de cada lenguaje de programación. 
-
-Así se hace cuando tienes una "lista de elementos".
+Las **listas** forman parte de cada lenguaje de programación. Es lo que se usa cuando quieres una "lista de elementos".
 
 Por ejemplo, podríamos tener una lista que almacena los días de la semana:
 
 ```py
-my_list = ['sunday','monday','tuesday','wednesday','thursday','friday','saturday']
+my_list = ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday']
 ```
 
 
 
 Cada lista tiene las siguientes partes:
 
-- `Items`: son los valores reales en cada posición de la lista.
+- `Items`: son los valores en cada posición de la lista.
 
 - `Length`: es el tamaño de la lista, el número de elementos (items).
 
@@ -24,16 +20,16 @@ Cada lista tiene las siguientes partes:
 
 Para acceder a un elemento particular dentro de la lista necesitas conocer su `index` (posición).
 
-El índice (`index`) es un valor entero que representa la posición en la cuál está ubicado el elemento en la lista.
+El índice (`index`) es un valor entero que representa la posición en la cual está ubicado el elemento en la lista.
 
-## :mag_right: Importante:
+## 🔎 Importante:
 
-¡Cada lista empieza en cero `(0)`! Así que para obtener el primer elemento deberíamos usar `my_list[0]`
+Cada lista empieza en cero (0), así que para obtener el primer elemento deberíamos usar `my_list[0]`
 
 ## 📝 Instrucciones:
 
 1. Usando la función `print()`, imprime el **3er elemento** de la lista.
 
-2. Cambia el valor de la posición en que se encuentra `Thursday` a `None`.
+2. Cambia el valor de la posición en que se encuentra `thursday` a `None`.
 
 3. Imprime la posición en que se encuentra el elemento del paso 2.
diff --git a/exercises/01.1-Access-and-Retrieve/README.md b/exercises/01.1-Access-and-Retrieve/README.md
index db512aa8..a4dbda7e 100644
--- a/exercises/01.1-Access-and-Retrieve/README.md
+++ b/exercises/01.1-Access-and-Retrieve/README.md
@@ -4,38 +4,36 @@ tutorial: "https://www.youtube.com/watch?v=uUQ6FlkoZbQ"
 
 # `01.1` Access and retrieve
 
-## 📝Instructions:
-
 **Lists** are part of every programming language. They are the way to go when you want to have a 'list of elements'.
 
-For example, we could have a list that is storing the days of the week:
+For example, we could have a list that stores the days of the week:
 
 ```py
-my_list = ['sunday','monday','tuesday','wednesday','thursday','friday','saturday']
+my_list = ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday']
 ```
 
 
 
 Every list has the following parts:
 
-- `Items:` are the actual values inside on each position of the list.
+- `Items:` are the actual values inside each position of the list.
 
 - `Length:` is the size of the list, the number of items.
 
 - `Index:` is the position of an element.
 
-To access any particular item within the list you need to know its `index` (position).
+To access any particular item within the list, you need to know its `index` (position).
 
 The `index` is an integer value that represents the position in which the element is located.
 
-## :mag_right: Important:
+## 🔎 Important:
 
-Every list starts from zero (0)! So to get the `first item` we'd use `my_list[0]`
+Every list starts from zero (0), so to get the first item we'd use `my_list[0]`.
 
 ## 📝 Instructions:
 
 1. Using the `print()` function, print the 3rd item from the list.
 
-2. Change the value in the position where `Thursday'` is located to `None`.
+2. Change the value in the position where `thursday` is located to `None`.
 
-3. Print the particular position of the step two.
+3. Print the particular position of step two.
diff --git a/exercises/01.1-Access-and-Retrieve/app.py b/exercises/01.1-Access-and-Retrieve/app.py
index c215ca3f..250261b7 100644
--- a/exercises/01.1-Access-and-Retrieve/app.py
+++ b/exercises/01.1-Access-and-Retrieve/app.py
@@ -1,8 +1,7 @@
+my_list = ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday']
 
-my_list = ['sunday','monday','tuesday','wednesday','thursday','friday','saturday']
+# 1. Print the 3rd item here
 
-# 1. print the item here
+# 2. Change the value of 'thursday' to None
 
-# 2. change the position were 'thursday' is to None
-
-# 3. print that position now here
\ No newline at end of file
+# 3. Print that position now here
diff --git a/exercises/01.1-Access-and-Retrieve/solution.hide.py b/exercises/01.1-Access-and-Retrieve/solution.hide.py
new file mode 100644
index 00000000..288a11ef
--- /dev/null
+++ b/exercises/01.1-Access-and-Retrieve/solution.hide.py
@@ -0,0 +1,8 @@
+my_list = ['sunday', 'monday', 'tuesday', 'wednesday', 'thursday', 'friday', 'saturday']
+
+# 1. Print the 3rd item here
+print(my_list[2])
+# 2. Change the value of 'thursday' to None
+my_list[4] = None
+# 3. Print that position now here
+print(my_list[4])
diff --git a/exercises/01.1-Access-and-Retrieve/test.py b/exercises/01.1-Access-and-Retrieve/test.py
index cc7ca600..3daa4242 100644
--- a/exercises/01.1-Access-and-Retrieve/test.py
+++ b/exercises/01.1-Access-and-Retrieve/test.py
@@ -1,18 +1,18 @@
 import io, sys, pytest
 
-@pytest.mark.it('Your console have to print the 3rd item from the `list`')
+@pytest.mark.it('Your console has to print the 3rd item from my_list')
 def test_output_one(capsys, app):
     app()
     captured = capsys.readouterr()
     assert "tuesday\n" in captured.out
 
-@pytest.mark.it('Your code have to print the position of step 2')
+@pytest.mark.it('Your code has to print the fourth position from my_list')
 def test_output_two(capsys, app):
     app()
     captured = capsys.readouterr()
     assert "None\n" in captured.out
 
-@pytest.mark.it('Set the position were thrusday is to None')
+@pytest.mark.it('Set the value of thursday to None')
 def test_position_two():
     from app import my_list
-    assert my_list[4] is None
\ No newline at end of file
+    assert my_list[4] is None
diff --git a/exercises/01.2-Retrieve-items/README.es.md b/exercises/01.2-Retrieve-items/README.es.md
index 9af1b41c..1855b299 100644
--- a/exercises/01.2-Retrieve-items/README.es.md
+++ b/exercises/01.2-Retrieve-items/README.es.md
@@ -1,17 +1,17 @@
-# `01.2` Obtener elementos
+# `01.2` Retrieve items
 
-La única forma de acceder a un elemento particuar en una `list` (en python), es usando un índice.
+La única forma de acceder a un elemento particular en una lista (en Python), es usando el índice.
 
-Un `index` es un número entero que representa la `posición` a la que quieres acceder en la lista.
+Un `index` es un número entero que representa la *posición* a la que quieres acceder en la lista.
 
-Necesitas `envolver` el índice entre `corchetes` así:
+Debes **envolver** el índice entre corchetes así:
 
 ```py
-my_value = list[index]
+my_value = my_list[index]
 ```
 
 ## 📝 Instrucciones:
 
-1. Imprime en la consola el `1er elemento` de la lista.
+1. Imprime en la consola el 1er elemento de la lista.
 
-2. Imprime en la consola el `4to elemento` de la lista.
+2. Imprime en la consola el 4to elemento de la lista.
diff --git a/exercises/01.2-Retrieve-items/README.md b/exercises/01.2-Retrieve-items/README.md
index d9180bd8..a30d5d24 100644
--- a/exercises/01.2-Retrieve-items/README.md
+++ b/exercises/01.2-Retrieve-items/README.md
@@ -4,18 +4,18 @@ tutorial: "https://www.youtube.com/watch?v=Yyo3cP3zyT4"
 
 # `01.2` Retrieve items
 
-The only way of accessing a particular element in an `list`(in python), is using an index.
+The only way of accessing a particular element in an list (in Python), is using an index.
 
-An `index` is an integer number that represents the `position` you want to access in the list.
+An `index` is an integer number that represents the *position* you want to access in the list.
 
-You need to `wrap` the index into `brackets` like this:
+You need to **wrap** the index into brackets like this:
 
 ```py
-my_value = list[index]
+my_value = my_list[index]
 ```
 
 ## 📝 Instructions:
 
-1. Print on the console the 1st element of the list
+1. Print on the console the 1st element of the list.
 
-2. Print on the console the 4th element of the list
+2. Print on the console the 4th element of the list.
diff --git a/exercises/01.2-Retrieve-items/app.py b/exercises/01.2-Retrieve-items/app.py
index 48a9d7db..9208b3cd 100644
--- a/exercises/01.2-Retrieve-items/app.py
+++ b/exercises/01.2-Retrieve-items/app.py
@@ -1,5 +1,5 @@
 my_list = [4,5,734,43,45,100,4,56,23,67,23,58,45,3,100,4,56,23]
 
-# Print in the console the 1st element on the list:
+# Print in the console the 1st element on the list
 
-# Print in the console the 4th element on the list:
\ No newline at end of file
+# Print in the console the 4th element on the list
diff --git a/exercises/01.2-Retrieve-items/solution.hide.py b/exercises/01.2-Retrieve-items/solution.hide.py
new file mode 100644
index 00000000..f5b374e5
--- /dev/null
+++ b/exercises/01.2-Retrieve-items/solution.hide.py
@@ -0,0 +1,6 @@
+my_list = [4,5,734,43,45,100,4,56,23,67,23,58,45,3,100,4,56,23]
+
+# Print in the console the 1st element on the list
+print(my_list[0])
+# Print in the console the 4th element on the list
+print(my_list[3])
diff --git a/exercises/01.3-Print-the-last-one/README.es.md b/exercises/01.3-Print-the-last-one/README.es.md
index 2a92b231..b1666623 100644
--- a/exercises/01.3-Print-the-last-one/README.es.md
+++ b/exercises/01.3-Print-the-last-one/README.es.md
@@ -1,31 +1,31 @@
-# `01.3` Imprimir el último
+# `01.3` Print the last one
 
-Nunca sabrás cuántos `items` tiene `my_stupid_list`, porque se genera aleatoriamente durante la ejecución!
+¡Nunca sabrás cuántos *items* tiene `my_stupid_list`, porque se genera aleatoriamente durante la ejecución!
 
 Sabes que la propiedad:
 
 ```py
-len(name_list) # función
+len(list_name)
 ```
 
-devuelve la `longitud` (`length of`) nombre_lista .
+Devuelve la longitud de `list_name`.
 
 ## 📝 Instrucciones:
 
-1. Importa la función `random` al inicio del archivo/fichero.
+1. Importa la función `random` al inicio del archivo.
 
 2. Crea una variable llamada `the_last_one` y asígnale el último elemento de `my_stupid_list`.
 
 3. Imprime `the_last_one` en la consola.
 
-## 💡 Pista::
+## 💡 Pistas:
 
-- Para usar la función random, debemos importarla. La forma más efectiva de hacerlo es `import random`, sin comillas, al principio del archivo. 
++ Para usar la función random, debemos importarla. La forma más efectiva de hacerlo es escribir `import random` al principio del archivo. 
 
 + Para más información sobre la importación, consulta la documentación de Python: https://docs.python.org/3/reference/import.html?highlight=importing.
 
-+ Recuerda que, en Python, podemos acceder al primer elemento de la lista usando `my_list_name[0]`, al segundo con `my_list_name[1]` y así. 
++ Recuerda que, en Python, podemos acceder al primer elemento de la lista usando `my_list_name[0]`, al segundo con `my_list_name[1]` y así sucesivamente. 
  
 + Para acceder a elementos empezando por el *final* de la lista, podemos usar valores negativos, empezando desde `my_list_name[-1]` (no hay un [-0]). 
 
-+ Para más, consulta esto: https://docs.python.org/3/tutorial/introduction.html.
++ Para más información, consulta esto: https://docs.python.org/3/tutorial/introduction.html
diff --git a/exercises/01.3-Print-the-last-one/README.md b/exercises/01.3-Print-the-last-one/README.md
index 17380d3d..468cc256 100644
--- a/exercises/01.3-Print-the-last-one/README.md
+++ b/exercises/01.3-Print-the-last-one/README.md
@@ -7,27 +7,29 @@ tutorial: "https://www.youtube.com/watch?v=p7tN9AUwy5Q"
 You will never know how many items `my_stupid_list` has, because it is being randomly generated during runtime!
 
 You know that the property:
+
 ```py
-len(name_list) # function
+len(list_name)
 ```
-returns the `length of` name_list .
+
+returns the length of `list_name`.
 
 ## 📝 Instructions:
 
-1. Import `random function` at the beginning of the file.
+1. Import `random` at the beginning of the file.
 
 2. Create a variable named `the_last_one`, and assign it the LAST element of `my_stupid_list`.
 
 3. Print `the_last_one` to the console.
 
-## 💡 Hint:
+## 💡 Hints:
 
-- To use the random functionality, we must import. The most effective way is by using `import random`, without the quotes, at the beginning of the document.
++ To use the random functionality, we must import. The most effective way is by using `import random` at the beginning of the document.
 
 + For more information about importing, check out the Python documentation: https://docs.python.org/3/reference/import.html?highlight=importing.
 
-+ To access the first element in a list by using `my_list_name[0]`, the second with `my_list_name[1]` and so on. 
++ To access the first element in a list we use `my_list_name[0]`, the second with `my_list_name[1]` and so on. 
 
 + To access items starting at the *end* of the list, we can use negative values starting from `my_list_name[-1]` (there is no [-0]). 
 
-+ For more check out: https://docs.python.org/3/tutorial/introduction.html.
++ For more, check out: https://docs.python.org/3/tutorial/introduction.html
diff --git a/exercises/01.3-Print-the-last-one/app.py b/exercises/01.3-Print-the-last-one/app.py
index a9a794ce..68fa5b25 100644
--- a/exercises/01.3-Print-the-last-one/app.py
+++ b/exercises/01.3-Print-the-last-one/app.py
@@ -9,6 +9,8 @@ def generate_random_list():
         aux_list.append(randonlength)
         i += i
     return aux_list
+
 my_stupid_list = generate_random_list()
 
-# Feel happy to write the code below this comment, good luck!:
+# Write your code below this comment, good luck!
+
diff --git a/exercises/01.3-Print-the-last-one/solution.hide.py b/exercises/01.3-Print-the-last-one/solution.hide.py
new file mode 100644
index 00000000..33479076
--- /dev/null
+++ b/exercises/01.3-Print-the-last-one/solution.hide.py
@@ -0,0 +1,18 @@
+# import the random package here "import random"
+import random
+
+def generate_random_list():
+    aux_list = []
+    randonlength = random.randint(1, 100)
+
+    for i in range(randonlength):
+        aux_list.append(randonlength)
+        i += i
+    return aux_list
+
+my_stupid_list = generate_random_list()
+
+# Write your code below this comment, good luck!
+
+the_last_one = my_stupid_list[-1]
+print(the_last_one)
diff --git a/exercises/01.3-Print-the-last-one/test.py b/exercises/01.3-Print-the-last-one/test.py
index 09c5f0f4..f5913df7 100644
--- a/exercises/01.3-Print-the-last-one/test.py
+++ b/exercises/01.3-Print-the-last-one/test.py
@@ -8,14 +8,14 @@ def test_import_random():
         regex = re.compile(r"import(\s)+random")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Create the variable the_last_one")
+@pytest.mark.it("Create a variable called 'the_last_one'")
 def test_variable_exists(app):
     try:
         app.the_last_one
     except AttributeError:
         raise AttributeError("The variable 'the_last_one' should exist on app.py")
 
-@pytest.mark.it("Assign the last number to the variable")
+@pytest.mark.it("Assign the last element of the list to the variable")
 def test_assing(app):
     assert app.the_last_one == app.my_stupid_list[-1]
 
@@ -30,4 +30,4 @@ def test_use_print():
 def test_output(capsys, app):
     import app
     captured = capsys.readouterr()
-    assert  str(app.my_stupid_list[-1])+"\n" in captured.out
\ No newline at end of file
+    assert  str(app.my_stupid_list[-1])+"\n" in captured.out
diff --git a/exercises/01.4-Add-item-to-list/README.es.md b/exercises/01.4-Add-item-to-list/README.es.md
deleted file mode 100644
index 18f7bdc8..00000000
--- a/exercises/01.4-Add-item-to-list/README.es.md
+++ /dev/null
@@ -1,21 +0,0 @@
-# `01.4` Agregar elementos a la lista
-
-## 📝 Instrucciones:
-
-1. Añadir 10 enteros aleatorios a la lista `arr`.
-
-## 💡 Pista:
-
-- Tienes que importar la función "random": `import random`.
-
-- Usa la función `random()` para obtener números aleatorios.
-
-- Busca en Google cómo usar la función random.
-
-## Resultado esperado:
-
-Lo esperado en la consola es algo similar a esto:
-
-```py
-[4, 5, 734, 43, 45, 36, 2, 88, 12, 87, 79, 96, 58, 46, 7]
-```
\ No newline at end of file
diff --git a/exercises/01.4-Add-item-to-list/README.md b/exercises/01.4-Add-item-to-list/README.md
deleted file mode 100644
index ecbb6bb6..00000000
--- a/exercises/01.4-Add-item-to-list/README.md
+++ /dev/null
@@ -1,24 +0,0 @@
----
-tutorial: "https://www.youtube.com/watch?v=blkw9_c-s8M"
----
-
-# `01.4` Add items to the list
-
-## 📝Instructions:
-
-1. Add 10 random integers to the `arr` list.
-
-
-## 💡 Hint:
-
-+ You have to `import random` module.
-
-+ Use the `random.randint()` function to get random numbers.
-Search on Google how to use randint function.
-
-
-## Expected result:
-
-```py
-[4, 5, 734, 43, 45, 36, 2, 88, 12, 87, 79, 96, 58, 46, 7]
-```
diff --git a/exercises/01.4-Add-item-to-list/app.py b/exercises/01.4-Add-item-to-list/app.py
deleted file mode 100644
index a0ba2ac1..00000000
--- a/exercises/01.4-Add-item-to-list/app.py
+++ /dev/null
@@ -1,5 +0,0 @@
-#Remember import random function here:
-
-my_list = [4,5,734,43,45]
-
-#The magic is here:
diff --git a/exercises/01.5-loop-seventeen/README.es.md b/exercises/01.4-loop-seventeen/README.es.md
similarity index 68%
rename from exercises/01.5-loop-seventeen/README.es.md
rename to exercises/01.4-loop-seventeen/README.es.md
index 3de9ab2e..7d32a37e 100644
--- a/exercises/01.5-loop-seventeen/README.es.md
+++ b/exercises/01.4-loop-seventeen/README.es.md
@@ -1,6 +1,7 @@
-# `01.5` Bucle del 1 al 17
+# `01.4` Loop from 1 to 17
+
+Para iterar un número específico de veces, podemos usar:
 
-Para iterar un número específico de números, podemos usar 
 ```py
 range(,)
 ``` 
@@ -11,7 +12,7 @@ Por ejemplo:
 
 ```py
 for x in range(0,5):
-  print(x)
+    print(x)
 ```
 
 Salida:
@@ -26,19 +27,17 @@ Salida:
 
 Nota que el número especificado en el `range()`, 5 en este ejemplo, nunca es alcanzado y 4 es nuestra última salida. 
 
-Podemos incorporar parámetros adicionales para especificar más detalle (ahora sería un buen momento para buscar en Google o, al menos, ver la sección de pistas ;) ).
+Podemos incorporar parámetros adicionales para especificar más detalle (ahora sería un buen momento para buscar en Google o, al menos, ver la sección de pistas 😉).
 
-## 📝Instrucciones:
+## 📝 Instrucciones:
 
 1. Contar del 1 al 17 con un bucle e imprimir cada número en la consola.
 
-## 💡 Pista:
-
-+ Así haces un bucle:
+## 💡 Pistas:
 
-https://www.w3schools.com/python/python_for_loops.asp
++ Así haces un bucle: https://www.w3schools.com/python/python_for_loops.asp
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 1
diff --git a/exercises/01.5-loop-seventeen/README.md b/exercises/01.4-loop-seventeen/README.md
similarity index 67%
rename from exercises/01.5-loop-seventeen/README.md
rename to exercises/01.4-loop-seventeen/README.md
index 8abe4235..c2fa80e6 100644
--- a/exercises/01.5-loop-seventeen/README.md
+++ b/exercises/01.4-loop-seventeen/README.md
@@ -2,9 +2,9 @@
 tutorial: "https://www.youtube.com/watch?v=qO3ZNWrkeGg"
 ---
 
-# `01.5` Loop from 1 to 17
+# `01.4` Loop from 1 to 17
 
-To loop a specific number of times, we can use 
+To loop a specific number of times, we can use:
 
 ```py
 range(,)
@@ -16,7 +16,7 @@ For example:
 
 ```python
 for x in range(0,5):
-  print(x)
+    print(x)
 ```
 
 Expected output:
@@ -30,17 +30,17 @@ Expected output:
 
 Note that the number specified in `range()`, 5 in this example, is never reached and 4 is our last output. 
 
-We can incorporate additional parameters to further specify (now could be a good time to google or at least check the HINT section ;) ).
+We can incorporate additional parameters to further specify (now could be a good time to Google or at least check the HINT section 😉).
 
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Count from 1 to 17 with a loop and print each number on the console.
 
-## 💡 Hint:
+## 💡 Hints:
 
-- This how you loop : https://www.w3schools.com/python/python_for_loops.asp
+- This how you loop: https://www.w3schools.com/python/python_for_loops.asp
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 1
diff --git a/exercises/01.5-loop-seventeen/app.py b/exercises/01.4-loop-seventeen/app.py
similarity index 100%
rename from exercises/01.5-loop-seventeen/app.py
rename to exercises/01.4-loop-seventeen/app.py
diff --git a/exercises/01.4-loop-seventeen/solution.hide.py b/exercises/01.4-loop-seventeen/solution.hide.py
new file mode 100644
index 00000000..ce7749e1
--- /dev/null
+++ b/exercises/01.4-loop-seventeen/solution.hide.py
@@ -0,0 +1,3 @@
+# Your code here, have fun:
+for x in range(1,18):
+    print(x)
diff --git a/exercises/01.5-loop-seventeen/test.py b/exercises/01.4-loop-seventeen/test.py
similarity index 100%
rename from exercises/01.5-loop-seventeen/test.py
rename to exercises/01.4-loop-seventeen/test.py
diff --git a/exercises/01.5-Add-item-to-list/README.es.md b/exercises/01.5-Add-item-to-list/README.es.md
new file mode 100644
index 00000000..586cc0bf
--- /dev/null
+++ b/exercises/01.5-Add-item-to-list/README.es.md
@@ -0,0 +1,12 @@
+# `01.5` Add items to the list
+
+## 📝 Instrucciones:
+
+1. Añade 10 números enteros aleatorios a la lista `my_list`.
+
+## 💡 Pistas:
+
++ Tienes que importar el módulo "random": `import random`.
+
++ Usa la función `random.randint()` para obtener números aleatorios. Busca en Google "cómo usar la función randint".
+
diff --git a/exercises/01.5-Add-item-to-list/README.md b/exercises/01.5-Add-item-to-list/README.md
new file mode 100644
index 00000000..d8e37185
--- /dev/null
+++ b/exercises/01.5-Add-item-to-list/README.md
@@ -0,0 +1,16 @@
+---
+tutorial: "https://www.youtube.com/watch?v=blkw9_c-s8M"
+---
+
+# `01.5` Add items to the list
+
+## 📝 Instructions:
+
+1. Add 10 random integers to `my_list`.
+
+## 💡 Hints:
+
++ You have to `import random` module.
+
++ Use the `random.randint()` function to get random numbers. Search on Google "how to use the randint function".
+
diff --git a/exercises/01.5-Add-item-to-list/app.py b/exercises/01.5-Add-item-to-list/app.py
new file mode 100644
index 00000000..c74ded5f
--- /dev/null
+++ b/exercises/01.5-Add-item-to-list/app.py
@@ -0,0 +1,5 @@
+# Remember to import random function here
+
+my_list = [4, 5, 734, 43, 45]
+
+# The magic goes below
diff --git a/exercises/01.5-Add-item-to-list/solution.hide.py b/exercises/01.5-Add-item-to-list/solution.hide.py
new file mode 100644
index 00000000..dd5067d7
--- /dev/null
+++ b/exercises/01.5-Add-item-to-list/solution.hide.py
@@ -0,0 +1,12 @@
+# Remember to import random function here
+import random
+
+my_list = [4, 5, 734, 43, 45]
+
+# The magic goes below
+
+for item in range(10):
+    random_integer = random.randint(1, 100)
+    my_list.append(random_integer)
+
+print(my_list)
diff --git a/exercises/01.4-Add-item-to-list/test.py b/exercises/01.5-Add-item-to-list/test.py
similarity index 87%
rename from exercises/01.4-Add-item-to-list/test.py
rename to exercises/01.5-Add-item-to-list/test.py
index 4b5b6fde..499d4f19 100644
--- a/exercises/01.4-Add-item-to-list/test.py
+++ b/exercises/01.5-Add-item-to-list/test.py
@@ -8,7 +8,7 @@ def test_import_random():
         regex = re.compile(r"import(\s)+random")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use the for loop to loop 10 times")
+@pytest.mark.it("Use a for loop to loop 10 times")
 def test_for_loop():
     path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
     with open(path, 'r') as content_file:
@@ -17,7 +17,7 @@ def test_for_loop():
         assert bool(regex.search(content)) == True
 
 
-@pytest.mark.it("Use the randint function to add a radom number to the list each time you loop")
+@pytest.mark.it("Use the randint function to add a random number to the list each time you loop")
 def test_for_randint():
     path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
     with open(path, 'r') as content_file:
diff --git a/exercises/02-Loop-list/README.es.md b/exercises/02-Loop-list/README.es.md
index a2f46688..1c7b6a36 100644
--- a/exercises/02-Loop-list/README.es.md
+++ b/exercises/02-Loop-list/README.es.md
@@ -1,17 +1,16 @@
-# `02` Iterar una lista
+# `02` Loop list
 
 ## 📝 Instrucciones:
 
 1. Imprimir todos los elementos en la consola, en lugar de solo un elemento de la lista.
-```py
-Tendrás que iterar a lo largo de la lista entera usando un bucle `for`.
-```
+
+> Tendrás que iterar a lo largo de la lista entera usando un bucle `for`.
 
 ## 💡 Pista:
 
 + Si tu objetivo es imprimir cada elemento, que es una tarea repetitiva, podemos usar un bucle. Piensa, por cada item(`each_item`) de `my_list`, ¿Qué queremos? Podemos hacer la referencia a cada item usando `each_item` y ejecutar cualquier operación que queramos en cada iteración.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 232
diff --git a/exercises/02-Loop-list/README.md b/exercises/02-Loop-list/README.md
index f0d7d852..c3c8e5e0 100644
--- a/exercises/02-Loop-list/README.md
+++ b/exercises/02-Loop-list/README.md
@@ -4,19 +4,17 @@ tutorial: "https://www.youtube.com/watch?v=VK7jmXad64k"
 
 # `02` Loop list
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Print all of the elements in the console, instead of just the single value of the list.
+1. Print all the elements in the console instead of just a single value of the list.
 
-```py
-You will have to loop through the whole array using a for loop.
-```
+> You will have to loop through the whole array using a `for` loop.
 
- ## 💡 Hint:
+## 💡 Hint:
  
  + If our goal is to print every item, which is a repetitive task, we can use a loop. Think, for `each_item` in `my_list`, what do we want? We can then use the namespace reference to each item by using `each_item` and perform any operations we want upon each iteration.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 232
diff --git a/exercises/02-Loop-list/app.py b/exercises/02-Loop-list/app.py
index b2ab27c2..13b3228b 100644
--- a/exercises/02-Loop-list/app.py
+++ b/exercises/02-Loop-list/app.py
@@ -1,4 +1,4 @@
 my_list = [232,32,1,4,55,4,3,32,3,24,5,5,5,34,2,35,5365743,52,34,3,55]
 
-#Your code go here:
-print(my_list[0])
\ No newline at end of file
+# Your code here
+print(my_list[0])
diff --git a/exercises/02-Loop-list/solution.hide.py b/exercises/02-Loop-list/solution.hide.py
new file mode 100644
index 00000000..1626a81c
--- /dev/null
+++ b/exercises/02-Loop-list/solution.hide.py
@@ -0,0 +1,5 @@
+my_list = [232,32,1,4,55,4,3,32,3,24,5,5,5,34,2,35,5365743,52,34,3,55]
+
+# Your code here
+for item in my_list:
+    print(item)
diff --git a/exercises/02-Loop-list/test.py b/exercises/02-Loop-list/test.py
index 7e6c682e..c65879d5 100644
--- a/exercises/02-Loop-list/test.py
+++ b/exercises/02-Loop-list/test.py
@@ -1,7 +1,7 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Print the all items from the list")
+@pytest.mark.it("Print all items from the list")
 def test_output(capsys, app):
     app()
     captured = capsys.readouterr()
diff --git a/exercises/02.1-Loop-from-the-top/README.es.md b/exercises/02.1-Loop-from-the-top/README.es.md
index d1b4d339..e3670e4c 100644
--- a/exercises/02.1-Loop-from-the-top/README.es.md
+++ b/exercises/02.1-Loop-from-the-top/README.es.md
@@ -1,14 +1,13 @@
-# `02.1` Iterar desde el tope
+# `02.1` Loop from the end
 
-```py
-Este bucle es `iterando` la lista de principio a fin... incrementando uno a uno.
-```
+Este bucle está iterando la lista de principio a fin, incrementando uno en uno.
 
 ## 📝 Instrucciones:
 
 1. Vamos a intentar iterar desde el fin hasta el principio.
 
-La salida en la consola debería ser algo así:
+## 💻 Resultado esperado:
+
 ```js
 12
 25
@@ -24,4 +23,4 @@ La salida en la consola debería ser algo así:
 4
 5
 3423
-```
\ No newline at end of file
+```
diff --git a/exercises/02.1-Loop-from-the-top/README.md b/exercises/02.1-Loop-from-the-top/README.md
index a6220bf0..c9bc8869 100644
--- a/exercises/02.1-Loop-from-the-top/README.md
+++ b/exercises/02.1-Loop-from-the-top/README.md
@@ -2,17 +2,15 @@
 tutorial: "https://www.youtube.com/watch?v=tFCstq-Us3I"
 ---
 
-# `02.1` Loop from the top
+# `02.1` Loop from the end
 
-```py
-This loop is `looping` the list from beginning to end... increasing one by one.
-```
+This loop is *looping* the list from beginning to end, increasing one by one.
 
-## 📝Instructions::
+## 📝 Instructions:
 
-1. Lets try looping from the end to the beginning.
+1. Let's try looping from the end to the beginning.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 12
diff --git a/exercises/02.1-Loop-from-the-top/app.py b/exercises/02.1-Loop-from-the-top/app.py
index e125f958..1442ea68 100644
--- a/exercises/02.1-Loop-from-the-top/app.py
+++ b/exercises/02.1-Loop-from-the-top/app.py
@@ -1,9 +1,6 @@
 my_sample_list = [3423,5,4,47889,654,8,867543,23,48,56432,55,23,25,12]
 
-# The magic pass below:
-# Create a variable, like "i", that uses the last index position in the array "my_sample_list". Remember we can access the length property of an array using len, and that the position will always be 1 less than the item number (item one is index 0, item 5653 would be one less...) 
+# Modify the loop below to print from end to start
 
-# You can now use the variable holding the last position to iterate until you get to the first position- which will always be 0. Create a for loop using that variable, make sure the value of the variable is modified on each iteration of the loop.
-# while some_variable_reference > 0:
-#     print(my_sample_list[some_variable_reference])
-#     chage after doing what we wanted, change the variables value so that the next pass it references the new index position
+for i in range(0, len(my_sample_list)):
+    print(my_sample_list[i])
diff --git a/exercises/02.1-Loop-from-the-top/solution.hide.py b/exercises/02.1-Loop-from-the-top/solution.hide.py
new file mode 100644
index 00000000..f732e1fa
--- /dev/null
+++ b/exercises/02.1-Loop-from-the-top/solution.hide.py
@@ -0,0 +1,6 @@
+my_sample_list = [3423,5,4,47889,654,8,867543,23,48,56432,55,23,25,12]
+
+# Modify the loop below to print from end to start
+
+for i in range(len(my_sample_list) - 1, -1, -1):
+    print(my_sample_list[i])
diff --git a/exercises/02.1-Loop-from-the-top/test.py b/exercises/02.1-Loop-from-the-top/test.py
index f06b7ceb..faf48448 100644
--- a/exercises/02.1-Loop-from-the-top/test.py
+++ b/exercises/02.1-Loop-from-the-top/test.py
@@ -7,9 +7,9 @@ def test_output(capsys, app):
     captured = capsys.readouterr()
     assert "12\n25\n23\n55\n56432\n48\n23\n867543\n8\n654\n47889\n4\n5\n3423\n" in captured.out
 
-@pytest.mark.it("Use the while loop")
+@pytest.mark.it("Use the for loop")
 def test_for_loop():
     with open(path, 'r') as content_file:
         content = content_file.read()
-        regex = re.compile(r"while(\s)+[a-zA-Z\-_]+(\s)")
+        regex = re.compile(r"for(\s)+[a-zA-Z\-_]+(\s)")
         assert bool(regex.search(content)) == True
diff --git a/exercises/02.2-Loop-adding-two/README.es.md b/exercises/02.2-Loop-adding-two/README.es.md
index 0eaf8f6e..1bebc27c 100644
--- a/exercises/02.2-Loop-adding-two/README.es.md
+++ b/exercises/02.2-Loop-adding-two/README.es.md
@@ -1,14 +1,12 @@
-# `02.2` Iterando agregando dos
+# `02.2` Loop adding two
 
-```py
-Este códico es `iterando` la lista entera, `uno a uno`.
-```
+Este código está iterando la lista entera de *uno en uno*.
 
 ## 📝 Instrucciones:
 
-1. Cambia el bucle para que itere `de dos en dos` en lugar de uno a uno.
+1. Cambia el bucle para que itere de *dos en dos* en lugar de *uno en uno*.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 3423
@@ -18,4 +16,4 @@ Este códico es `iterando` la lista entera, `uno a uno`.
 48
 55
 25
-```
\ No newline at end of file
+```
diff --git a/exercises/02.2-Loop-adding-two/README.md b/exercises/02.2-Loop-adding-two/README.md
index 5d29e21c..78b1d900 100644
--- a/exercises/02.2-Loop-adding-two/README.md
+++ b/exercises/02.2-Loop-adding-two/README.md
@@ -4,15 +4,13 @@ tutorial: "https://www.youtube.com/watch?v=SJv6IgPick8"
 
 # `02.2` Loop adding two
 
-```py
-This code is `looping` the whole array, `one by one`.
-```
+This code is looping the whole array, *one by one*.
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Change the loop so it loops `two by two` instead of one by one.
+1. Change the loop so it loops *two by two* instead of *one by one*.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 3423
diff --git a/exercises/02.2-Loop-adding-two/app.py b/exercises/02.2-Loop-adding-two/app.py
index a335d15b..2a2a5f60 100644
--- a/exercises/02.2-Loop-adding-two/app.py
+++ b/exercises/02.2-Loop-adding-two/app.py
@@ -1,7 +1,6 @@
-my_sample_list= [3423,5,4,47889,654,8,867543,23,48,56432,55,23,25,12]
-
-#your code go below of this line, nothing change above:
+my_sample_list = [3423,5,4,47889,654,8,867543,23,48,56432,55,23,25,12]
 
+# Your code below, don't change anything above
 
 for i in range(0, len(my_sample_list), 1):
     print(my_sample_list[i])
diff --git a/exercises/02.2-Loop-adding-two/solution.hide.py b/exercises/02.2-Loop-adding-two/solution.hide.py
new file mode 100644
index 00000000..3501d2da
--- /dev/null
+++ b/exercises/02.2-Loop-adding-two/solution.hide.py
@@ -0,0 +1,6 @@
+my_sample_list = [3423,5,4,47889,654,8,867543,23,48,56432,55,23,25,12]
+
+# Your code below, don't change anything above
+
+for i in range(0, len(my_sample_list), 2):
+    print(my_sample_list[i])
diff --git a/exercises/02.3-loop-from-the-half-to-the-end/README.es.md b/exercises/02.3-loop-from-the-half-to-the-end/README.es.md
index 27bddf11..7ed0516d 100644
--- a/exercises/02.3-loop-from-the-half-to-the-end/README.es.md
+++ b/exercises/02.3-loop-from-the-half-to-the-end/README.es.md
@@ -1,15 +1,15 @@
 
-# `02.3` Iterando desde la mitad hasta el final
+# `02.3` Loop from the half to the end
 
-Este bucle no es iterándolo todo... porque las variables `initialValue`, `stopValue` e `increasingValue` son iguales a cero.
+Este bucle no está iterándolo todo... porque las variables `initial_value`, `stop_value` e `increasing_value` son iguales a cero.
 
-# 📝 Instrucciones:
+## 📝 Instrucciones:
 
 1. Cambia el valor de esas variables para hacer que el bucle imprima solo la segunda mitad de la lista.
 
 2. ¡No cambies nada más que el valor de esas tres variables!
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 23
diff --git a/exercises/02.3-loop-from-the-half-to-the-end/README.md b/exercises/02.3-loop-from-the-half-to-the-end/README.md
index 6195fe34..5c3cdc18 100644
--- a/exercises/02.3-loop-from-the-half-to-the-end/README.md
+++ b/exercises/02.3-loop-from-the-half-to-the-end/README.md
@@ -4,16 +4,15 @@ tutorial: "https://www.youtube.com/watch?v=SzX_AdVBRn4"
 
 # `02.3` Loop from the half to the end
 
+This loop is not looping at all... because the variables `initial_value`, `stop_value` and `increasing_value` are equal to zero.
 
-This loop is not looping at all... because the variables initialValue, stopValue and increasingValue are equal to zero.
-
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Change the value of those variables to make the loop print only the last half of the list.
 
 2. Change nothing but the value of those 3 variables!
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 23
diff --git a/exercises/02.3-loop-from-the-half-to-the-end/app.py b/exercises/02.3-loop-from-the-half-to-the-end/app.py
index b54d88af..a2cf3175 100644
--- a/exercises/02.3-loop-from-the-half-to-the-end/app.py
+++ b/exercises/02.3-loop-from-the-half-to-the-end/app.py
@@ -1,11 +1,9 @@
 my_list = [3423,5,4,47889,654,8,867543,23,48,56432,55,23,25,12]
 
-#Your code here:
-inicialValue = 0
-stopValue = 0
-increaseValue = 0
+# Your code here
+inicial_value = 0
+stop_value = 0
+increase_value = 0
 
-for i in range(inicialValue, stopValue):
-    if i == my_list[i]:
-        i += increaseValue
+for i in range(inicial_value, stop_value, increase_value):
     print(my_list[i])
diff --git a/exercises/02.3-loop-from-the-half-to-the-end/solution.hide.py b/exercises/02.3-loop-from-the-half-to-the-end/solution.hide.py
new file mode 100644
index 00000000..65088e0d
--- /dev/null
+++ b/exercises/02.3-loop-from-the-half-to-the-end/solution.hide.py
@@ -0,0 +1,9 @@
+my_list = [3423,5,4,47889,654,8,867543,23,48,56432,55,23,25,12]
+
+# Your code here
+inicial_value = round(len(my_list)/2)
+stop_value = len(my_list)
+increase_value = 1
+
+for i in range(inicial_value, stop_value, increase_value):
+    print(my_list[i])
diff --git a/exercises/02.4-One_last_looping/README.es.md b/exercises/02.4-One_last_looping/README.es.md
index 78cef30d..fda5e583 100644
--- a/exercises/02.4-One_last_looping/README.es.md
+++ b/exercises/02.4-One_last_looping/README.es.md
@@ -1,19 +1,24 @@
-# `02.4` Una última iteración
+# `02.4` One last looping
 
 ## 📝 Instrucciones:
 
 1. Cambia el valor del segundo elemento a `Steven`.
 
-2. Establece la última posición a `Pepe`.
+2. Establece el valor de la última posición a `Pepe`.
 
-3. Define el valor del primer elemento al del 3er elemento concatenado con el valor del 5to elemento.
+3. Asígnale al primer elemento, el valor del 3er elemento concatenado con el valor del 5to elemento.
 
-4. Invierte el ciclo (desde el final hasta el principio) de toda la lista e imprime todos los elementos.
+4. Realiza un bucle en la lista en orden inverso (desde el final hasta el principio) e imprime todos los elementos...
 
-## 💡 Pista:
+## 💡 Pistas:
 
-- Recuerda que la posición inicial de la lista es 0.
-## Resultado esperado:
++ Recuerda que la posición inicial de la lista es 0.
+
++ Recuerda utilizar el bucle `for` en este ejercicio.
+
++ No debes utilizar ningún método para invertir la lista en lugar de `for`.
+
+## 💻 Resultado esperado:
 
 ```py
 Pepe
@@ -27,4 +32,4 @@ Lebron
 Ruth
 Steven
 RuthPedro
-```
\ No newline at end of file
+```
diff --git a/exercises/02.4-One_last_looping/README.md b/exercises/02.4-One_last_looping/README.md
index 5bb918f6..8d2b7a24 100644
--- a/exercises/02.4-One_last_looping/README.md
+++ b/exercises/02.4-One_last_looping/README.md
@@ -4,21 +4,25 @@ tutorial: "https://www.youtube.com/watch?v=ca1DZgLwy00"
 
 # `02.4` One last looping
 
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Change the second item value to `Steven`.
 
 2. Set the last position to `Pepe`.
 
-3. Set the first element to the value of the 3rd element concatenated to the value of the 5th element.
+3. Set the first element's value to the value of the 3rd element concatenated to the value of the 5th element.
 
-4. Reverse loop (from the end to the beginning) the whole list and print all the elements.
+4. Loop the list in reverse order (from the end to the beginning) and print all the elements.
 
-## 💡Hint:
+## 💡 Hints:
 
-- Remember that list start at position `0`.
++ Remember that lists start at position `0`.
 
-## Expected result:
++ Remember to use the `for` loop in this exercise.
+
++ You should use the `for` loop to reverse it instead of any other method.
+
+## 💻 Expected result:
 
 ```py
 Pepe
diff --git a/exercises/02.4-One_last_looping/app.py b/exercises/02.4-One_last_looping/app.py
index 268cf7bc..0607676f 100644
--- a/exercises/02.4-One_last_looping/app.py
+++ b/exercises/02.4-One_last_looping/app.py
@@ -1,4 +1,3 @@
-my_sample_list = ['Esmeralda','Kiko','Ruth','Lebron','Pedro','Maria','Lou','Fernando','Cesco','Bart','Annie']
-
-#Your code here:
+names = ['Esmeralda','Kiko','Ruth','Lebron','Pedro','Maria','Lou','Fernando','Cesco','Bart','Annie']
 
+# Your code here
diff --git a/exercises/02.4-One_last_looping/solution.hide.py b/exercises/02.4-One_last_looping/solution.hide.py
new file mode 100644
index 00000000..e8afe307
--- /dev/null
+++ b/exercises/02.4-One_last_looping/solution.hide.py
@@ -0,0 +1,8 @@
+names = ['Esmeralda','Kiko','Ruth','Lebron','Pedro','Maria','Lou','Fernando','Cesco','Bart','Annie']
+
+# Your code here
+names[1] = "Steven"
+names[-1] = "Pepe"
+names[0] = names[2] + names[4]
+for i in range(len(names) - 1, -1 , -1):
+    print(names[i])
diff --git a/exercises/02.4-One_last_looping/test.py b/exercises/02.4-One_last_looping/test.py
index 0f606747..cd9ddff5 100644
--- a/exercises/02.4-One_last_looping/test.py
+++ b/exercises/02.4-One_last_looping/test.py
@@ -1,15 +1,36 @@
-import io, sys, pytest, os, re
+import io, sys, pytest, os, re, app
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Add, change values and reversed list")
-def test_output(capsys, app):
-    app()
-    captured = capsys.readouterr()
-    assert "Pepe\nBart\nCesco\nFernando\nLou\nMaria\nPedro\nLebron\nRuth\nSteven\nRuthPedro\n" in captured.out
+@pytest.mark.it('The variable "names" should exist')
+def test_variable_exists():
+    try:
+        app.names
+    except AttributeError:
+        raise AttributeError('The variable "names" should exist on app.py')
+
+@pytest.mark.it('You have to set the second element of the list to "Steven"')
+def test_change_second():
+    try:
+        assert app.names[1] == "Steven"
+    except AttributeError:
+        raise AttributeError('The second element of the list "names" should should be "Steven"')
+
+@pytest.mark.it('You have to change the first element of the list to the third + the fifth element')
+def test_change_first():
+    try:
+        assert app.names[0] == "RuthPedro"
+    except AttributeError:
+        raise AttributeError('The first element of the list "names" should should be "RuthPedro"')
 
-@pytest.mark.it("Use the for loop")
+@pytest.mark.it("You have to use a for loop")
 def test_for_loop():
     with open(path, 'r') as content_file:
         content = content_file.read()
-        regex = re.compile(r"for(\s)+[a-zA-Z\-_]+(\s)+in(\s)+range.*")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        regex = re.compile(r"for(\s*)+\S+(\s*)+in(\s*)+range.*")
+        assert bool(regex.search(content)) == True
+
+@pytest.mark.it('You should print the list "names" reversed')
+def test_output(capsys, app):
+    app()
+    captured = capsys.readouterr()
+    assert "Pepe\nBart\nCesco\nFernando\nLou\nMaria\nPedro\nLebron\nRuth\nSteven\nRuthPedro\n" in captured.out
diff --git a/exercises/02.5-Finding_wally/README.es.md b/exercises/02.5-Finding_wally/README.es.md
index d2bdf62c..fcabf239 100644
--- a/exercises/02.5-Finding_wally/README.es.md
+++ b/exercises/02.5-Finding_wally/README.es.md
@@ -1,20 +1,20 @@
-# `02.5` Encontrando a Wally
+# `02.5` Finding Wally
 
 ## 📝 Instrucciones:
 
-1. Encuentra a Wally :)
+1. Encuentra a Wally 😊
 
 2. Imprime la(s) posición(es) de Wally en la consola.
 
-## 📝 Pista
+## 💡 Pista:
 
-+ Usa un bucle y un if (condicional)
++ Usa un bucle `for` y un condicional `if`.
 
-## :gem: Elemento sorpresa:
+## 💎 Elemento sorpresa:
 
 ¿Qué pasa si hay más de un Wally?
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 65
diff --git a/exercises/02.5-Finding_wally/README.md b/exercises/02.5-Finding_wally/README.md
index ed5f8580..a36bc814 100644
--- a/exercises/02.5-Finding_wally/README.md
+++ b/exercises/02.5-Finding_wally/README.md
@@ -4,21 +4,21 @@ tutorial: "https://www.youtube.com/watch?v=zez4r9ApjSY"
 
 # `02.5` Finding Wally
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Find Wally :)
+1. Find Wally 😊
 
 2. Print the position(s) of Wally in the console.
 
 ## 💡 Hint:
 
-- Use a loop and an if (conditional)
++ Use a `for` loop and an `if` statement.
 
-## :gem: Easter Egg:
+## 💎 Easter Egg:
 
 What if there is more than one Wally?
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 65
diff --git a/exercises/02.5-Finding_wally/app.py b/exercises/02.5-Finding_wally/app.py
index 4eb9f6d6..44797d49 100644
--- a/exercises/02.5-Finding_wally/app.py
+++ b/exercises/02.5-Finding_wally/app.py
@@ -1,4 +1,3 @@
-people = [ 'Lebron','Aaliyah','Diamond','Dominique','Aliyah','Jazmin','Darnell','Hatfield','Hawkins','Hayden','Hayes','Haynes','Hays','Head','Heath','Hebert','Henderson','Hendricks','Hendrix','Henry','Hensley','Henson','Herman','Hernandez','Herrera','Herring','Hess','Hester','Hewitt','Hickman','Hicks','Higgins','Hill','Hines','Hinton','Hobbs','Hodge','Hodges','Hoffman','Hogan','Holcomb','Holden','Holder','Holland','Holloway','Holman','Holmes','Holt','Hood','Hooper','Hoover','Hopkins','Hopper','Horn','Horne','Horton','House','Houston','Howard','Howe','Howell','Hubbard','Huber','Hudson','Huff','Wally','Hughes','Hull','Humphrey','Hunt','Hunter','Hurley','Hurst','Hutchinson','Hyde','Ingram','Irwin','Jackson','Jacobs','Jacobson','James','Jarvis','Jefferson','Jenkins','Jennings','Jensen','Jimenez','Johns','Johnson','Johnston','Jones','Jordan','Joseph','Joyce','Joyner','Juarez','Justice','Kane','Kaufman','Keith','Keller','Kelley','Kelly','Kemp','Kennedy','Kent','Kerr','Key','Kidd','Kim','King','Kinney','Kirby','Kirk','Kirkland','Klein','Kline','Knapp','Knight','Knowles','Knox','Koch','Kramer','Lamb','Lambert','Lancaster','Landry','Lane','Lang','Langley','Lara','Larsen','Larson','Lawrence','Lawson','Le','Leach','Leblanc','Lee','Leon','Leonard','Lester','Levine','Levy','Lewis','Lindsay','Lindsey','Little','Livingston','Lloyd','Logan','Long','Lopez','Lott','Love','Lowe','Lowery','Lucas','Luna','Lynch','Lynn','Lyons','Macdonald','Macias','Mack','Madden','Maddox','Maldonado','Malone','Mann','Manning','Marks','Marquez','Marsh','Marshall','Martin','Martinez','Mason','Massey','Mathews','Mathis','Matthews','Maxwell','May','Mayer','Maynard','Mayo','Mays','Mcbride','Mccall','Mccarthy','Mccarty','Mcclain','Mcclure','Mcconnell','Mccormick','Mccoy','Mccray','Wally','Mcdaniel','Mcdonald','Mcdowell','Mcfadden','Mcfarland','Mcgee','Mcgowan','Mcguire','Mcintosh','Mcintyre','Mckay','Mckee','Mckenzie','Mckinney','Mcknight','Mclaughlin','Mclean','Mcleod','Mcmahon','Mcmillan','Mcneil','Mcpherson','Meadows','Medina','Mejia','Melendez','Melton','Mendez','Mendoza','Mercado','Mercer','Merrill','Merritt','Meyer','Meyers','Michael','Middleton','Miles','Miller','Mills','Miranda','Mitchell','Molina','Monroe','Lucas','Jake','Scott','Amy','Molly','Hannah','Lucas']
-
-#Your code here:
+people = ['Lebron','Aaliyah','Diamond','Dominique','Aliyah','Jazmin','Darnell','Hatfield','Hawkins','Hayden','Hayes','Haynes','Hays','Head','Heath','Hebert','Henderson','Hendricks','Hendrix','Henry','Hensley','Henson','Herman','Hernandez','Herrera','Herring','Hess','Hester','Hewitt','Hickman','Hicks','Higgins','Hill','Hines','Hinton','Hobbs','Hodge','Hodges','Hoffman','Hogan','Holcomb','Holden','Holder','Holland','Holloway','Holman','Holmes','Holt','Hood','Hooper','Hoover','Hopkins','Hopper','Horn','Horne','Horton','House','Houston','Howard','Howe','Howell','Hubbard','Huber','Hudson','Huff','Wally','Hughes','Hull','Humphrey','Hunt','Hunter','Hurley','Hurst','Hutchinson','Hyde','Ingram','Irwin','Jackson','Jacobs','Jacobson','James','Jarvis','Jefferson','Jenkins','Jennings','Jensen','Jimenez','Johns','Johnson','Johnston','Jones','Jordan','Joseph','Joyce','Joyner','Juarez','Justice','Kane','Kaufman','Keith','Keller','Kelley','Kelly','Kemp','Kennedy','Kent','Kerr','Key','Kidd','Kim','King','Kinney','Kirby','Kirk','Kirkland','Klein','Kline','Knapp','Knight','Knowles','Knox','Koch','Kramer','Lamb','Lambert','Lancaster','Landry','Lane','Lang','Langley','Lara','Larsen','Larson','Lawrence','Lawson','Le','Leach','Leblanc','Lee','Leon','Leonard','Lester','Levine','Levy','Lewis','Lindsay','Lindsey','Little','Livingston','Lloyd','Logan','Long','Lopez','Lott','Love','Lowe','Lowery','Lucas','Luna','Lynch','Lynn','Lyons','Macdonald','Macias','Mack','Madden','Maddox','Maldonado','Malone','Mann','Manning','Marks','Marquez','Marsh','Marshall','Martin','Martinez','Mason','Massey','Mathews','Mathis','Matthews','Maxwell','May','Mayer','Maynard','Mayo','Mays','Mcbride','Mccall','Mccarthy','Mccarty','Mcclain','Mcclure','Mcconnell','Mccormick','Mccoy','Mccray','Wally','Mcdaniel','Mcdonald','Mcdowell','Mcfadden','Mcfarland','Mcgee','Mcgowan','Mcguire','Mcintosh','Mcintyre','Mckay','Mckee','Mckenzie','Mckinney','Mcknight','Mclaughlin','Mclean','Mcleod','Mcmahon','Mcmillan','Mcneil','Mcpherson','Meadows','Medina','Mejia','Melendez','Melton','Mendez','Mendoza','Mercado','Mercer','Merrill','Merritt','Meyer','Meyers','Michael','Middleton','Miles','Miller','Mills','Miranda','Mitchell','Molina','Monroe','Lucas','Jake','Scott','Amy','Molly','Hannah','Lucas']
 
+# Your code here
diff --git a/exercises/02.5-Finding_wally/solution.hide.py b/exercises/02.5-Finding_wally/solution.hide.py
new file mode 100644
index 00000000..78f51b4a
--- /dev/null
+++ b/exercises/02.5-Finding_wally/solution.hide.py
@@ -0,0 +1,7 @@
+people = ['Lebron','Aaliyah','Diamond','Dominique','Aliyah','Jazmin','Darnell','Hatfield','Hawkins','Hayden','Hayes','Haynes','Hays','Head','Heath','Hebert','Henderson','Hendricks','Hendrix','Henry','Hensley','Henson','Herman','Hernandez','Herrera','Herring','Hess','Hester','Hewitt','Hickman','Hicks','Higgins','Hill','Hines','Hinton','Hobbs','Hodge','Hodges','Hoffman','Hogan','Holcomb','Holden','Holder','Holland','Holloway','Holman','Holmes','Holt','Hood','Hooper','Hoover','Hopkins','Hopper','Horn','Horne','Horton','House','Houston','Howard','Howe','Howell','Hubbard','Huber','Hudson','Huff','Wally','Hughes','Hull','Humphrey','Hunt','Hunter','Hurley','Hurst','Hutchinson','Hyde','Ingram','Irwin','Jackson','Jacobs','Jacobson','James','Jarvis','Jefferson','Jenkins','Jennings','Jensen','Jimenez','Johns','Johnson','Johnston','Jones','Jordan','Joseph','Joyce','Joyner','Juarez','Justice','Kane','Kaufman','Keith','Keller','Kelley','Kelly','Kemp','Kennedy','Kent','Kerr','Key','Kidd','Kim','King','Kinney','Kirby','Kirk','Kirkland','Klein','Kline','Knapp','Knight','Knowles','Knox','Koch','Kramer','Lamb','Lambert','Lancaster','Landry','Lane','Lang','Langley','Lara','Larsen','Larson','Lawrence','Lawson','Le','Leach','Leblanc','Lee','Leon','Leonard','Lester','Levine','Levy','Lewis','Lindsay','Lindsey','Little','Livingston','Lloyd','Logan','Long','Lopez','Lott','Love','Lowe','Lowery','Lucas','Luna','Lynch','Lynn','Lyons','Macdonald','Macias','Mack','Madden','Maddox','Maldonado','Malone','Mann','Manning','Marks','Marquez','Marsh','Marshall','Martin','Martinez','Mason','Massey','Mathews','Mathis','Matthews','Maxwell','May','Mayer','Maynard','Mayo','Mays','Mcbride','Mccall','Mccarthy','Mccarty','Mcclain','Mcclure','Mcconnell','Mccormick','Mccoy','Mccray','Wally','Mcdaniel','Mcdonald','Mcdowell','Mcfadden','Mcfarland','Mcgee','Mcgowan','Mcguire','Mcintosh','Mcintyre','Mckay','Mckee','Mckenzie','Mckinney','Mcknight','Mclaughlin','Mclean','Mcleod','Mcmahon','Mcmillan','Mcneil','Mcpherson','Meadows','Medina','Mejia','Melendez','Melton','Mendez','Mendoza','Mercado','Mercer','Merrill','Merritt','Meyer','Meyers','Michael','Middleton','Miles','Miller','Mills','Miranda','Mitchell','Molina','Monroe','Lucas','Jake','Scott','Amy','Molly','Hannah','Lucas']
+
+# Your code here
+
+for i in range(0, len(people)):
+    if people[i].lower() == "wally":
+        print(i)
diff --git a/exercises/02.5-Finding_wally/test.py b/exercises/02.5-Finding_wally/test.py
index dccf74e4..426b6441 100644
--- a/exercises/02.5-Finding_wally/test.py
+++ b/exercises/02.5-Finding_wally/test.py
@@ -14,7 +14,7 @@ def test_for_loop():
         regex = re.compile(r"for(\s)")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
diff --git a/exercises/03-flip_list/README.es.md b/exercises/03-flip_list/README.es.md
index a0cb3091..abd5a005 100644
--- a/exercises/03-flip_list/README.es.md
+++ b/exercises/03-flip_list/README.es.md
@@ -1,21 +1,22 @@
-# `03` Lista volteada
+# `03` Flip list
 
 ## 📝 Instrucciones:
 
 1. Crea la variable `new_list`.
 
-2. Usando un bucle, invierte la lista `arr`.
+2. Usando un bucle, invierte la lista `sample_list`.
 
 3. Agrega el resultado del bucle a la variable `new_list`.
 
 4. Con la función `print()` imprime en la consola el resultado obtenido.
 
-```py
-list inicial:  [45, 67, 87, 23, 5,  32, 60]
-list final:    [60, 32, 5 , 23, 87, 67, 45]
-```
-
-
 ## 💡 Pista:
 
 - Deberías iterar la lista entera y meter los valores en la nueva lista a medida que avanzas.
+
+## 💻 Resultado esperado:
+
+```py
+lista inicial:  [45, 67, 87, 23, 5, 32, 60]
+lista final:    [60, 32, 5, 23, 87, 67, 45]
+```
diff --git a/exercises/03-flip_list/README.md b/exercises/03-flip_list/README.md
index 3b16b1f8..9e9c5891 100644
--- a/exercises/03-flip_list/README.md
+++ b/exercises/03-flip_list/README.md
@@ -4,22 +4,24 @@ tutorial: "https://www.youtube.com/watch?v=8wM8muTQJmU"
 
 # `03` Flip list
 
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Create a variable `new_list`.
 
-2. Using a loop, invert the `arr` list.
+2. Using a loop, invert the `sample_list`.
 
 3. Append the result loop into the `new_list` variable.
 
-4. With `print()` function output in the console the result that you have.
+4. With the `print()` function output in the console the result that you have.
 
-```py
-Initial list:  [45, 67, 87, 23, 5,  32, 60]
-Final list:    [60, 32, 5 , 23, 87, 67, 45]
-```
+## 💡 Hint:
 
+- You should loop the entire list, and append all the items (as you go) into a new list.
 
-## 💡 Hint:
+## 💻 Expected Result:
+
+```py
+initial list:  [45, 67, 87, 23, 5, 32, 60]
+final list:    [60, 32, 5, 23, 87, 67, 45]
+```
 
-- You should loop the entire list, and push all the items (as you go) into a new list.
diff --git a/exercises/03-flip_list/app.py b/exercises/03-flip_list/app.py
index cf1ab123..d2f3e18b 100644
--- a/exercises/03-flip_list/app.py
+++ b/exercises/03-flip_list/app.py
@@ -1,3 +1,3 @@
-arr = [45, 67, 87, 23, 5,  32, 60]
+sample_list = [45, 67, 87, 23, 5, 32, 60]
 
-#your code below:
+# Your code below
diff --git a/exercises/03-flip_list/solution.hide.py b/exercises/03-flip_list/solution.hide.py
new file mode 100644
index 00000000..74b6590d
--- /dev/null
+++ b/exercises/03-flip_list/solution.hide.py
@@ -0,0 +1,8 @@
+sample_list = [45, 67, 87, 23, 5, 32, 60]
+
+# Your code below
+
+for i in range(len(sample_list) -1, -1, -1):
+    new_list.append(sample_list[i])
+
+print(new_list)
diff --git a/exercises/04-mixed_list/README.es.md b/exercises/04-mixed_list/README.es.md
index 2815c1b5..c364ac5f 100644
--- a/exercises/04-mixed_list/README.es.md
+++ b/exercises/04-mixed_list/README.es.md
@@ -1,17 +1,20 @@
-# `04` Lista mezclada
+# `04` Mixed list
 
 ## 📝 Instrucciones:
 
-1. Escribe una función para imprimir en la consola los tipos de los valores contenidos en la lista en cada posición.
+1. Escribe una función para imprimir en la consola los tipos de valores contenidos en la lista en cada posición.
 
 2. Puedes usar el bucle `for`.
 
-## Resultado esperado:
+## 💡 Pistas:
 
-```py
-La consola debería mostrar algo como esto:
+- Puedes usar la función `type()` de Python.
+
+- Recuerda que `len()` devuelve la longitud de tu lista.
 
+## 💻 Resultado esperado:
 
+```py
 
 
 
@@ -21,8 +24,4 @@ La consola debería mostrar algo como esto:
 
 ```
 
-## 💡 Pista:
-
-- Puedes usar la función `type()` de python.
 
-- Recuerda que `len()` devuelve la longitud de tu lista.
diff --git a/exercises/04-mixed_list/README.md b/exercises/04-mixed_list/README.md
index 964fddf5..39a79548 100644
--- a/exercises/04-mixed_list/README.md
+++ b/exercises/04-mixed_list/README.md
@@ -6,15 +6,19 @@ tutorial: "https://www.youtube.com/watch?v=tJ-si9lRkUc"
 
 ## 📝 Instructions:
 
-1. Write a function to programmatically print in the console the types of the values that the list contains in each position.
+1. Write a function to programmatically print in the console the types of values that the list contains in each position.
 
-2. You can use the `for` loop.
+2. You can use a `for` loop.
 
-## Expected result:
+## 💡 Hints:
 
-```py
-The console must have something like this:
+- You can use the `type()` Python function.
+
+- Remember that `len()` returns the length of your list.
+
+## 💻 Expected result:
 
+```py
 
 
 
@@ -24,8 +28,3 @@ The console must have something like this:
 
 ```
 
-## 💡 Hint:
-
-- You can use the `type()` python function.
-
-- Remember that `len()` return the large of your list.
diff --git a/exercises/04-mixed_list/app.py b/exercises/04-mixed_list/app.py
index 4f9e71f4..3aab4234 100644
--- a/exercises/04-mixed_list/app.py
+++ b/exercises/04-mixed_list/app.py
@@ -1,3 +1,3 @@
 mix = [42, True, "towel", [2,1], 'hello', 34.4, {"name": "juan"}]
 
-# Your code below:
+# Your code below
diff --git a/exercises/04-mixed_list/solution.hide.py b/exercises/04-mixed_list/solution.hide.py
new file mode 100644
index 00000000..fdc52657
--- /dev/null
+++ b/exercises/04-mixed_list/solution.hide.py
@@ -0,0 +1,6 @@
+mix = [42, True, "towel", [2,1], 'hello', 34.4, {"name": "juan"}]
+
+# Your code below
+
+for item in mix:
+    print(type(item))
diff --git a/exercises/04-mixed_list/test.py b/exercises/04-mixed_list/test.py
index c4e29787..4b94a1b8 100644
--- a/exercises/04-mixed_list/test.py
+++ b/exercises/04-mixed_list/test.py
@@ -2,13 +2,13 @@
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
 
-@pytest.mark.it("Print the types of items from list")
+@pytest.mark.it("Print the types of values from list")
 def test_find(capsys, app):
     import app
     captured = capsys.readouterr()
     assert "\n\n\n\n\n\n\n" in captured.out
 
-@pytest.mark.it("Use the for in loop")
+@pytest.mark.it("Use the for loop")
 def test_for_loop():
     with open(path, 'r') as content_file:
         content = content_file.read()
@@ -20,4 +20,4 @@ def test_type():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"type")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
diff --git a/exercises/04.1-count_on/README.es.md b/exercises/04.1-count_on/README.es.md
index cdf6d5ee..5f48f999 100644
--- a/exercises/04.1-count_on/README.es.md
+++ b/exercises/04.1-count_on/README.es.md
@@ -1,18 +1,22 @@
-# `04.1` Contando
+# `04.1` Count On
 
-Como has visto en el ejercicio anterior tu lista puede ser un a mezcla de `tipos de datos` que vamos a dividir y conquistar.
+Como has visto en el ejercicio anterior, tu lista puede ser una mezcla de diferentes tipos de datos.
 
-¿Serías tan amable de añadir todos los elementos con *data-type* `dict` y `list` dentro de la lista `hello`?
+¿Serías tan amable de añadir todos los elementos con tipo de dato `dict` y `list` de la lista `my_list` en una nueva lista llamada `new_list`?
 
 ## 📝 Instrucciones:
 
-1. Itera la lista dada.
+1. Itera la lista dada (`my_list`).
 
-2. Mete los tipos de datos encontrados en una nueva lista llamada `hello`.
+2. Mete los tipos de datos `dict` y `list` encontrados en una nueva lista llamada `new_list`.
 
-3. Imprime la variable `hello`.
+3. Imprime la variable `new_list`.
 
-## 💡 Pista:
+## 💡 Pistas:
+
++ Recuerda que puedes saber el tipo de dato de una variable o valor con la función `type()`
+
++ Para más información sobre la función `type()`: https://www.w3schools.com/python/ref_func_type.asp
 
 Así es como puedes imprimir TODOS los elementos:
 
@@ -22,7 +26,8 @@ my_list = [42, true, "towel", [2,1], 'hello', 34.4, {"name": "juan"}]
 for x in my_list:
     print(x)
 ```
-## Resultado esperado:
+
+## 💻 Resultado esperado:
 
 ```py
 [[2, 1], {'name': 'juan'}]
diff --git a/exercises/04.1-count_on/README.md b/exercises/04.1-count_on/README.md
index d3d8c65d..b6fc0ae8 100644
--- a/exercises/04.1-count_on/README.md
+++ b/exercises/04.1-count_on/README.md
@@ -1,18 +1,22 @@
 # `04.1` Count On
 
-As you saw in the last exercise your list can be a mix `types of data` we are going to divide and conquer.
+As you saw in the last exercise, your list can be a mix of different types of data.
 
-Would you be so kind to add all the items with data-type `dict` and `list` into the hello list?
+Would you be so kind to add all the items with data-type `dict` and `list` of the list named `my_list` into a new list named `new_list`?
 
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Loop the given list.
 
-2. Push the data-types found to an new list called `hello`.
+2. Push the data-types `dict` and `list` found to a new list called `new_list`.
 
-3. Print the variable `hello`.
+3. Print the variable `new_list`.
 
-## 💡 Hint :
+## 💡 Hints:
+
++ Remember that you can know the data-type of a variable or value with the function `type()`.
+
++ Check this link for more information about the `type()` function: https://www.w3schools.com/python/ref_func_type.asp
 
 Here is how to print ALL the items.
 
@@ -23,7 +27,7 @@ for x in my_list:
     print(x)
 ```
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 [[2, 1], {'name': 'juan'}]
diff --git a/exercises/04.1-count_on/app.py b/exercises/04.1-count_on/app.py
index 1384dfe0..c02ec494 100644
--- a/exercises/04.1-count_on/app.py
+++ b/exercises/04.1-count_on/app.py
@@ -1,7 +1,3 @@
-
 my_list = [42, True, "towel", [2,1], 'hello', 34.4, {"name": "juan"}]
 
-
-#your code go here:
-
-print(hello)
+# Your code here
diff --git a/exercises/04.1-count_on/solution.hide.py b/exercises/04.1-count_on/solution.hide.py
new file mode 100644
index 00000000..a64b0142
--- /dev/null
+++ b/exercises/04.1-count_on/solution.hide.py
@@ -0,0 +1,10 @@
+my_list = [42, True, "towel", [2,1], 'hello', 34.4, {"name": "juan"}]
+
+# Your code here
+new_list = []
+
+for item in my_list:
+    if type(item) == dict or type(item) == list:
+        new_list.append(item)
+
+print(new_list)
diff --git a/exercises/04.1-count_on/test.py b/exercises/04.1-count_on/test.py
index fa4f24b1..00a7909f 100644
--- a/exercises/04.1-count_on/test.py
+++ b/exercises/04.1-count_on/test.py
@@ -1,23 +1,38 @@
-import io, sys, os, pytest, re
+import io, sys, os, pytest, re, app
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Cool !!! 😎 You have the all data-type object")
-def test_all_data_type(capsys, app):
-    app()
-    captured = capsys.readouterr()
-    assert "[[2, 1], {'name': 'juan'}]\n" in captured.out
+@pytest.mark.it("The variable 'new_list' should exist")
+def test_variable_exists():
+    assert app.new_list != None
 
-@pytest.mark.it("Use the for loop")
+@pytest.mark.it("The variable 'new_list' should contain data-types of 'dict' and 'list'")
+def test_variable_value():
+    assert app.new_list == [[2, 1], {'name': 'juan'}]
+
+@pytest.mark.it("You have to use a for loop")
 def test_for_loop():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"for(\s)")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("You have to use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"if(\s)")
         assert bool(regex.search(content)) == True
 
+@pytest.mark.it("You should use print()")
+def test_print():
+    with open(path, 'r') as content_file:
+        content = content_file.read()
+        regex = re.compile(r"print\(new_list\)")
+        assert bool(regex.search(content)) == True
+
+@pytest.mark.it("You have to print the value of the variable 'new_list' in the console")
+def test_all_data_type(capsys, app):
+    app()
+    captured = capsys.readouterr()
+
+    assert "[[2, 1], {'name': 'juan'}]\n" in captured.out
diff --git a/exercises/05-Sum_all_items/README.es.md b/exercises/05-Sum_all_items/README.es.md
index e2c33cb2..ae46a6b6 100644
--- a/exercises/05-Sum_all_items/README.es.md
+++ b/exercises/05-Sum_all_items/README.es.md
@@ -1,13 +1,15 @@
-
-# `05` Sumar todos los elementos
+# `05` Sum all items
 
 ## 📝 Instrucciones:
 
-1. Completa el código de la función `sum` para que devuelva la suma de todos los elementos en la lista `my_sample_list`.
+1. Completa el código de la función `sum_all_values` para que devuelva la suma de todos los elementos en la lista `my_sample_list`.
 
-```py
-El resultado debería ser 925960
-```
 ## 💡 Pista:
 
-+ Tienes que `iterar la lista entera` y sumar el valor de cada elemento en la variable `total`.
\ No newline at end of file
++ Tienes que iterar la lista entera y sumar el valor de cada elemento en la variable `total`.
+
+## 💻 Resultado esperado:
+
+```py
+925960
+```
diff --git a/exercises/05-Sum_all_items/README.md b/exercises/05-Sum_all_items/README.md
index 0047c3ed..3acd36ea 100644
--- a/exercises/05-Sum_all_items/README.md
+++ b/exercises/05-Sum_all_items/README.md
@@ -1,13 +1,16 @@
 
 # `05` Sum all items
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Complete the code of the function `sum` so that it returns the sum of all the items in `my_sample_list`.
+1. Complete the code of the function `sum_all_values` so that it returns the sum of all the items in `my_sample_list`.
+
+## 💡 Hint:
+
++ You have to loop the entire list and add the value of each item into the `total` variable.
+
+## 💻 Expected Result:
 
 ```py
-The result should be 925960
+925960
 ```
-## 💡Hint:
-
-+ You have to `loop the entire list` and add the value of each item into the "total" variable.
\ No newline at end of file
diff --git a/exercises/05-Sum_all_items/app.py b/exercises/05-Sum_all_items/app.py
index c9d38ec2..26582cb2 100644
--- a/exercises/05-Sum_all_items/app.py
+++ b/exercises/05-Sum_all_items/app.py
@@ -1,11 +1,10 @@
 my_sample_list = [3423,5,4,47889,654,8,867543,23,48,5345,234,6,78,54,23,67,3,6,432,55,23,25,12]
 
-
-def sum_all_values(items):
-
-    total= 0
-    #The magic happens here:
-   
-
+def sum_all_values(list):
+    total = 0
+    # The magic happens here
+    
+    
     return total
-print(sum_all_values(my_sample_list))
\ No newline at end of file
+    
+print(sum_all_values(my_sample_list))
diff --git a/exercises/05-Sum_all_items/solution.hide.py b/exercises/05-Sum_all_items/solution.hide.py
new file mode 100644
index 00000000..cc5fb24d
--- /dev/null
+++ b/exercises/05-Sum_all_items/solution.hide.py
@@ -0,0 +1,11 @@
+my_sample_list = [3423,5,4,47889,654,8,867543,23,48,5345,234,6,78,54,23,67,3,6,432,55,23,25,12]
+
+def sum_all_values(list):
+    total = 0
+    # The magic happens here
+    for i in list:
+        total += i
+    
+    return total
+    
+print(sum_all_values(my_sample_list))
diff --git a/exercises/05.1-sum_odd_items/README.es.md b/exercises/05.1-sum_odd_items/README.es.md
index cf5b8e62..a4b85899 100644
--- a/exercises/05.1-sum_odd_items/README.es.md
+++ b/exercises/05.1-sum_odd_items/README.es.md
@@ -1,22 +1,19 @@
-# `05.1` Suma los números impares
-
+# `05.1` Sum the odd numbers
 
 ## 📝 Instrucciones:
 
-1. Crea una función llamada `sumOdds` que sume todos los números impares en la variable `arr`.
-
-2. Devuleve e imprime el resultado.
+1. Crea una función llamada `sum_odds` que sume todos los números impares en la variable `my_list`.
 
-## 💡 Pista:
+2. Devuelve e imprime el resultado.
 
-- Debes declarar una variable auxiliar fuera del bucle para llevar la suma de valores.
+## 💡 Pistas:
 
-- Crea una función.
+- Debes declarar una **variable auxiliar** fuera del bucle para llevar la suma de valores.
 
 - Tienes que iterar la lista.
 
-- En cada iteración, tienes que preguntar en esa posición de la lista es un número impar.
+- En cada iteración, tienes que preguntar en esa posición de la lista si es un número impar.
 
-- Si es impar, entonces añádelo a la **variable auxiliar**.
+- Si es impar, entonces súmalo en la **variable auxiliar**.
 
-- Una **variable auxiliar** es una variable como cualquier otra, la única diferencia es una diferencia lógica. Una **variable auxiliar** será útil hasta que complete su propósito (sumar todos los valores, hacer una copia de un valor, etc).
+- Una **variable auxiliar** es una variable como cualquier otra, la única diferencia es una diferencia lógica. Una **variable auxiliar** será útil hasta que complete su propósito (sumar todos los valores, hacer una copia de un valor, etc.).
diff --git a/exercises/05.1-sum_odd_items/README.md b/exercises/05.1-sum_odd_items/README.md
index 7674a1dd..5aea6603 100644
--- a/exercises/05.1-sum_odd_items/README.md
+++ b/exercises/05.1-sum_odd_items/README.md
@@ -1,21 +1,19 @@
 # `05.1` Sum the odd numbers
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Create a function called sumOdds that sums all the odd numbers in the `arr` variable.
+1. Create a function called `sum_odds` that sums all the odd numbers in the `my_list` variable.
 
-2. Returns and print the result.
+2. Return and print the result.
 
-## 💡 Hint:
+## 💡 Hints:
 
-- You will need to declare an **auxiliar variable** outside the loop to keep adding the values.
-
-- Create a function.
+- You will need to declare an **auxiliary variable** outside the loop to keep adding the values.
 
 - You have to loop the list.
 
 - On each loop, you have to ask if the value of the list in that index position is an odd number.
 
-- If its odd then add the value to the **auxiliar variable**.
+- If its odd, then add the value to the **auxiliary variable**.
 
-- An **auxiliar variable** is a regular variable, the only difference is a logical difference; an **auxiliar variable** is like a chosen one, it'll be useful until it completes its purpose (add all the values, make a copy of a value, etc).
+- An **auxiliary variable** is a regular variable, the only difference is a logical difference; an **auxiliary variable** is like a chosen one, it'll be useful until it completes its purpose (add all the values, make a copy of a value, etc.).
diff --git a/exercises/05.1-sum_odd_items/app.py b/exercises/05.1-sum_odd_items/app.py
index 14562204..c6f86a84 100644
--- a/exercises/05.1-sum_odd_items/app.py
+++ b/exercises/05.1-sum_odd_items/app.py
@@ -1,5 +1,3 @@
-arr = [4,5,734,43,45,100,4,56,23,67,23,58,45]
-
-#Your code go here:
-
+my_list = [4,5,734,43,45,100,4,56,23,67,23,58,45]
 
+# Your code here
diff --git a/exercises/05.1-sum_odd_items/solution.hide.py b/exercises/05.1-sum_odd_items/solution.hide.py
new file mode 100644
index 00000000..0d118f68
--- /dev/null
+++ b/exercises/05.1-sum_odd_items/solution.hide.py
@@ -0,0 +1,12 @@
+my_list = [4,5,734,43,45,100,4,56,23,67,23,58,45]
+
+# Your code here
+def sum_odds(list):
+    odd_sum = 0
+
+    for num in list:
+        if num % 2 != 0:
+            odd_sum += num
+    return odd_sum
+
+print(sum_odds(my_list))
diff --git a/exercises/05.1-sum_odd_items/test.py b/exercises/05.1-sum_odd_items/test.py
index 8253dd65..533ec9cf 100644
--- a/exercises/05.1-sum_odd_items/test.py
+++ b/exercises/05.1-sum_odd_items/test.py
@@ -1,9 +1,8 @@
 import io, sys, os, pytest, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-
-@pytest.mark.it("Print the odd number")
-def test_odd_numbers(capsys, app):
+@pytest.mark.it("Print the sum of all odd numbers")
+def test_odd_numbers(capsys):
     import app
     captured = capsys.readouterr()
     assert "251\n" in captured.out
@@ -13,4 +12,12 @@ def test_for_loop():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"for(\s)")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
+
+@pytest.mark.it("sum_odds function should exist")
+def test_function_exists():
+    import app
+    try:
+        assert app.sum_odds
+    except:
+        raise AttributeError("The function 'sum_odds' should exist")
diff --git a/exercises/06-Print_by_condition/README.es.md b/exercises/06-Print_by_condition/README.es.md
new file mode 100644
index 00000000..0f22a049
--- /dev/null
+++ b/exercises/06-Print_by_condition/README.es.md
@@ -0,0 +1,11 @@
+# `06` Loop and print by condition
+
+Es posible recorrer una lista usando un bucle `for` especificando además qué hacer en cada iteración del bucle.
+
+## 📝 Instrucciones:
+
+1. Por favor, modifica el código para imprimir solo los números **divisibles entre 14**.
+
+## 💡 Pista:
+
++ Un número x es divisible entre 2 si: `(x % 2 == 0)`
diff --git a/exercises/06-Print_by_condition/README.md b/exercises/06-Print_by_condition/README.md
new file mode 100644
index 00000000..b5c3266f
--- /dev/null
+++ b/exercises/06-Print_by_condition/README.md
@@ -0,0 +1,11 @@
+# `06` Loop and print by condition
+
+It is possible to traverse a list using a `for` loop, also specifying what to do on each iteration of the loop.
+
+## 📝 Instructions:
+
+1. Please modify the code to print only the numbers **divisible by 14**.
+
+## 💡 Hint:
+
++ A number x is divisible by 2 if: `(x % 2 == 0)`
diff --git a/exercises/06-forEach_loop/app.py b/exercises/06-Print_by_condition/app.py
similarity index 83%
rename from exercises/06-forEach_loop/app.py
rename to exercises/06-Print_by_condition/app.py
index 513aad92..de6e8f61 100644
--- a/exercises/06-forEach_loop/app.py
+++ b/exercises/06-Print_by_condition/app.py
@@ -1,8 +1,6 @@
 my_list = [3344,34334,454543,342534,4563456,3445,23455,234,262,2335,43323,4356,345,4545,452,345,434,36,345,4334,5454,345,4352,23,365,345,47,63,425,6578759,768,834,754,35,32,445,453456,56,7536867,3884526,4234,35353245,53244523,566785,7547,743,4324,523472634,26665,63432,54645,32,453625,7568,5669576,754,64356,542644,35,243,371,3251,351223,13231243,734,856,56,53,234342,56,545343]
 
 
-for numb in my_list:
-    #the magic go here:
-   
-        print(numb)
-    
\ No newline at end of file
+for i in my_list:
+    # The magic happens here
+    
diff --git a/exercises/06-Print_by_condition/solution.hide.py b/exercises/06-Print_by_condition/solution.hide.py
new file mode 100644
index 00000000..60fd12df
--- /dev/null
+++ b/exercises/06-Print_by_condition/solution.hide.py
@@ -0,0 +1,7 @@
+my_list = [3344,34334,454543,342534,4563456,3445,23455,234,262,2335,43323,4356,345,4545,452,345,434,36,345,4334,5454,345,4352,23,365,345,47,63,425,6578759,768,834,754,35,32,445,453456,56,7536867,3884526,4234,35353245,53244523,566785,7547,743,4324,523472634,26665,63432,54645,32,453625,7568,5669576,754,64356,542644,35,243,371,3251,351223,13231243,734,856,56,53,234342,56,545343]
+
+
+for i in my_list:
+    # The magic happens here
+    if (i % 14 == 0):
+        print(i)
diff --git a/exercises/06-forEach_loop/test.py b/exercises/06-Print_by_condition/test.py
similarity index 87%
rename from exercises/06-forEach_loop/test.py
rename to exercises/06-Print_by_condition/test.py
index de43aab0..ec4c4c47 100644
--- a/exercises/06-forEach_loop/test.py
+++ b/exercises/06-Print_by_condition/test.py
@@ -14,9 +14,9 @@ def test_for_loop():
         regex = re.compile(r"for(\s)")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"if(\s)")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
diff --git a/exercises/06-forEach_loop/README.es.md b/exercises/06-forEach_loop/README.es.md
deleted file mode 100644
index b2e9d575..00000000
--- a/exercises/06-forEach_loop/README.es.md
+++ /dev/null
@@ -1,13 +0,0 @@
-# `06` Bucle `ForEach`
-
-Es posible recorrer una lista usando un bucle de la función for. Tú tienes que especificar qué hacer en cada iteración del bucle.
-
-## 📝 Instrucciones:
-
-Justo ahora, el código está imprimiendo todos los elementos en la lista.
-
- 1. Por favor, cambia el código para imprimir solo los números **divisibles entre 14**.
-
-## 💡 Pista:
-
-+ Un número X es divisible entre 2 si: `(X % 2 === 0)`
diff --git a/exercises/06-forEach_loop/README.md b/exercises/06-forEach_loop/README.md
deleted file mode 100644
index b2bab6df..00000000
--- a/exercises/06-forEach_loop/README.md
+++ /dev/null
@@ -1,14 +0,0 @@
-# `06` ForEach loop
-
-It is possible to traverse a list using a `for` loop. You have to specify what to do on each iteration of the loop.
-
-## 📝Instructions:
-
-Right now, the code is printing all the items in the list.
-
- 1. Please change the function code to print only
- the numbers **divisible by 14**.
-
-## 💡 Pista:
-
-+ A number x is divisible by 2 if: `(x % 2 === 0)`
diff --git a/exercises/06.1-Everything_is_awesome/README.es.md b/exercises/06.1-Everything_is_awesome/README.es.md
index bcf1dc18..0f09e832 100644
--- a/exercises/06.1-Everything_is_awesome/README.es.md
+++ b/exercises/06.1-Everything_is_awesome/README.es.md
@@ -1,18 +1,19 @@
-# `06.1` Todo es asombroso
+# `06.1` Everything is Awesome
 
-## Instrucciones:
+## 📝 Instrucciones:
 
-1. Compara el elemento. Si es 1 mete el número en la lista `new_list`.
+1. Compara el elemento. Si es `1`, añade el número en la lista `new_list`.
 
-2. Compara el elemento. Si es `0` mete "Yahoo" en la lista `new_list`, en lugar del número.
-## Ejemplo:
+2. Compara el elemento. Si es `0`, añade `Yahoo` en la lista `new_list`, en lugar del número.
+
+## 💻 Resultado esperado:
 
 ```py
 Ejemplo de salida para [0,0,1,1,0]:
 
-Yahoo,
-Yahoo,
+'Yahoo',
+'Yahoo',
 1,
 1,
-Yahoo
-```
\ No newline at end of file
+'Yahoo'
+```
diff --git a/exercises/06.1-Everything_is_awesome/README.md b/exercises/06.1-Everything_is_awesome/README.md
index 2a575f58..64174100 100644
--- a/exercises/06.1-Everything_is_awesome/README.md
+++ b/exercises/06.1-Everything_is_awesome/README.md
@@ -1,17 +1,19 @@
 # `06.1` Everything is Awesome
 
-## Instructions:
+## 📝 Instructions:
 
-1. Compare the item if it is 1 push the number to the list `new_list`.
+1. Compare the item; if it is `1`, push the number to the list `new_list`.
 
-2. Compare the item if it is 0 push `Yahoo` to the list `new_list` (instead of the number).
+2. Compare the item; if it is `0`, push `Yahoo` to the list `new_list` (instead of the number).
+
+## 💻 Expected Result:
 
 ```py
 Example output for [0,0,1,1,0]:
 
-Yahoo,
-Yahoo,
+'Yahoo',
+'Yahoo',
 1,
 1,
-Yahoo
-```
\ No newline at end of file
+'Yahoo'
+```
diff --git a/exercises/06.1-Everything_is_awesome/app.py b/exercises/06.1-Everything_is_awesome/app.py
index a50ac8b9..4c3d0c26 100644
--- a/exercises/06.1-Everything_is_awesome/app.py
+++ b/exercises/06.1-Everything_is_awesome/app.py
@@ -1,11 +1,11 @@
-my_list = [ 1, 0, 0, 0, 1, 0, 0, 0, 1, 1 ]
+my_list = [1, 0, 0, 0, 1, 0, 0, 0, 1, 1]
 
 def my_function(numbers):
     new_list = []
-    for numb in numbers:
-    #The magic go here:
+    for i in numbers:
+        # The magic happens here
+        
         
     return new_list
+    
 print(my_function(my_list))
-
-
diff --git a/exercises/06.1-Everything_is_awesome/solution.hide.py b/exercises/06.1-Everything_is_awesome/solution.hide.py
new file mode 100644
index 00000000..f3c87253
--- /dev/null
+++ b/exercises/06.1-Everything_is_awesome/solution.hide.py
@@ -0,0 +1,14 @@
+my_list = [1, 0, 0, 0, 1, 0, 0, 0, 1, 1]
+
+def my_function(numbers):
+    new_list = []
+    for i in numbers:
+        # The magic happens here
+        if (i == 0):
+            new_list.append("Yahoo")
+        elif(i == 1):
+            new_list.append(1)
+            
+    return new_list
+    
+print(my_function(my_list))
diff --git a/exercises/07-Do_while/README.es.md b/exercises/07-Do_while/README.es.md
index 6b82c54b..97e3f294 100644
--- a/exercises/07-Do_while/README.es.md
+++ b/exercises/07-Do_while/README.es.md
@@ -1,8 +1,6 @@
-# `07` Hacer mientras
+# `07` Do While
 
-Hacer, hacer, hacer.
-
-La función `while()` es otro ejemplo de bucle en python es menos común usarla, pero es un bucle:
+La función `while()` es otro ejemplo de bucle en Python, es menos común usarla, pero es un bucle:
 
 ```py
 x = 1
@@ -13,15 +11,15 @@ while x < 6:
 
 ## 📝 Instrucciones:
 
-1. Imprime cada número de iteración en la cónsola desde el `20` a `0`, pero **concatena un signo de exclamación** a la salida si el número es un múltiplo  de `5`.
+1. Imprime cada iteración en la consola de los números del `20` al `1`, pero **concatena un signo de exclamación** si el número es múltiplo de 5.
 
-2. al final imrpime `LIFTOFF`.
+2. Al final imprime `LIFTOFF`.
 
 ## 💡 Pista:
 
 + https://www.w3schools.com/python/python_while_loops.asp
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 Ejemplo de salida en la consola:
@@ -39,6 +37,7 @@ Ejemplo de salida en la consola:
 10!
 .
 .
+1
 LIFTOFF
 ```
 
diff --git a/exercises/07-Do_while/README.md b/exercises/07-Do_while/README.md
index 5c36cbb6..f711910b 100644
--- a/exercises/07-Do_while/README.md
+++ b/exercises/07-Do_while/README.md
@@ -1,7 +1,6 @@
-# `07` D0 While
+# `07` Do While
 
-DO DO DO
-The do while() is another loop example in python is less commonly used but it is a loop.
+DO DO DO. The `while()` function is another loop example in Python and is less commonly used, but it is still a loop.
 
 ```py
 x = 1
@@ -12,15 +11,15 @@ while x < 6:
 
 ## 📝 Instructions:
 
-1. Print every iteration number on the console from 20 to 0, but **concatenate an exclamation point** to the output if the number is a multiple of 5.
+1. Print every iteration number on the console from `20` to `1`, but **concatenate an exclamation mark** to the output if the number is a multiple of 5.
 
-2. At the end print() `LIFTOFF`.
+2. At the end print `LIFTOFF`.
 
 ## 💡 Hint:
 
 + https://www.w3schools.com/python/python_while_loops.asp
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 Example Output on the console:
@@ -38,6 +37,7 @@ Example Output on the console:
 10!
 .
 .
+1
 LIFTOFF
 ```
 
diff --git a/exercises/07-Do_while/app.py b/exercises/07-Do_while/app.py
index 5a8b0ad3..fce62c1d 100644
--- a/exercises/07-Do_while/app.py
+++ b/exercises/07-Do_while/app.py
@@ -1,2 +1 @@
-
-#Your code go here:
+# Your code here
diff --git a/exercises/07-Do_while/solution.hide.py b/exercises/07-Do_while/solution.hide.py
new file mode 100644
index 00000000..786d3331
--- /dev/null
+++ b/exercises/07-Do_while/solution.hide.py
@@ -0,0 +1,12 @@
+# Your code here
+
+number = 20
+
+while number >= 1:
+    if number % 5 == 0:
+        print(str(number) + "!")
+    else:
+        print(number)
+    number -= 1
+
+print("LIFTOFF")
diff --git a/exercises/07-Do_while/test.py b/exercises/07-Do_while/test.py
index cadd9b67..58f23923 100644
--- a/exercises/07-Do_while/test.py
+++ b/exercises/07-Do_while/test.py
@@ -1,7 +1,7 @@
 import io, sys, os, pytest, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("You have a good list numbers with exclamation sign!!! 😃")
+@pytest.mark.it("The output should be as expected")
 def test_output(capsys, app):
     app()
     captured = capsys.readouterr()
@@ -12,10 +12,11 @@ def test_output(capsys, app):
 def test_for_loop():
     with open(path, 'r') as content_file:
         content = content_file.read()
-        regex = re.compile(r"while(\s)+[a-zA-Z\-_]+(\s)")
+        # regex = re.compile(r"while(\s)+[a-zA-Z\-_]+(\s)") only checks for one character before the space.
+        regex = re.compile(r"while(\s)\S*")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
diff --git a/exercises/08-Delete_element/README.es.md b/exercises/08-Delete_element/README.es.md
index 971930ee..f96a25e4 100644
--- a/exercises/08-Delete_element/README.es.md
+++ b/exercises/08-Delete_element/README.es.md
@@ -1,17 +1,17 @@
-# `08` Borrar un elemento
+# `08` Delete element
 
-La unica forma de borrar a `Daniella` de la lista (sin trampas)
-será crear una nueva lista con todas las demás personas, excepto Daniella.
+La única forma de borrar a `Daniella` de la lista (sin trampas) sería crear una nueva lista con todas las demás personas, excepto `Daniella`.
 
 ## 📝 Instrucciones:
 
-1. Por favor, crea una función `deletePerson` que elimina a una persona dada de una lista y devuelve una nueva lista sin esa persona.
+1. Por favor, crea una función `delete_person` que elimine a una persona dada de una lista y devuelva una nueva lista sin esa persona.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
  ```py
- Resultado:
- ['juan', 'ana', 'michelle', 'stefany', 'lucy', 'barak']
+Resultado:
+
+['juan', 'ana', 'michelle', 'stefany', 'lucy', 'barak']
 ['ana', 'michelle', 'daniella', 'stefany', 'lucy', 'barak']
 ['juan', 'ana', 'michelle', 'daniella', 'stefany', 'lucy', 'barak']
-```
\ No newline at end of file
+```
diff --git a/exercises/08-Delete_element/README.md b/exercises/08-Delete_element/README.md
index eeb58302..d3da0ed5 100644
--- a/exercises/08-Delete_element/README.md
+++ b/exercises/08-Delete_element/README.md
@@ -1,16 +1,17 @@
 # `08` Delete element
 
-The only way to delete `Daniella` from the list (without cheating) will be to create a new list with all the other people but `Daniella`.
+The only way to delete `Daniella` from the list (without cheating) would be to create a new list with all the other people but `Daniella`.
 
 ## 📝 Instructions:
 
-1. Please create a `deletePerson` function that deletes any given person from the list and returns a new list without that person.
+1. Please create a `delete_person` function that deletes any given person from the list and returns a new list without that person.
 
-## Expected result:
+## 💻 Expected result:
 
  ```py
- Result:
- ['juan', 'ana', 'michelle', 'stefany', 'lucy', 'barak']
+Result:
+
+['juan', 'ana', 'michelle', 'stefany', 'lucy', 'barak']
 ['ana', 'michelle', 'daniella', 'stefany', 'lucy', 'barak']
 ['juan', 'ana', 'michelle', 'daniella', 'stefany', 'lucy', 'barak']
-```
\ No newline at end of file
+```
diff --git a/exercises/08-Delete_element/app.py b/exercises/08-Delete_element/app.py
index 0538c11b..36514c4d 100644
--- a/exercises/08-Delete_element/app.py
+++ b/exercises/08-Delete_element/app.py
@@ -1,9 +1,11 @@
 people = ['juan','ana','michelle','daniella','stefany','lucy','barak']
 
-#Your code go here:
-def deletePerson(person_name):
-    #Your code go here:
+def delete_person(person_name):
+    # Your code here
     
-print(deletePerson("daniella"))
-print(deletePerson("juan"))
-print(deletePerson("emilio"))
\ No newline at end of file
+
+    
+# Don't delete anything below
+print(delete_person("daniella"))
+print(delete_person("juan"))
+print(delete_person("emilio"))
diff --git a/exercises/08-Delete_element/solution.hide.py b/exercises/08-Delete_element/solution.hide.py
new file mode 100644
index 00000000..e5da36c9
--- /dev/null
+++ b/exercises/08-Delete_element/solution.hide.py
@@ -0,0 +1,15 @@
+people = ['juan','ana','michelle','daniella','stefany','lucy','barak']
+
+def delete_person(person_name):
+    # Your code here
+    updated_people = list(people)
+
+    if person_name in updated_people:
+        updated_people.remove(person_name)
+    
+    return updated_people
+    
+# Don't delete anything below
+print(delete_person("daniella"))
+print(delete_person("juan"))
+print(delete_person("emilio"))
diff --git a/exercises/08-Delete_element/test.py b/exercises/08-Delete_element/test.py
index 27122e1e..c38dbfbd 100644
--- a/exercises/08-Delete_element/test.py
+++ b/exercises/08-Delete_element/test.py
@@ -14,9 +14,9 @@ def test_for_loop():
         regex = re.compile(r"for(\s)")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"if(\s)")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
diff --git a/exercises/08.1-Merge_list/README.es.md b/exercises/08.1-Merge_list/README.es.md
index 098c8fcf..80665a38 100644
--- a/exercises/08.1-Merge_list/README.es.md
+++ b/exercises/08.1-Merge_list/README.es.md
@@ -1,27 +1,27 @@
-# `08.1` Fusionar listas:
-
-Dado que vivimos en un nuevo mundo, no deberían haber colores ni etiquetas, ¿verdad?
+# `08.1` Merge List
 
 ## 📝 Instrucciones:
 
-Escribe una función que una dos listas y devuelva una nueva lista (`merge_list`) uniendo todos los valores de las dos listas.
+Escribe una función `merge_list` que una dos listas y devuelva una nueva lista uniendo todos los valores de las dos listas.
 
  1. Declara una lista vacía.
 
  2. Itera las dos listas.
 
- 3. Concatena los valores a la lista nueva (`merge_list`).
+ 3. Inserta los valores a la lista nueva.
+
+ 4. Imprime la nueva variable con las dos listas.
+
+## 💡 Pistas:
 
- 4. Imprime la variable con las dos listas.
++ Tendrás que iterar cada lista e insertar sus elementos en una nueva lista.
 
-## 💡 Pista:
++ Hay más formas para combinar listas en Python. Este es un buen momento para buscar en Internet "cómo combinar listas en python".
 
-- Tendrás que iterar cada lista e insertar sus elementos en una nueva lista.
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
- Salida esperada:
- ['Lebron', 'Aaliyah', 'Diamond', 'Dominique', 'Aliyah', 'Jazmin', 'Darnell', 'Lucas', 'Jake', 'Scott', 'Amy', 'Molly', 'Hannah', 'Lucas']
+['Lebron', 'Aaliyah', 'Diamond', 'Dominique', 'Aliyah', 'Jazmin', 'Darnell', 'Lucas', 'Jake', 'Scott', 'Amy', 'Molly', 'Hannah', 'Lucas']
 ```
 
 
diff --git a/exercises/08.1-Merge_list/README.md b/exercises/08.1-Merge_list/README.md
index b2efd307..4ad1c73f 100644
--- a/exercises/08.1-Merge_list/README.md
+++ b/exercises/08.1-Merge_list/README.md
@@ -1,27 +1,26 @@
-# `08.1` Merge List:
+# `08.1` Merge List
 
-Since we live in a new world, there should be no colors or labels, right?
+## 📝 Instructions:
 
-## 📝Instructions:
-
-Write a function that merges two list and returns a single new list (`merge_list`) merging all the values of both lists.
+Write a function `merge_list` that merges two lists and returns a single new list merging all the values of both lists.
 
  1. Declare an empty list.
 
- 2. Loop the two list.
+ 2. Loop the two lists.
+
+ 3. Append the results into an empty list.
 
- 3. Concatenate the result in an empty lists.
+ 4. Print the new variable with the merged lists.
 
- 4. Print the variable with two list.
+ ## 💡 Hints:
 
- ## 💡 Hint:
++ You will have to loop through each list and insert their items into a new list.
 
-- You will have to loop through each list and insert their items into a new list.
++ There are more ways to merge lists in Python. This would be a good time for you to search on the Internet "how to merge lists in python".
 
- ## Expected result:
+ ## 💻 Expected result:
 
 ```py
- The console expected:
- ['Lebron', 'Aaliyah', 'Diamond', 'Dominique', 'Aliyah', 'Jazmin', 'Darnell', 'Lucas', 'Jake', 'Scott', 'Amy', 'Molly', 'Hannah', 'Lucas']
+['Lebron', 'Aaliyah', 'Diamond', 'Dominique', 'Aliyah', 'Jazmin', 'Darnell', 'Lucas', 'Jake', 'Scott', 'Amy', 'Molly', 'Hannah', 'Lucas']
 ```
 
diff --git a/exercises/08.1-Merge_list/app.py b/exercises/08.1-Merge_list/app.py
index 883dff97..6146f098 100644
--- a/exercises/08.1-Merge_list/app.py
+++ b/exercises/08.1-Merge_list/app.py
@@ -1,8 +1,9 @@
-chunk_one = [ 'Lebron', 'Aaliyah', 'Diamond', 'Dominique', 'Aliyah', 'Jazmin', 'Darnell' ]
-chunk_two = [ 'Lucas' , 'Jake','Scott','Amy', 'Molly','Hannah','Lucas']
+chunk_one = ['Lebron', 'Aaliyah', 'Diamond', 'Dominique', 'Aliyah', 'Jazmin', 'Darnell']
+chunk_two = ['Lucas', 'Jake', 'Scott', 'Amy', 'Molly', 'Hannah', 'Lucas']
 
 
 def merge_list(list1, list2):
-    #Your code go here:
+    # Your code here
+
     
 print(merge_list(chunk_one, chunk_two))
diff --git a/exercises/08.1-Merge_list/solution.hide.py b/exercises/08.1-Merge_list/solution.hide.py
new file mode 100644
index 00000000..91d523fb
--- /dev/null
+++ b/exercises/08.1-Merge_list/solution.hide.py
@@ -0,0 +1,16 @@
+chunk_one = ['Lebron', 'Aaliyah', 'Diamond', 'Dominique', 'Aliyah', 'Jazmin', 'Darnell']
+chunk_two = ['Lucas', 'Jake', 'Scott', 'Amy', 'Molly', 'Hannah', 'Lucas']
+
+
+def merge_list(list1, list2):
+    # Your code here
+    new_list = []
+    for i in list1:
+        new_list.append(i)
+    for i in list2:
+        new_list.append(i)
+    
+    return new_list
+    
+    
+print(merge_list(chunk_one, chunk_two))
diff --git a/exercises/08.2-Divide_and_conquer/README.es.md b/exercises/08.2-Divide_and_conquer/README.es.md
index aa39700f..563536be 100644
--- a/exercises/08.2-Divide_and_conquer/README.es.md
+++ b/exercises/08.2-Divide_and_conquer/README.es.md
@@ -1,26 +1,33 @@
-# `08.2` Divide y vencerás:
+# `08.2` Divide and conquer
 
 ## 📝 Instrucciones:
 
-1. Crea una función llamada `merge_two_list` que espere una lista números enteros.
+1. Crea una función llamada `sort_odd_even` que espere una lista de números enteros.
 
-2. Itera la lista y separa los números pares e impares en diferentes listas.
+2. Itera la lista y separa los números *pares* e *impares*.
 
-3. Si el número es impar colócalo en una lista llamada `odd`.
+3. Crea una lista vacía llamada `sorted_list` y empieza a insertar los números *impares*.
 
-4. Si el número es par colócalo en una lista llamada `even`.
+4. Si el número es par, colócalo en una lista llamada `even`.
 
-5. Luego concatena la lista `odd` y la lista `even` para combinarlas. Recuerda que la lista `odd` va primero y que debes añadirle la lista `even`.
+5. Luego concatena la lista `even` en `sorted_list`. Recuerda que los números *impares* van primero y luego debes añadirle la lista `even` después.
 
 ## 💡 Pista:
 
 + Crea variables vacías cuando necesites almacenar información.
 
-## Ejemplo:
++ Lee sobre el método `extend()`: https://www.w3schools.com/python/ref_list_extend.asp
+
+## 💻 Resultado esperado:
+
+Debe quedar todo dentro de una sola lista, no debe haber listas anidadas.
 
 ```py
-mergeTwoList([1,2,33,10,20,4])
+sort_odd_even([1, 2, 33, 10, 20, 4])
 
-[[1,33,2], [10,20,4]]
+[1, 33, 2, 10, 20, 4] # <-- Si
+[[1,33], [2,10,20,4]] # <-- No
 ```
 
+
+
diff --git a/exercises/08.2-Divide_and_conquer/README.md b/exercises/08.2-Divide_and_conquer/README.md
index 0c1a2962..dad03b80 100644
--- a/exercises/08.2-Divide_and_conquer/README.md
+++ b/exercises/08.2-Divide_and_conquer/README.md
@@ -1,25 +1,30 @@
-# `08.2` Divide and conquer:
+# `08.2` Divide and conquer
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Create a function called `merge_two_list` that expects an list of numbers (integers).
+1. Create a function called `sort_odd_even` that expects a list of numbers (integers).
 
-2. Loop through the list and separate the `odd` and the `even` numbers in different lists.
+2. Loop through the list and separate the *odd* and the *even* numbers.
 
-3. If the number is odd number push it to a placeholder list named `odd`.
+3. Create a variable called `sorted_list` to start appending the *odd* numbers.
 
-4. If the number is even number push it to a placeholder list named `even`.
+4. If the number is even, push it to a placeholder list named `even`.
 
-5. Then concatenate the `odd` list to the even list to combine them. Remember, the `odd` list comes first and you have to append the even `mergeTwoList`.
+5. Then insert the `even` list into the `sorted_list`. Remember, the *odd* numbers come first, and you have to insert the `even` list after.
 
-## 💡 Hint:
+## 💡 Hints:
 
 + Create empty (placeholder) variables when you need to store data.
 
-## Example:
++ Check out the `extend()` method: https://www.w3schools.com/python/ref_list_extend.asp
+
+## 💻 Expected result:
+
+Everything should be inside a single list; there should not be nested lists.
 
 ```py
-mergeTwoList([1,2,33,10,20,4])
+sort_odd_even([1, 2, 33, 10, 20, 4])
 
-[[1,33,2], [10,20,4]]
+[1, 33, 2, 10, 20, 4] # <-- Yes
+[[1,33], [2,10,20,4]] # <-- No
 ```
diff --git a/exercises/08.2-Divide_and_conquer/app.py b/exercises/08.2-Divide_and_conquer/app.py
index a584ec4a..106fd02b 100644
--- a/exercises/08.2-Divide_and_conquer/app.py
+++ b/exercises/08.2-Divide_and_conquer/app.py
@@ -1,8 +1,7 @@
-list_of_numbers = [4,	80,	85,	59,	37, 25, 5, 64, 66, 81, 20, 64, 41, 22, 76, 76, 55, 96, 2, 68]
+list_of_numbers = [4, 80, 85, 59, 37, 25, 5, 64, 66, 81, 20, 64, 41, 22, 76, 76, 55, 96, 2, 68]
 
+# Your code here
 
-#Your code here:
 
-
-print(merge_two_list(list_of_numbers))
+print(sort_odd_even(list_of_numbers))
 
diff --git a/exercises/08.2-Divide_and_conquer/solution.hide.py b/exercises/08.2-Divide_and_conquer/solution.hide.py
new file mode 100644
index 00000000..cd6e09e4
--- /dev/null
+++ b/exercises/08.2-Divide_and_conquer/solution.hide.py
@@ -0,0 +1,17 @@
+list_of_numbers = [4, 80, 85, 59, 37, 25, 5, 64, 66, 81, 20, 64, 41, 22, 76, 76, 55, 96, 2, 68]
+
+# Your code here
+def sort_odd_even(numbers):
+    sorted_list = []
+    even = []
+
+    for i in numbers:
+        if (i % 2 == 1):
+            sorted_list.append(i)
+        elif (i % 2 == 0):
+            even.append(i)
+
+    sorted_list.extend(even)
+    return sorted_list
+
+print(sort_odd_even(list_of_numbers))
diff --git a/exercises/08.2-Divide_and_conquer/test.py b/exercises/08.2-Divide_and_conquer/test.py
index 254ce639..9bb7c65d 100644
--- a/exercises/08.2-Divide_and_conquer/test.py
+++ b/exercises/08.2-Divide_and_conquer/test.py
@@ -1,11 +1,11 @@
 import io, sys, os, pytest, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Concatenate both lists. Remember the Odd list come first")
+@pytest.mark.it("Concatenate both lists. Remember the odd list comes first")
 def test_odd_even(capsys, app):
     import app
     captured = capsys.readouterr()
-    assert "[[85, 59, 37, 25, 5, 81, 41, 55], [4, 80, 64, 66, 20, 64, 22, 76, 76, 96, 2, 68]]\n" in captured.out
+    assert "[85, 59, 37, 25, 5, 81, 41, 55, 4, 80, 64, 66, 20, 64, 22, 76, 76, 96, 2, 68]\n" in captured.out
 
 @pytest.mark.it("Use the for loop")
 def test_for_loop():
@@ -14,16 +14,16 @@ def test_for_loop():
         regex = re.compile(r"for(\s)")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"if(\s)")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it('1. You should create a function named merge_two_list')
+@pytest.mark.it('You should create a function named sort_odd_even')
 def test_variable_exists(app):
     try:
-        app.merge_two_list
+        app.sort_odd_even
     except AttributeError:
-        raise AttributeError("The function 'merge_two_list' should exist on app.py")
\ No newline at end of file
+        raise AttributeError("The function 'sort_odd_even' should exist on app.py")
diff --git a/exercises/09-Max_integer_from_list/README.es.md b/exercises/09-Max_integer_from_list/README.es.md
index 0346e8e2..49b539fa 100644
--- a/exercises/09-Max_integer_from_list/README.es.md
+++ b/exercises/09-Max_integer_from_list/README.es.md
@@ -1,14 +1,20 @@
-# `09` Máximo entero en my_list
+# `09` Max integer from my_list
 
 ## 📝 Instrucciones:
 
-1. Escribe un script que encuentre el entero más grande la lista.
+1. Crea una función llamada `max_integer`. 
 
-2. Imprime ese número en la consola con al función `print()`.
+2. Esta función debe tomar una lista como parámetro de entrada y devolver el número máximo encontrado en la lista. 
 
-## 💡 Pista:
+3. Deberías usar un bucle `for` para recorrer la lista. 
 
-- Defina una variable auxiliar y establece su valor en 0.
+4. Utiliza la función `print()` para imprimir lo que devuelve la función al ser llamada. 
+
+    + Por ejemplo: `print(my_function(param))`
+
+## 💡 Pistas:
+
+- Defina una variable auxiliar y establece su valor como el primer elemento de la lista.
 
 - Compara la variable con todos los elementos de la lista.
 
@@ -16,8 +22,8 @@
 
 - Al final, tendrás el número más grande almacenado en la variable.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
- ```py
-Tu resultado debería ser 5435.
-```
\ No newline at end of file
+```py
+5435
+```
diff --git a/exercises/09-Max_integer_from_list/README.md b/exercises/09-Max_integer_from_list/README.md
index a327696b..f100cd55 100644
--- a/exercises/09-Max_integer_from_list/README.md
+++ b/exercises/09-Max_integer_from_list/README.md
@@ -1,23 +1,29 @@
 # `09` Max integer from my_list
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Write a script that finds the biggest integer in the list.
+1. Create a function named `max_integer`
 
-2. Print that number in the console with the `print()` function.
+2. This function should take a list as an input parameter and return the maximum number found in the list. 
 
-## 💡Hint:
+3. You should use a `for` loop to iterate through the list. 
 
-- Define an auxiliar variable and set the first value to `0`.
+4. Use the `print()` function to print what the function returns when it is called.
+  
+    + For example: `print(my_function(param))` 
 
-- Then compare the variables with all the items in the list.
+## 💡 Hints:
 
-- Replace the value every time the new element is bigger than the one stored in the auxiliar variable.
+- Define an auxiliary variable and set the first value to the first element on the list.
 
-- At the end you will have the biggest number stored in the variable.
+- Then compare the variable with all the items in the list.
 
-## Expected Result:
+- Replace the value every time the new element is bigger than the one stored in the auxiliary variable.
 
- ```py
-Your result should be 5435.
+- At the end, you will have the biggest number stored in the variable.
+
+## 💻 Expected result:
+
+```py
+5435
 ```
diff --git a/exercises/09-Max_integer_from_list/__pycache__/test.cpython-38-PYTEST.pyc b/exercises/09-Max_integer_from_list/__pycache__/test.cpython-38-PYTEST.pyc
deleted file mode 100644
index 8f8cb4c4..00000000
Binary files a/exercises/09-Max_integer_from_list/__pycache__/test.cpython-38-PYTEST.pyc and /dev/null differ
diff --git a/exercises/09-Max_integer_from_list/app.py b/exercises/09-Max_integer_from_list/app.py
index 98630f38..c0a5a543 100644
--- a/exercises/09-Max_integer_from_list/app.py
+++ b/exercises/09-Max_integer_from_list/app.py
@@ -1,3 +1,3 @@
 my_list = [43,23,6,87,43,1,4,6,3,67,8,3445,3,7,5435,63,346,3,456,734,6,34]
 
-#Your code go from here:
+# Your code here
diff --git a/exercises/09-Max_integer_from_list/solution.hide.py b/exercises/09-Max_integer_from_list/solution.hide.py
new file mode 100644
index 00000000..a605de60
--- /dev/null
+++ b/exercises/09-Max_integer_from_list/solution.hide.py
@@ -0,0 +1,12 @@
+my_list = [43,23,6,87,43,1,4,6,3,67,8,3445,3,7,5435,63,346,3,456,734,6,34]
+
+# Your code here
+def max_integer(list):
+    max_int = list[0]
+    
+    for i in range(len(list)):
+        if list[i] > max_int:
+            max_int = list[i]
+    return max_int
+
+print(max_integer(my_list))
diff --git a/exercises/09-Max_integer_from_list/test.py b/exercises/09-Max_integer_from_list/test.py
index a656a2e7..a010e2c8 100644
--- a/exercises/09-Max_integer_from_list/test.py
+++ b/exercises/09-Max_integer_from_list/test.py
@@ -1,12 +1,19 @@
 import io, sys, os, pytest, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
+@pytest.mark.it('The function max_integer must exist')
+def test_function_existence(capsys, app):
+    assert app.max_integer
 
-@pytest.mark.it("Max integer from the list")
+@pytest.mark.it("The function should return the maximum number from a list")
 def test_output(capsys, app):
-    app()
-    captured = capsys.readouterr()
-    assert "5435\n" in captured.out
+    result = app.max_integer([43,23,6,87,43,1,4,6,3,67,8,3445,3,7,5435,63,346,3,456,734,6,34])
+    assert result == 5435
+
+@pytest.mark.it("The function should work with other lists")
+def test_output_2(capsys, app):
+    result = app.max_integer([43,23,6,8733,43,1,4,6,3,67,8,99999,3,7,5435,63])
+    assert result == 99999
 
 @pytest.mark.it("Use the for loop")
 def test_for_loop():
@@ -15,9 +22,9 @@ def test_for_loop():
         regex = re.compile(r"for(\s)*")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"if(\s)*")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
diff --git a/exercises/09.1-For_loop_min_value/README.es.md b/exercises/09.1-For_loop_min_value/README.es.md
index b1a593c6..e37a2a26 100644
--- a/exercises/09.1-For_loop_min_value/README.es.md
+++ b/exercises/09.1-For_loop_min_value/README.es.md
@@ -1,23 +1,23 @@
-# `09.1` Mínimo entero:
+# `09.1` Minimum Integer
 
-Es posible recorrer una lista usando un bucle `for` para listas, tú tienes que especificar qué hacer en cada iteración de la lista.
+Es posible recorrer una lista usando un bucle `for`, y luego especificar qué hacer en cada iteración de la lista.
 
 ## 📝 Instrucciones:
 
-1. Por favor, usa la función for para obtener el menor valor de la lista e imprimirlo en la consola.
+1. Por favor, usa la función `for` para obtener el menor valor de la lista e imprimirlo en la consola.
 
-## 💡 Pista:
+## 💡 Pistas:
 
-* Declara una variable auxiliar global.
++ Declara una variable auxiliar global.
 
-* Establece su valor inicial con un entero muy grande.
++ Establece su valor inicial con el primer elemento de la lista.
 
-* Cada vez que iteres, compara su valor con el valor del elemento, si el valor del elemento es más pequeño, asígnalo como nuevo valor de la variable auxiliar.
++ Cada vez que iteres, compara su valor con el valor del siguiente elemento, si el valor del elemento es más pequeño, asígnalo como nuevo valor en la variable auxiliar.
 
-* Fuera del bucle, después de que el bucle haya finalizado, imprime el valor auxiliar.
++ Fuera del bucle, después de que el bucle haya finalizado, imprime el valor auxiliar.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
- 23
+23
 ```
diff --git a/exercises/09.1-For_loop_min_value/README.md b/exercises/09.1-For_loop_min_value/README.md
index ba9a3d4a..e06e0afd 100644
--- a/exercises/09.1-For_loop_min_value/README.md
+++ b/exercises/09.1-For_loop_min_value/README.md
@@ -1,24 +1,23 @@
-# `09.1` Minimum integer:
+# `09.1` Minimum Integer
 
-It is possible to traverse a list using the `for` loop, you have to specify what to do on each iteration of the loop.
+It is possible to traverse a list using the `for` loop, and you have to specify what to do on each iteration of the loop.
 
+## 📝 Instructions:
 
-## 📝Instructions:
+1. Please use the `for` loop function to get the minimum value from the list and print it in the console.
 
-1. Please use the `for` loop function to get the minimum value of the list and print it in the console.
+## 💡 Hints:
 
-## 💡 Hint:
++ Declare an auxiliary global variable.
 
-* Declare an Auxiliary Global Variable.
++ Set its value to the first element on the list.
 
-* Set it's value to a very big interger.
++ Every time you loop, compare its value to the next element's value, if it's smaller, update the auxiliary variable's value to the element's value.
 
-* Every time you loop, compare it's value to the item value. If the item value is smaller, update the auxiliary variable value to the item value.
++ Outside the loop, after the loop is finished, print the auxiliary variable's value.
 
-* Outside of the loop, after the loop is finished, print the auxiliary value.
-
-## Expected result:
+## 💻 Expected result:
 
 ```py
-expected: 23
+23
 ```
diff --git a/exercises/09.1-For_loop_min_value/app.py b/exercises/09.1-For_loop_min_value/app.py
index a6f8c057..594b1d3d 100644
--- a/exercises/09.1-For_loop_min_value/app.py
+++ b/exercises/09.1-For_loop_min_value/app.py
@@ -1,7 +1,3 @@
-my_list = [3344,34334,454543,342534,4563456,3445,23455,234,262,2335,
-43323,4356,345,4545,452,345,434,36,345,4334,5454,345,4352,23,365,345,47,63,
-425,6578759,768,834,754,35,32,445,453456,56,7536867,3884526,4234,35353245,53244523,
-566785,7547,743,4324,523472634,26665,63432,54645,32,453625,7568,5669576,754,64356,542644,
-35,243,371,3251,351223,13231243,734,856,56,53,234342,56,545343]
+my_list = [3344,34334,454543,342534,4563456,3445,23455,234,262,2335,43323,4356,345,4545,452,345,434,36,345,4334,5454,345,4352,23,365,345,47,63,425,6578759,768,834,754,35,32,445,453456,56,7536867,3884526,4234,35353245,53244523,566785,7547,743,4324,523472634,26665,63432,54645,32,453625,7568,5669576,754,64356,542644,35,243,371,3251,351223,13231243,734,856,56,53,234342,56,545343]
 
-#Your code here:
+# Your code here
diff --git a/exercises/09.1-For_loop_min_value/solution.hide.py b/exercises/09.1-For_loop_min_value/solution.hide.py
new file mode 100644
index 00000000..e7299394
--- /dev/null
+++ b/exercises/09.1-For_loop_min_value/solution.hide.py
@@ -0,0 +1,11 @@
+my_list = [3344,34334,454543,342534,4563456,3445,23455,234,262,2335,43323,4356,345,4545,452,345,434,36,345,4334,5454,345,4352,23,365,345,47,63,425,6578759,768,834,754,35,32,445,453456,56,7536867,3884526,4234,35353245,53244523,566785,7547,743,4324,523472634,26665,63432,54645,32,453625,7568,5669576,754,64356,542644,35,243,371,3251,351223,13231243,734,856,56,53,234342,56,545343]
+
+# Your code here
+
+smallest_integer = my_list[0]
+
+for number in my_list:
+    if number < smallest_integer:
+        smallest_integer = number
+    
+print(smallest_integer)
diff --git a/exercises/09.1-For_loop_min_value/test.py b/exercises/09.1-For_loop_min_value/test.py
index 18a2cce4..eac697c9 100644
--- a/exercises/09.1-For_loop_min_value/test.py
+++ b/exercises/09.1-For_loop_min_value/test.py
@@ -14,9 +14,9 @@ def test_for_loop():
         regex = re.compile(r"for(\s)")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"if(\s)")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
diff --git a/exercises/10-Find_avg/README.es.md b/exercises/10-Find_avg/README.es.md
index c5fb0aa7..fd770362 100644
--- a/exercises/10-Find_avg/README.es.md
+++ b/exercises/10-Find_avg/README.es.md
@@ -1,19 +1,19 @@
-# `10` Encuentra el promedio
-
+# `10` Find average
 
 ## 📝 Instrucciones:
 
-1. Declara una variable con valor `0`.
+1. Calcula el valor promedio de todos los elementos de la lista e imprímelo en la consola.
+
+## 💡 Pistas:
 
-2. Calcula el valor promedio de todos los elementos de la lista e imprímelo en la consola.
++ Para imprimir el promedio, tienes que sumar todos los valores y dividir el total entre la cantidad de elementos de la lista.
 
-## 💡 Pista:
++ Debes usar un bucle `for`.
 
-* Para imprimir el promedio, tienes que sumar todos los valores y dividir el total entre la cantidad de elementos de la lista.
++ Puedes usar tantas variables auxiliares como necesites.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
-El resultado debería ser similar a:
 27278.8125
 ```
diff --git a/exercises/10-Find_avg/README.md b/exercises/10-Find_avg/README.md
index e296e425..97bbf155 100644
--- a/exercises/10-Find_avg/README.md
+++ b/exercises/10-Find_avg/README.md
@@ -1,18 +1,19 @@
 # `10` Find average
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Declare a variable with value `0`.
+1. Calculate the average value of all the items in the list and print it on the console.
 
-2. Calculate the average value of all the items in the list and print it on the console.
+## 💡 Hints:
 
-## 💡 Hint:
++ To print the average, you have to add all the values and divide the result by the total length of the list.
 
-* To print the average, you have to add all the values and divide the result by the total length of the list.
++ Make sure you are using a `for` loop.
 
-## Expected result:
++ You can use as many auxiliary variables as you need.
+
+## 💻 Expected result:
 
 ```py
-The result have to be like:
 27278.8125
 ```
diff --git a/exercises/10-Find_avg/app.py b/exercises/10-Find_avg/app.py
index fe495015..c881b318 100644
--- a/exercises/10-Find_avg/app.py
+++ b/exercises/10-Find_avg/app.py
@@ -1,4 +1,3 @@
 my_list = [2323,4344,2325,324413,21234,24531,2123,42234,544,456,345,42,5445,23,5656,423]
 
-#Your code here:
-
+# Your code here
diff --git a/exercises/10-Find_avg/solution.hide.py b/exercises/10-Find_avg/solution.hide.py
new file mode 100644
index 00000000..aa38a2a8
--- /dev/null
+++ b/exercises/10-Find_avg/solution.hide.py
@@ -0,0 +1,11 @@
+my_list = [2323,4344,2325,324413,21234,24531,2123,42234,544,456,345,42,5445,23,5656,423]
+
+# Your code here
+total = 0
+
+for num in my_list:
+    total += num
+
+average = total / len(my_list)
+
+print(average)
diff --git a/exercises/10.1-And_One_and_a_Two_and_a_Three/README.es.md b/exercises/10.1-And_One_and_a_Two_and_a_Three/README.es.md
index fe4d2b66..e6f559a3 100644
--- a/exercises/10.1-And_One_and_a_Two_and_a_Three/README.es.md
+++ b/exercises/10.1-And_One_and_a_Two_and_a_Three/README.es.md
@@ -1,27 +1,25 @@
-# `10.1` Y uno, y dos, y tres
+# `10.1`  And one and two and three
 
-Los diccionarios (o `dict` en Python) son una forma de almacenar elementos como lo harías en una lista de Python, con la diferencia de que en lugar de acceder a los elementos por su índice, asignas una clave fija a cada uno y accedes al elemento usando su clave. A lo que te enfrentas ahora es un par `key-value` ("clave-valor"), el cual es, en ocasiones, una estructura de datos más apropiada para muchos problemas, en lugar de una simple lista.
+Los diccionarios (o "dict" en Python) son una forma de almacenar elementos como lo harías en una lista de Python, con la diferencia de que en lugar de acceder a los elementos por su índice, asignas una clave fija a cada uno y accedes al elemento usando su clave. A lo que te enfrentas ahora es a un par `key-value` (clave-valor), el cual es, en ocasiones, una estructura de datos más apropiada para diferentes problemas, en lugar de una simple lista.
 
 ## 📝 Instrucciones:
 
-1. Dado un objeto `contact`, por favor **itera todas sus propiedades y valores** e imprímelos en la consola.
+1. Dado un objeto `contact`, por favor itera todas sus claves y valores e imprímelos en la consola.
 
 2. Tendrás que iterar sus propiedades para poder imprimirlos
 
-## 💡 Pista:
+## 💡 Pistas:
 
 - contact.keys()  `['fullname', 'phone', 'email']`.
 
 - contact.values()  `['Jane Doe', '321-321-4321', 'test@test.com']`.
 
-- contact.items()  `[('fullname', 'Jane Doe'), ('phone', '321-321-4321'), ``('email', 'test@test.com')]`
+- contact.items()  `[('fullname', 'Jane Doe'), ('phone', '321-321-4321'), ('email', 'test@test.com')]`
 
-## Resultado esperado:
+## 💻 Ejemplo de resultado:
 
 ```py
-Ejemplo de salida:
-
-fullname : John Doe
-phone : 123-123-2134
-email : test@nowhere.com
+fullname: John Doe
+phone: 123-123-2134
+email: test@nowhere.com
 ```
diff --git a/exercises/10.1-And_One_and_a_Two_and_a_Three/README.md b/exercises/10.1-And_One_and_a_Two_and_a_Three/README.md
index 6a71fa96..1f394435 100644
--- a/exercises/10.1-And_One_and_a_Two_and_a_Three/README.md
+++ b/exercises/10.1-And_One_and_a_Two_and_a_Three/README.md
@@ -1,25 +1,25 @@
 # `10.1` And one and two and three
 
-Dictionaries (or dict in Python) are a way of storing elements just like you would in a Python list but intead of accessing elements using its index, you assign a fixed key to it and access the element using the key. What you now deal with is a `key-value` pair, which is sometimes a more appropriate data structure or many problems instead of a simple list.
+Dictionaries (or "dict" in Python) are a way of storing elements just like you would in a Python list, but instead of accessing elements using its index, you assign a fixed key to it and access the element using the key. What you now deal with is a `key-value` pair, which is sometimes a more appropriate data structure for solving different problems than a simple list.
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Given a contact object, please `loop all its properties and values` and print them on the console.
+1. Given a contact dictionary, please loop through all its keys and values and print them on the console.
 
-2. You will have to loop its properties to be able to print them.
+2. You will have to loop over its keys to be able to print them.
 
-## 💡Hint:
+## 💡 Hints:
 
 - contact.keys()  `['fullname', 'phone', 'email']`
 
 - contact.values()  `['Jane Doe', '321-321-4321', 'test@test.com']`
 
-- contact.items()  `[('fullname', 'Jane Doe'), ('phone', '321-321-4321'), ``('email', 'test@test.com')]`
+- contact.items()  `[('fullname', 'Jane Doe'), ('phone', '321-321-4321'), ('email', 'test@test.com')]`
 
-## Example console output:
+## 💻 Example console output:
 
 ```py
-fullname : John Doe
-phone : 123-123-2134
-email : test@nowhere.com
-```
\ No newline at end of file
+fullname: John Doe
+phone: 123-123-2134
+email: test@nowhere.com
+```
diff --git a/exercises/10.1-And_One_and_a_Two_and_a_Three/app.py b/exercises/10.1-And_One_and_a_Two_and_a_Three/app.py
index 8ba5d016..54e60221 100644
--- a/exercises/10.1-And_One_and_a_Two_and_a_Three/app.py
+++ b/exercises/10.1-And_One_and_a_Two_and_a_Three/app.py
@@ -3,5 +3,6 @@
     "phone": "321-321-4321",
     "email": "test@test.com"
 }
-#Your code here:
+
+# Your code here
 
diff --git a/exercises/10.1-And_One_and_a_Two_and_a_Three/solution.hide.py b/exercises/10.1-And_One_and_a_Two_and_a_Three/solution.hide.py
new file mode 100644
index 00000000..b5e67bec
--- /dev/null
+++ b/exercises/10.1-And_One_and_a_Two_and_a_Three/solution.hide.py
@@ -0,0 +1,10 @@
+contact = {
+    "fullname": "Jane Doe",
+    "phone": "321-321-4321",
+    "email": "test@test.com"
+}
+
+# Your code here
+
+for key in contact.keys():
+    print(f"{key}: {contact[key]}")
diff --git a/exercises/10.1-And_One_and_a_Two_and_a_Three/test.py b/exercises/10.1-And_One_and_a_Two_and_a_Three/test.py
index ff0a5003..2234baf5 100644
--- a/exercises/10.1-And_One_and_a_Two_and_a_Three/test.py
+++ b/exercises/10.1-And_One_and_a_Two_and_a_Three/test.py
@@ -5,7 +5,7 @@
 def test_dict(capsys, app):
     app()
     captured = capsys.readouterr()
-    assert "fullname : Jane Doe\nphone : 321-321-4321\nemail : test@test.com\n" in captured.out
+    assert "fullname: Jane Doe\nphone: 321-321-4321\nemail: test@test.com\n" in captured.out
 
 @pytest.mark.it("Use the for loop")
 def test_for_loop():
diff --git a/exercises/11-Nested_list/README.es.md b/exercises/11-Nested_list/README.es.md
index 6c905966..b732de51 100644
--- a/exercises/11-Nested_list/README.es.md
+++ b/exercises/11-Nested_list/README.es.md
@@ -1,28 +1,27 @@
-
-# `11` Lista anidada
+# `11` Nested list
 
 Es posible encontrar una lista dentro de otra lista (se llama lista de dos dimensiones o matriz).
 
 En este ejemplo, tenemos una lista de coordenadas a las que puedes acceder haciendo lo siguiente:
 
 ```py
-longitude = []
-# bucle for en longitud
-longitude = coordinatesList[0][1];
+# La primera coordenada es latitud
+latitude = coordinates_list[0][0]
+# La segunda coordenada es longitud
+longitude = coordinates_list[0][1]
 ```
 
 ## 📝 Instrucciones:
 
-1. Itera la lista imprimiendo solo las longitudes.
+1. Itera la lista imprimiendo solo las *longitudes*.
 
 ## 💡 Pista:
 
-* Recuerda que el índice en la primera posición es list[0].
++ Recuerda que el índice en la primera posición es `list[0]`.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
-El resultado debería ser algo como esto:
 -112.633853
 -63.987
 -81.901693
diff --git a/exercises/11-Nested_list/README.md b/exercises/11-Nested_list/README.md
index 9066a160..6701639d 100644
--- a/exercises/11-Nested_list/README.md
+++ b/exercises/11-Nested_list/README.md
@@ -1,30 +1,27 @@
-
 # `11` Nested list
 
-It is possible to find a list comprised of other lists (it is called a two-dimension list or matrix).
+It is possible to find a list comprised of other lists (it is called a two-dimensional list or matrix).
 
 In this example, we have a list of coordinates that you can access by doing the following:
 
 ```py
-longitude = []
-
-for loop in coordinate longitude
-
-longitude = coordinatesList[0][1];
+# The first coordinate is latitude
+latitude = coordinates_list[0][0]
+# The second coordinate is longitude
+longitude = coordinates_list[0][1]
 ```
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Loop through the list printing only the longitudes.
+1. Loop through the list, printing only the *longitudes*.
 
 ## 💡 Hint:
 
-- Remember the index of the position 1 is list[0]
++ Remember, the index of the first item in a list is `list[0]`.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
-The result should be something like this:
 -112.633853
 -63.987
 -81.901693
diff --git a/exercises/11-Nested_list/app.py b/exercises/11-Nested_list/app.py
index 467f6ad8..c08ecc4a 100644
--- a/exercises/11-Nested_list/app.py
+++ b/exercises/11-Nested_list/app.py
@@ -1,6 +1,3 @@
+coordinates_list = [[33.747252, -112.633853], [-33.867886, -63.987], [41.303921, -81.901693], [-33.350534, -71.653268]]
 
-coordinatesList = [[33.747252,-112.633853],[-33.867886, -63.987],[41.303921, -81.901693],[-33.350534, -71.653268]]
-
-# Your code go here:
-
-
+# Your code here
diff --git a/exercises/11-Nested_list/solution.hide.py b/exercises/11-Nested_list/solution.hide.py
new file mode 100644
index 00000000..f92c9fcf
--- /dev/null
+++ b/exercises/11-Nested_list/solution.hide.py
@@ -0,0 +1,6 @@
+coordinates_list = [[33.747252, -112.633853], [-33.867886, -63.987], [41.303921, -81.901693], [-33.350534, -71.653268]]
+
+# Your code here
+
+for coord in coordinates_list:
+    print(coord[1])
diff --git a/exercises/12-Map_a_list/README.es.md b/exercises/12-Map_a_list/README.es.md
index aad4bb7a..7dbeb820 100644
--- a/exercises/12-Map_a_list/README.es.md
+++ b/exercises/12-Map_a_list/README.es.md
@@ -1,17 +1,13 @@
-# `12` Mapea una lista
+# `12` Map a list
 
-```py
-Python map()
-```
-
-La función `map()` aplica una función dada a cada elemento de un 'iterable' (ya sea lista, tupla, etc.) y devuelve una lista de resultados.
+La función `map()` aplica una función dada a cada elemento de un "iterable" (ya sea lista, tupla, etc.) y devuelve una lista de resultados.
 
 ### La sintaxis de map() es:
  
-
 ```py
-map(funcion, iterable, ...)
+map(función, iterable, ...)
 ```
+
 #### Parámetros de map():
 
 - **función:** La función `map()` pasa cada elemento del iterable a esta función.
@@ -22,15 +18,22 @@ map(funcion, iterable, ...)
 
 La función `map()` aplica una función dada a cada elemento de un iterable y devuelve una lista de resultados.
 
-El valor devuelto por `map()`, que es un map object, es pasado a funciones como `list()` (para crear una lista), `set()` (para crear un conjunto) y así.
+El valor devuelto por `map()`, que es un *map object*, es pasado a funciones como `list()` (para crear una lista), `set()` (para crear un conjunto) y así.
 
 ## 📝 Instrucciones:
 
 1. Usando la misma lógica, agrega el código necesario para convertir una lista de valores Celsius en Fahrenheit dentro de la función `map()`.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
-Salida esperada en la consola:
 [28.4, 93.2, 132.8, 14.0]
 ```
+
+## 💡 Pista:
+
++ Para convertir de Celsius a Fahrenheit, multiplica la temperatura en Celsius por 9/5 y luego sumale 32.
+
+```text
+(Cº * 9/5) + 32
+```
diff --git a/exercises/12-Map_a_list/README.md b/exercises/12-Map_a_list/README.md
index 7d15111c..9a9b25ce 100644
--- a/exercises/12-Map_a_list/README.md
+++ b/exercises/12-Map_a_list/README.md
@@ -1,10 +1,6 @@
 # `12` Map a list
 
-```py
-Python map()
-```
-
-The `map()` function applies a given function to each item of an iterable (list, tuple etc.) and returns a list of the results.
+The `map()` function applies a given function to each item of an "iterable" (list, tuple, etc.) and returns a list of the results.
 
 ### The syntax of map() is:
 
@@ -12,7 +8,7 @@ The `map()` function applies a given function to each item of an iterable (list,
 map(function, iterable, ...)
 ```
 
-#### map() Parameter:
+#### map() Parameters:
 
 **function:** passes each item of the iterable to this function.
 
@@ -20,19 +16,24 @@ map(function, iterable, ...)
 
 #### Return Value from map():
 
-The `map()` function applies to a given function and in particular to each item of an iterable and returns a list of the results.
+The `map()` function applies to a given function and, in particular, to each item of an iterable to return a list of the results.
 
-The returned value from `map()` (map object) then can be passed to functions
-like list() (to create a list), set() (to create a set) and so on.
+The returned value from `map()` (map object) then can be passed to functions like `list()` (to create a list), `set()` (to create a set) and so on.
 
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Using the same logic, add the needed code to convert a list of Celsius values into Fahrenheit inside the `map()` function.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
-Expected in console:
-
 [28.4, 93.2, 132.8, 14.0]
 ```
+
+## 💡 Hint:
+
++ To convert from Celsius to Fahrenheit, multiply the Celsius temperature by 9/5 and add 32.
+
+```text
+(Cº * 9/5) + 32
+```
diff --git a/exercises/12-Map_a_list/app.py b/exercises/12-Map_a_list/app.py
index f0b071cc..bbaa6e5d 100644
--- a/exercises/12-Map_a_list/app.py
+++ b/exercises/12-Map_a_list/app.py
@@ -1,9 +1,9 @@
-Celsius_values = [-2,34,56,-10]
+celsius_values = [-2, 34, 56, -10]
 
+def celsius_to_fahrenheit(celsius):
+    # The magic happens here
+   
 
+result = list(map(celsius_to_fahrenheit, celsius_values))
 
-def fahrenheit_values(x):
-# the magic go here:
-   
-result = list(map(fahrenheit_values, Celsius_values))
 print(result)
diff --git a/exercises/12-Map_a_list/solution.hide.py b/exercises/12-Map_a_list/solution.hide.py
new file mode 100644
index 00000000..5b8c8b04
--- /dev/null
+++ b/exercises/12-Map_a_list/solution.hide.py
@@ -0,0 +1,9 @@
+celsius_values = [-2, 34, 56, -10]
+
+def celsius_to_fahrenheit(celsius):
+    # The magic happens here
+    return (celsius * 9/5) + 32
+
+result = list(map(celsius_to_fahrenheit, celsius_values))
+
+print(result)
diff --git a/exercises/12-Map_a_list/test.py b/exercises/12-Map_a_list/test.py
index 1980cf57..6fffeeb8 100644
--- a/exercises/12-Map_a_list/test.py
+++ b/exercises/12-Map_a_list/test.py
@@ -1,7 +1,7 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Convert Celsius to Fahrenheit and print to console")
+@pytest.mark.it("Convert celsius to fahrenheit and print to console")
 def test_dict(capsys, app):
     import app
     captured = capsys.readouterr()
@@ -11,4 +11,4 @@ def test_dict(capsys, app):
 def test_if_loo():
     f = open(os.path.dirname(os.path.abspath(__file__))+'/app.py')
     content = f.read()
-    assert content.find("map") > 0
\ No newline at end of file
+    assert content.find("map") > 0
diff --git a/exercises/12.1-more_mapping/README.es.md b/exercises/12.1-more_mapping/README.es.md
index 96b74c9a..5c67b4f2 100644
--- a/exercises/12.1-more_mapping/README.es.md
+++ b/exercises/12.1-more_mapping/README.es.md
@@ -1,30 +1,27 @@
-# `12.1` Más mapeo
+# `12.1` More mapping
 
-El método `map()` de una lista, llama a una función por cada valor en la lista y, luego, entrega una nueva lista con los valores modificados.
+El método `map()` llama a una función por cada valor en la lista y, luego, devuelve una nueva lista con los valores modificados.
 
 ```py
-#incrementando en 1
-def values_list(number) {
-  return number + 1
-}
+def increment_by_one(number):
+    return number + 1
 
 my_list = [1, 2, 3, 4]
-result = map(values_list, my_list)  #retorna [2, 3, 4, 5]
+result = map(increment_by_one, my_list)  # returns [2, 3, 4, 5]
 ```
-## 📝 Instrucciones:
 
-1. Crear una función llamada `increment_by_one` que multiplicará cada número por 3.
+## 📝 Instrucciones:
 
-2. Pasa un argumento a la función.
+1. Crear una función llamada `multiply_by_three` que multiplicará cada número por 3.
 
-3. Usa la función `map()` de la lista para ejecutar la función `increment_by_one` a través de cada valor en la lista.
+2. Usa la función `map()` de la lista para ejecutar la función `multiply_by_three` en cada valor de la lista.
 
-4. Almacena la nueva lista en una nueva llamada `new_list` e imprime los nuevos valores.
+3. Almacena la nueva lista en una variable llamada `new_list` e imprime los nuevos valores.
 
-## 💡 Pista:
+## 💡 Pistas:
 
-+ La función cogerá un parámetro con el elemento original y lo transformará e insertará en una nueva lista (`new_list`).
++ La función `map()` aplicará la función especificada por parámetro a cada elemento de tu lista.
 
-+ Recuerda que tu función debe devolver cada nuevo elemento para almacenarlo en la nueva lista (`new_list`).
++ Recuerda almacenar tu resultado en la nueva lista (`new_list`).
 
 
diff --git a/exercises/12.1-more_mapping/README.md b/exercises/12.1-more_mapping/README.md
index b986de39..14572f88 100644
--- a/exercises/12.1-more_mapping/README.md
+++ b/exercises/12.1-more_mapping/README.md
@@ -1,29 +1,25 @@
 # `12.1` More mapping
 
-The list `map()` method calls a function for each value in a list and then outputs a new list with the modified values.
+The `map()` method calls a function for each value in a list and then outputs a new list with the modified values.
 
 ```py
-#incrementByOne
-def values_list(number) {
-  return number + 1
-}
+def increment_by_one(number):
+    return number + 1
 
 my_list = [1, 2, 3, 4]
-result = map(values_list, my_list)  #returns [2, 3, 4, 5]
+result = map(increment_by_one, my_list)  # returns [2, 3, 4, 5]
 ```
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Create a function named `increment_by_one` that will multiply each number by 3.
+1. Create a function named `multiply_by_three` that will multiply each number by 3.
 
-2. Use the list `map()` function to run the `increment_by_one` function through each value in the list.
+2. Use the list `map()` function to run the `multiply_by_three` function through each value in the list.
 
 3. Store the new list in a variable named `new_list` and `print()` the new values.
 
-## 💡 Hint:
-
-+ The function will take a parameter with the original item being transformed and added into the new list.
-
-+ Remember that your function must return each of the new items to be stored into the new list.
+## 💡 Hints:
 
++ The `map()` function will apply the specified function to every item in your list.
 
++ Remember to store your result in the `new_list`.
diff --git a/exercises/12.1-more_mapping/app.py b/exercises/12.1-more_mapping/app.py
index 073c5a78..c5d1ca14 100644
--- a/exercises/12.1-more_mapping/app.py
+++ b/exercises/12.1-more_mapping/app.py
@@ -1,5 +1,5 @@
-myNumbers = [23,234,345,4356234,243,43,56,2]
+my_numbers = [23,234,345,4356234,243,43,56,2]
 
-#Your code go here:
+# Your code here
 
-print(new_list)
\ No newline at end of file
+print(new_list)
diff --git a/exercises/12.1-more_mapping/solution.hide.py b/exercises/12.1-more_mapping/solution.hide.py
new file mode 100644
index 00000000..cffe7a81
--- /dev/null
+++ b/exercises/12.1-more_mapping/solution.hide.py
@@ -0,0 +1,9 @@
+my_numbers = [23,234,345,4356234,243,43,56,2]
+
+# Your code here
+def multiply_by_three(number):
+    return number * 3
+
+new_list = list(map(multiply_by_three, my_numbers))
+
+print(new_list)
diff --git a/exercises/12.1-more_mapping/test.py b/exercises/12.1-more_mapping/test.py
index 876dbb5e..753927e5 100644
--- a/exercises/12.1-more_mapping/test.py
+++ b/exercises/12.1-more_mapping/test.py
@@ -1,7 +1,7 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Result of multiply by 3")
+@pytest.mark.it("Result of multiply_by_three must be correct")
 def test_multp(capsys, app):
     import app
     captured = capsys.readouterr()
@@ -13,12 +13,12 @@ def test_map():
     content = f.read()
     assert content.find("map") > 0
 
-@pytest.mark.it("Create the function increment_by_one")
+@pytest.mark.it("Create the function multiply_by_three")
 def test_variable_exists(app):
     try:
-        app.increment_by_one
+        app.multiply_by_three
     except AttributeError:
-        raise AttributeError("The function 'increment_by_one' should exist on app.py")
+        raise AttributeError("The function 'multiply_by_three' should exist on app.py")
         
 @pytest.mark.it("Create the variable new_list")
 def test_variable_new_list(app):
diff --git a/exercises/12.2-Map_function_inside_variable/README.es.md b/exercises/12.2-Map_function_inside_variable/README.es.md
index da9b9b71..188d4105 100644
--- a/exercises/12.2-Map_function_inside_variable/README.es.md
+++ b/exercises/12.2-Map_function_inside_variable/README.es.md
@@ -1,14 +1,23 @@
-# `12.2` Función map dentro de una variable
+# `12.2` Map function inside a variable
 
-La variable names contiene muchos nombres :unamused:(daah...)
+La variable `names` contiene muchos nombres (😒 daah...)
 
-La función `prepender` almacenada en la variable devuelve lo que sea que se le pase pero agregando antes: `'My name is:'`
+La función ya definida `prepender` devuelve lo que sea que se le pase pero agregando antes: `'My name is: '`.
 
 ## 📝 Instrucciones:
 
 1. Por favor, mapea la lista de nombres usando la función `prepender` para crear una nueva lista que se parezca a esto:
 
-## Resultado Esperado:
+## 💻 Resultado esperado:
+
+```py
+[ 'My name is: Alice',
+  'My name is: Bob',
+  'My name is: Marry',
+  'My name is: Joe',
+  'My name is: Hilary',
+  'My name is: Stevia',  
+  'My name is: Dylan' ]
+```
 
-
 
diff --git a/exercises/12.2-Map_function_inside_variable/README.md b/exercises/12.2-Map_function_inside_variable/README.md
index a3b29959..156534e8 100644
--- a/exercises/12.2-Map_function_inside_variable/README.md
+++ b/exercises/12.2-Map_function_inside_variable/README.md
@@ -1,15 +1,23 @@
-# `12.2` Map function inside of variable
+# `12.2` Map function inside a variable
 
-The variable names contains a lot of names (:unamused: dugh...)
+The variable `names` contains a lot of names (😒 duh...)
 
-The function stored in the variable `prepender` returns whatever is passed to it but prepended with the string: `'My name is:'`.
+The already defined function `prepender` returns whatever is passed to it but is prepended with the string: `'My name is: '`.
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Please map the names list  using the `prepender` function
-to create a new list that looks like this:
+1. Please map the names list using the `prepender` function to create a new list that looks like this:
 
-## Expected Result:
+## 💻 Expected result:
+
+```py
+[ 'My name is: Alice',
+  'My name is: Bob',
+  'My name is: Marry',
+  'My name is: Joe',
+  'My name is: Hilary',
+  'My name is: Stevia',  
+  'My name is: Dylan' ]
+```
 
-
 
diff --git a/exercises/12.2-Map_function_inside_variable/app.py b/exercises/12.2-Map_function_inside_variable/app.py
index 5eb02a38..7146df37 100644
--- a/exercises/12.2-Map_function_inside_variable/app.py
+++ b/exercises/12.2-Map_function_inside_variable/app.py
@@ -1,5 +1,6 @@
-names = ['Alice','Bob','Marry','Joe','Hilary','Stevia','Dylan']
+names = ['Alice', 'Bob', 'Marry', 'Joe', 'Hilary', 'Stevia', 'Dylan']
 
 def prepender(name):
     return "My name is: " + name
-#Your code go here:
\ No newline at end of file
+    
+# Your code here
diff --git a/exercises/12.2-Map_function_inside_variable/solution.hide.py b/exercises/12.2-Map_function_inside_variable/solution.hide.py
new file mode 100644
index 00000000..ae9da7fb
--- /dev/null
+++ b/exercises/12.2-Map_function_inside_variable/solution.hide.py
@@ -0,0 +1,10 @@
+names = ['Alice', 'Bob', 'Marry', 'Joe', 'Hilary', 'Stevia', 'Dylan']
+
+def prepender(name):
+    return "My name is: " + name
+    
+# Your code here
+
+new_list = list(map(prepender, names))
+
+print(new_list)
diff --git a/exercises/12.2-Map_function_inside_variable/test.py b/exercises/12.2-Map_function_inside_variable/test.py
index 6a23cae3..e6239937 100644
--- a/exercises/12.2-Map_function_inside_variable/test.py
+++ b/exercises/12.2-Map_function_inside_variable/test.py
@@ -1,7 +1,7 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Print the all the names as in the output")
+@pytest.mark.it("Print all the names as in the output")
 def test_multp(capsys, app):
     import app
     captured = capsys.readouterr()
@@ -11,4 +11,4 @@ def test_multp(capsys, app):
 def test_map():
     f = open(os.path.dirname(os.path.abspath(__file__)) + '/app.py')
     content = f.read()
-    assert content.find("map") > 0
\ No newline at end of file
+    assert content.find("map") > 0
diff --git a/exercises/12.3-Map_data_types/README.es.md b/exercises/12.3-Map_data_types/README.es.md
index 9a573996..ea564fa4 100644
--- a/exercises/12.3-Map_data_types/README.es.md
+++ b/exercises/12.3-Map_data_types/README.es.md
@@ -1,20 +1,18 @@
-# `12.3` Mapear tipos de datos
+# `12.3` Map data types
 
 Muchas veces las listas vienen con valores mixtos y necesitamos unificarlos dentro de un solo tipo de datos.
 
 ## 📝 Instrucciones:
 
-1. Actualiza la función `map()` para hacer que cree una nueva lista (`new_list`) que contenga el tipo de dato que corresponde a cada elemento de la lista original.
+1. Actualiza la función `type_list()` para hacer que cree una nueva lista (`new_list`) que contenga el tipo de dato que corresponde a cada elemento de la lista original.
 
-## 💡 Pista:
+## 💡 Pistas:
 
 + Usa la función `type()` para obtener el tipo de dato.
 
 + Más sobre tipos de datos: https://www.w3schools.com/python/python_datatypes.asp
 
-## Resultado esperado:
-
-El resultado en la consola debería parecerse a esto:
+## 💻 Resultado esperado:
 
 ```py
 [, , , , , , , ]
diff --git a/exercises/12.3-Map_data_types/README.md b/exercises/12.3-Map_data_types/README.md
index b22d11b9..0be99885 100644
--- a/exercises/12.3-Map_data_types/README.md
+++ b/exercises/12.3-Map_data_types/README.md
@@ -1,20 +1,18 @@
 # `12.3` Map data types
 
-Some times lists come with mixed values and you need to unify them into only one data type.
+Sometimes lists come with mixed values, and you need to unify them into only one data type.
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Update the map function to make it create a **new list** that contains the data types of each corresponding item from the original list.
+1. Update the `type_list` function to make it create a `new_list` that contains the data types of each corresponding item from the original list.
 
-## 💡 Hint:
+## 💡 Hints:
 
 + Use the `type()` function to get the data type.
 
 + More about data type: https://www.w3schools.com/python/python_datatypes.asp
 
-## Expected result:
-
-The result in the console should be something like:
+## 💻 Expected result:
 
 ```py
 [, , , , , , , ]
diff --git a/exercises/12.3-Map_data_types/app.py b/exercises/12.3-Map_data_types/app.py
index 18fb50ba..c1225967 100644
--- a/exercises/12.3-Map_data_types/app.py
+++ b/exercises/12.3-Map_data_types/app.py
@@ -1,8 +1,9 @@
-list_Strings = ['1','5','45','34','343','34',6556,323]
-
+mixed_list = ['1','5','45','34','343','34',6556,323]
 
 def type_list(items):
-        return items
+        # Your code here
+        return 
+
+new_list = list(map(type_list, mixed_list))
 
-new_list = list(map(type_list, list_Strings))
-print(new_list)
\ No newline at end of file
+print(new_list)
diff --git a/exercises/12.3-Map_data_types/solution.hide.py b/exercises/12.3-Map_data_types/solution.hide.py
new file mode 100644
index 00000000..6e9424c8
--- /dev/null
+++ b/exercises/12.3-Map_data_types/solution.hide.py
@@ -0,0 +1,9 @@
+mixed_list = ['1','5','45','34','343','34',6556,323]
+
+def type_list(items):
+        # Your code here
+        return type(items)
+
+new_list = list(map(type_list, mixed_list))
+
+print(new_list)
diff --git a/exercises/12.3-Map_data_types/test.py b/exercises/12.3-Map_data_types/test.py
index 8489f6fe..3b43a076 100644
--- a/exercises/12.3-Map_data_types/test.py
+++ b/exercises/12.3-Map_data_types/test.py
@@ -1,7 +1,7 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Print all data types of the list")
+@pytest.mark.it("Print all data types from the mixed_list")
 def test_multp(capsys, app):
     import app
     captured = capsys.readouterr()
@@ -11,4 +11,4 @@ def test_multp(capsys, app):
 def test_map():
     f = open(os.path.dirname(os.path.abspath(__file__))+'/app.py')
     content = f.read()
-    assert content.find("map") > 0
\ No newline at end of file
+    assert content.find("map") > 0
diff --git a/exercises/12.4-Map_list_of_objects/README.es.md b/exercises/12.4-Map_list_of_objects/README.es.md
index f73798aa..7876223d 100644
--- a/exercises/12.4-Map_list_of_objects/README.es.md
+++ b/exercises/12.4-Map_list_of_objects/README.es.md
@@ -1,26 +1,26 @@
-# `12.4` Mapeando lista de objetos
-
-El escenario más común para la función de mapeo es simplificar listas dadas, por ejemplo:
-
-El actual algoritmo crea una lista con solo los nombres de personas (`name_list`) y los imprime en la consola.
+# `12.4` Map a list of dictionaries
 
 ## 📝 Instrucciones:
 
-1. En este momento la función está imprimiendo solo los nombres. Por favor, actualiza la función de mapeo, de modo que cree una lista donde cada elemento contenga lo siguiente:
+1. En este momento la función `format_greeting` está imprimiendo solo los nombres. Por favor, actualiza la función de mapeo, de modo que cree una lista donde cada elemento contenga lo siguiente:
+
+```py
+'Hello, my name is  and I am  years old'
+```
 
-`Hello my name is  and I am  years old.`
+## 💡 Pistas:
 
-## 💡 Pista:
+- Tienes que obtener la edad de cada persona de acuerdo a su fecha de nacimiento (`birth_date`).
 
-- Tienes que obtener la edad de cada persona de acuerdo a su cumpleaños (`birthDate`).
+- Tómate tu tiempo para entender la función ya definida `calculate_age`.
 
-- Busca en Google "como obtener una fecha de nacimiento dada en python.
+- Busca en Google "cómo obtener la edad de alguien dada su fecha de nacimiento python".
 
-- Dentro de tu función de simplificación debes devolver una concatenación.
+- Dentro de tu función `format_greeting` debes devolver una concatenación.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
-La salida esperada debería ser similar a esta:
+Debe quedar algo similar a esto, sin embargo, las edades pueden variar.
 
 ```py
 [ 'Hello, my name is Joe and I am 32 years old',
diff --git a/exercises/12.4-Map_list_of_objects/README.md b/exercises/12.4-Map_list_of_objects/README.md
index 1cc4a316..67725b1f 100644
--- a/exercises/12.4-Map_list_of_objects/README.md
+++ b/exercises/12.4-Map_list_of_objects/README.md
@@ -1,26 +1,26 @@
-# `12.4` Map list of objects
-
-The most common scenario for the mapping function is for simplifying given lists, for example:
-
-The current algorithm creates a list with only the names of the people and prints it on the console.
+# `12.4` Map a list of dictionaries
 
 ## 📝 Instructions:
 
-1. At this time the function is printing the names only. Please update the mapping function so it creates a list where each item contains the following:
+1. At this time, the function `format_greeting` is printing the names only. Please update the mapping function so it creates a list where each item contains the following:
+
+```py
+'Hello, my name is  and I am  years old'
+```
 
-`Hello, my name is Joe and I am 13 years old`
+## 💡 Hints:
 
-## 💡 Hint:
++ You have to get the age of each person based on their `birth_date`.
 
-+ You have to get the age of each people based on their `birthDate`.
++ Take your time to understand the already defined `calculate_age` function.
 
-+ Search in Google "How to get the age of given birth date in python"
++ Search in Google "How to get the age of a given birth date in python".
 
-+ Inside your simplifier function you have to return a concatenation.
++ Inside your `format_greeting` function you have to return a concatenation.
 
-## Expected result:
+## 💻 Expected result:
 
-The expected output should look similar but not exactly to this:
+The result should be similar to this, but the ages might be different.
 
 ```py
 [ 'Hello, my name is Joe and I am 32 years old',
diff --git a/exercises/12.4-Map_list_of_objects/app.py b/exercises/12.4-Map_list_of_objects/app.py
index 8cfea2f9..de3e0d1f 100644
--- a/exercises/12.4-Map_list_of_objects/app.py
+++ b/exercises/12.4-Map_list_of_objects/app.py
@@ -1,20 +1,23 @@
 import datetime
 
-
 people = [
-	{ "name": 'Joe', "birthDate": datetime.datetime(1986,10,24) },
-	{ "name": 'Bob', "birthDate": datetime.datetime(1975,5,24) },
-	{ "name": 'Erika', "birthDate": datetime.datetime(1989,6,12) },
-	{ "name": 'Dylan', "birthDate": datetime.datetime(1999,12,14) },
-	{ "name": 'Steve', "birthDate": datetime.datetime(2003,4,24) }
+	{ "name": 'Joe', "birth_date": datetime.datetime(1986,10,24) },
+	{ "name": 'Bob', "birth_date": datetime.datetime(1975,5,24) },
+	{ "name": 'Erika', "birth_date": datetime.datetime(1989,6,12) },
+	{ "name": 'Dylan', "birth_date": datetime.datetime(1999,12,14) },
+	{ "name": 'Steve', "birth_date": datetime.datetime(2003,4,24) }
 ]
 
-
-def calculateAge(birthDate):
+def calculate_age(date_of_birth):
     today = datetime.date.today()
-    age = today.year - birthDate.year - ((today.month, today.day) < (birthDate.month, birthDate.day))
+    age = today.year - date_of_birth.year - ((today.month, today.day) < (date_of_birth.month, date_of_birth.day))
     return age
 
-name_list = list(map(lambda person:  person["name"] , people))
-print(name_list)
+def format_greeting(person):
+    # Your code here
+    return person["name"]
 
+
+name_list = list(map(format_greeting, people))
+
+print(name_list)
diff --git a/exercises/12.4-Map_list_of_objects/solution.hide.py b/exercises/12.4-Map_list_of_objects/solution.hide.py
new file mode 100644
index 00000000..0f94fbab
--- /dev/null
+++ b/exercises/12.4-Map_list_of_objects/solution.hide.py
@@ -0,0 +1,24 @@
+import datetime
+
+people = [
+	{ "name": 'Joe', "birth_date": datetime.datetime(1986,10,24) },
+	{ "name": 'Bob', "birth_date": datetime.datetime(1975,5,24) },
+	{ "name": 'Erika', "birth_date": datetime.datetime(1989,6,12) },
+	{ "name": 'Dylan', "birth_date": datetime.datetime(1999,12,14) },
+	{ "name": 'Steve', "birth_date": datetime.datetime(2003,4,24) }
+]
+
+def calculate_age(date_of_birth):
+    today = datetime.date.today()
+    age = today.year - date_of_birth.year - ((today.month, today.day) < (date_of_birth.month, date_of_birth.day))
+    return age
+
+def format_greeting(person):
+    # Your code here
+    name = person["name"]
+    age = calculate_age(person["birth_date"])
+    return f"Hello, my name is {name} and I am {age} years old"
+
+name_list = list(map(format_greeting, people))
+
+print(name_list)
diff --git a/exercises/12.4-Map_list_of_objects/test.py b/exercises/12.4-Map_list_of_objects/test.py
index 2666d3b1..6e4b285b 100644
--- a/exercises/12.4-Map_list_of_objects/test.py
+++ b/exercises/12.4-Map_list_of_objects/test.py
@@ -1,7 +1,7 @@
 import io, sys, pytest, os, re, datetime
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Each element needs to have this output: !!😎")
+@pytest.mark.it("Each element should to have the correct output")
 def test_multp(capsys, app):
     import app
     people = [
@@ -19,7 +19,7 @@ def calculateAge(birthDate):
     captured = capsys.readouterr()
     assert str(name_list) in captured.out
 
-@pytest.mark.it("Use the map function ")
+@pytest.mark.it("Use the map function")
 def test_map():
     f = open(os.path.dirname(os.path.abspath(__file__))+'/app.py')
     content = f.read()
diff --git a/exercises/12.5-Yes_and_no/README.es.md b/exercises/12.5-Yes_and_no/README.es.md
index 9cf3e014..e95454a2 100644
--- a/exercises/12.5-Yes_and_no/README.es.md
+++ b/exercises/12.5-Yes_and_no/README.es.md
@@ -1,26 +1,24 @@
-# `12.5` Sí y no
+# `12.5` Yes and no
 
 ## 📝 Instrucciones:
 
-1. Por favor, usa la funcionalidad de mapeo de lista para iterar la lista de buleanos y crear una nueva lista que contenga el texto `'wiki'` por cada 1 y `'woko'` por cada 0 que tenga la lista original.
+1. Por favor, usa la funcionalidad de mapeo de lista para iterar la lista de booleanos y crear una nueva lista que contenga el texto `'wiki'` por cada `1` y `'woko'` por cada `0` de la lista original.
 
 2. Imprime la nueva lista en la consola.
 
-## 💡 Pista:
+## 💡 Pistas:
 
 - Debes mapear la lista entera.
 
 - Dentro de tu función de mapeo necesitas usar un condicional para verificar si el valor actual es `1` o `0`.
 
-- Si el valor es 1 asignas el texto `'wiki'`.
+- Si el valor es `1` asignas el texto `'wiki'`.
 
-- Si el valor es 0 asignas el texto `'woko'`.
+- Si el valor es `0` asignas el texto `'woko'`.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
-Ejemplo de salida:
-
-[ 'woko',   'wiki',   'woko',   'woko',   'wiki',   'wiki',   'wiki',   'woko',   'woko',   'wiki',   'woko',   'wiki',   'wiki',   'woko',   'woko',   'woko',   'woko',   'woko',   'woko',   'woko',   'woko',   'wiki',   'woko',   'woko',   'woko',   'woko',   'wiki' ]
+[ 'woko', 'wiki', 'woko', 'woko', 'wiki', 'wiki', 'wiki', 'woko', 'woko', 'wiki', 'woko', 'wiki', 'wiki', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'wiki', 'woko', 'woko', 'woko', 'woko', 'wiki' ]
 ```
 
diff --git a/exercises/12.5-Yes_and_no/README.md b/exercises/12.5-Yes_and_no/README.md
index 39dccc5e..5c8f9f8f 100644
--- a/exercises/12.5-Yes_and_no/README.md
+++ b/exercises/12.5-Yes_and_no/README.md
@@ -1,23 +1,23 @@
 # `12.5` Yes and no
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Please use the list map functionality to loop the list of booleans and create a new list that contains the string `'wiki'` for every `1` and `'woko'` for every `0` that the original list had.
+1. Please use the map functionality to loop the list of booleans and create a new list that contains the string `'wiki'` for every `1` and `'woko'` for every `0` that the original list had.
 
 2. Print that list on the console.
 
-## 💡 Hint:
+## 💡 Hints:
 
 + You need to map the entire list.
 
 + Inside your mapping function you need to use a conditional to verify if the current value is `0` or `1`.
 
-+ If the current value is 1 you print the string `'wiki'`.
++ If the current value is `1` you print the string `'wiki'`.
 
-+ If the current value is 0 you print the string `'woko'`.
++ If the current value is `0` you print the string `'woko'`.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
-[ 'woko',   'wiki',   'woko',   'woko',   'wiki',   'wiki',   'wiki',   'woko',   'woko',   'wiki',   'woko',   'wiki',   'wiki',   'woko',   'woko',   'woko',   'woko',   'woko',   'woko',   'woko',   'woko',   'wiki',   'woko',   'woko',   'woko',   'woko',   'wiki' ]
+[ 'woko', 'wiki', 'woko', 'woko', 'wiki', 'wiki', 'wiki', 'woko', 'woko', 'wiki', 'woko', 'wiki', 'wiki', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'wiki', 'woko', 'woko', 'woko', 'woko', 'wiki' ]
 ```
diff --git a/exercises/12.5-Yes_and_no/app.py b/exercises/12.5-Yes_and_no/app.py
index 980f87d0..bdbe9f38 100644
--- a/exercises/12.5-Yes_and_no/app.py
+++ b/exercises/12.5-Yes_and_no/app.py
@@ -1,5 +1,4 @@
-theBools = [0,1,0,0,1,1,1,0,0,1,0,1,1,0,0,0,0,0,0,0,0,1,0,0,0,0,1]
-
-#Your code go here:
+the_bools = [0,1,0,0,1,1,1,0,0,1,0,1,1,0,0,0,0,0,0,0,0,1,0,0,0,0,1]
 
+# Your code here
 
diff --git a/exercises/12.5-Yes_and_no/solution.hide.py b/exercises/12.5-Yes_and_no/solution.hide.py
new file mode 100644
index 00000000..24504f98
--- /dev/null
+++ b/exercises/12.5-Yes_and_no/solution.hide.py
@@ -0,0 +1,7 @@
+the_bools = [0,1,0,0,1,1,1,0,0,1,0,1,1,0,0,0,0,0,0,0,0,1,0,0,0,0,1]
+
+# Your code here
+
+new_list = list(map(lambda x: 'wiki' if x == 1 else 'woko', the_bools))
+
+print(new_list)
diff --git a/exercises/12.5-Yes_and_no/test.py b/exercises/12.5-Yes_and_no/test.py
index d87e7e5d..a72afe92 100644
--- a/exercises/12.5-Yes_and_no/test.py
+++ b/exercises/12.5-Yes_and_no/test.py
@@ -1,19 +1,19 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Congratulation!!!, that was a nice work")
+@pytest.mark.it("The output should be correct")
 def test_output(capsys, app):
     import app
     captured = capsys.readouterr()
     assert "['woko', 'wiki', 'woko', 'woko', 'wiki', 'wiki', 'wiki', 'woko', 'woko', 'wiki', 'woko', 'wiki', 'wiki', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'woko', 'wiki', 'woko', 'woko', 'woko', 'woko', 'wiki']\n" in captured.out
 
-@pytest.mark.it("Use a map function")
+@pytest.mark.it("Use the map function")
 def test_map():
     f = open(os.path.dirname(os.path.abspath(__file__)) + '/app.py')
     content = f.read()
     assert content.find("map") > 0
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
diff --git a/exercises/12.6-Transformers/README.es.md b/exercises/12.6-Transformers/README.es.md
index 3595f75b..ac38936c 100644
--- a/exercises/12.6-Transformers/README.es.md
+++ b/exercises/12.6-Transformers/README.es.md
@@ -2,14 +2,12 @@
 
 ## 📝 Instrucciones:
 
-1. Declara una nueva función llamada `my_var` y pásale un argumento.
+1. Declara una nueva función llamada `data_transformer()` que reciba una lista como parámetro.
 
-2. Declara una nueva variable llamada `transformedData`.
+2. La función debe retornar una lista de strings con el nombre completo de cada usuario, debes hacerlo usando la función `map()`.
 
-3. Llena la variable declarada con una lista de strings de texto con el nombre completo de cada usuario, usando la función `map()`.
-
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
-'Mario Montes', 'Joe Biden', 'Bill Clon', 'Hilary Mccafee', 'Bobby Mc birth']
+['Mario Montes', 'Joe Biden', 'Bill Clon', 'Hilary Mccafee', 'Bobby Mc birth']
 ```
diff --git a/exercises/12.6-Transformers/README.md b/exercises/12.6-Transformers/README.md
index 48d6eb9a..1c25c049 100644
--- a/exercises/12.6-Transformers/README.md
+++ b/exercises/12.6-Transformers/README.md
@@ -1,15 +1,13 @@
 # `12.6` Transformers
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Declare a new function called `my_var` and pass 1 argument.
+1. Define a new function called `data_transformer()` that receives a list as parameter.
 
-2. Declare a new variable called `transformedData`.
+2. The function should return a list of strings containing the full name of each user using the `map()` method.
 
-3. Fill the declared variable with a list of strings containing the full name of each user using the `map()` function.
-
-## Expected result:
+## 💻 Expected result:
 
 ```py
-'Mario Montes', 'Joe Biden', 'Bill Clon', 'Hilary Mccafee', 'Bobby Mc birth']
-```
\ No newline at end of file
+['Mario Montes', 'Joe Biden', 'Bill Clon', 'Hilary Mccafee', 'Bobby Mc birth']
+```
diff --git a/exercises/12.6-Transformers/app.py b/exercises/12.6-Transformers/app.py
index 46aa74c8..cb949489 100644
--- a/exercises/12.6-Transformers/app.py
+++ b/exercises/12.6-Transformers/app.py
@@ -1,11 +1,10 @@
-incomingAJAXData = [
-	{ "name": 'Mario', "lastName": 'Montes' },
-	{ "name": 'Joe', "lastName": 'Biden' },
-	{ "name": 'Bill', "lastName": 'Clon' },
-	{ "name": 'Hilary', "lastName": 'Mccafee' },
-	{ "name": 'Bobby', "lastName": 'Mc birth' }
+incoming_ajax_data = [
+    { "name": 'Mario', "last_name": 'Montes' },
+    { "name": 'Joe', "last_name": 'Biden' },
+    { "name": 'Bill', "last_name": 'Clon' },
+    { "name": 'Hilary', "last_name": 'Mccafee' },
+    { "name": 'Bobby', "last_name": 'Mc birth' }
 ]
 
-#Your code go here:
-
+# Your code here
 
diff --git a/exercises/12.6-Transformers/solution.hide.py b/exercises/12.6-Transformers/solution.hide.py
new file mode 100644
index 00000000..218bdd76
--- /dev/null
+++ b/exercises/12.6-Transformers/solution.hide.py
@@ -0,0 +1,13 @@
+incoming_ajax_data = [
+    { "name": 'Mario', "last_name": 'Montes' },
+    { "name": 'Joe', "last_name": 'Biden' },
+    { "name": 'Bill', "last_name": 'Clon' },
+    { "name": 'Hilary', "last_name": 'Mccafee' },
+    { "name": 'Bobby', "last_name": 'Mc birth' }
+]
+
+# Your code here
+def data_transformer(data_list):
+    return list(map(lambda element: f"{element['name']} {element['last_name']}", data_list))
+
+print(data_transformer(incoming_ajax_data))
diff --git a/exercises/12.6-Transformers/test.py b/exercises/12.6-Transformers/test.py
index a5d02231..b56723e0 100644
--- a/exercises/12.6-Transformers/test.py
+++ b/exercises/12.6-Transformers/test.py
@@ -1,29 +1,44 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
+@pytest.mark.it('You should create a function named "data_transformer"')
+def test_variable_exists(app):
+    try:
+        assert app.data_transformer
+    except AttributeError:
+        raise AttributeError('The function "data_transformer" should exists')
 
-@pytest.mark.it("Nice work!!! the transformed_data variable is passed")
-def test_output(capsys, app):
-    import app
-    captured = capsys.readouterr()
-    assert "['Mario Montes', 'Joe Biden', 'Bill Clon', 'Hilary Mccafee', 'Bobby Mc birth']\n" in captured.out
-
-@pytest.mark.it("Using map function")
-def test_map():
-    f = open(os.path.dirname(os.path.abspath(__file__)) + '/app.py')
-    content = f.read()
-    assert content.find("map") > 0
-
-@pytest.mark.it("Create the function my_var")
-def test_function_exists(app):
+@pytest.mark.it('The function named data_transformer should return the correct output')
+def test_function_value1(app):
     try:
-        app.my_var
+        incoming_ajax_data = [
+	        { "name": 'Mario', "last_name": 'Montes' },
+	        { "name": 'Joe', "last_name": 'Biden' },
+	        { "name": 'Bill', "last_name": 'Clon' },
+	        { "name": 'Hilary', "last_name": 'Mccafee' },
+	        { "name": 'Bobby', "last_name": 'Mc birth' }
+        ]
+
+        assert app.data_transformer(incoming_ajax_data) == ['Mario Montes', 'Joe Biden', 'Bill Clon', 'Hilary Mccafee', 'Bobby Mc birth']
     except AttributeError:
-        raise AttributeError("The function 'my_var' should exist on app.py")
+        raise AttributeError("The variable 'transformed_data' should have the correct value")
 
-@pytest.mark.it("Create the variable transformedData")
-def test_variable_exists(app):
+@pytest.mark.it('The function named data_transformer should return the correct output (Testing with a different list)')
+def test_function_value2(app):
     try:
-        app.transformedData
+        incoming_ajax_data = [
+	        { "name": 'Donald', "last_name": 'Trump' },
+	        { "name": 'Cristiano', "last_name": 'Ronaldo' },
+	        { "name": 'Lebron', "last_name": 'James' },
+	        { "name": 'Steve', "last_name": 'Jobs' }
+        ]
+
+        assert app.data_transformer(incoming_ajax_data) == ['Donald Trump', 'Cristiano Ronaldo', 'Lebron James', 'Steve Jobs']
     except AttributeError:
-        raise AttributeError("The variable 'transformedData' should exist on app.py")
\ No newline at end of file
+        raise AttributeError("The variable 'transformed_data' should have the correct value")
+
+@pytest.mark.it("You should use the map method")
+def test_map_usage():
+    f = open(os.path.dirname(os.path.abspath(__file__)) + '/app.py')
+    content = f.read()
+    assert re.search(r"map\s*\(", content)
diff --git a/exercises/13-Filter_list/README.es.md b/exercises/13-Filter_list/README.es.md
index 39cb5cce..b40c1cfd 100644
--- a/exercises/13-Filter_list/README.es.md
+++ b/exercises/13-Filter_list/README.es.md
@@ -1,16 +1,17 @@
-# `13` Filtrar una lista
+# `13` Filter list
+
+Otra función de iteración en Python es la función `filter()`.
 
-Otra función de iteración en python es la función `filter()`.
 Su propósito principal es remover elementos de la lista original y devolver una nueva lista con el resultado.
 
-El código de la izquierda está filtrando los números impares de la lista `allNumbers`.
+El código de la izquierda está filtrando los números impares de la lista `all_numbers`.
 
 ## 📝 Instrucciones:
 
 1. Por favor, actualiza la función de filtrado para que filtre todos los números mayores que `10`.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 [ 23, 12, 35, 54, 21, 534, 23, 42 ]
-```
\ No newline at end of file
+```
diff --git a/exercises/13-Filter_list/README.md b/exercises/13-Filter_list/README.md
index b161faad..ca6f6cc6 100644
--- a/exercises/13-Filter_list/README.md
+++ b/exercises/13-Filter_list/README.md
@@ -1,17 +1,17 @@
 # `13` Filter list
 
-Another looping function that is available on python is the `filter()` function.
+Another looping function that is available in Python is the `filter()` function.
 
 Its main purpose is to remove elements from the original list and return a new list with the result.
 
-The code on the left is filtering the odd numbers from the `allNumbers` list.
+The code on the left is filtering the odd numbers from the `all_numbers` list.
 
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Please update the filtering function so it filters all the numbers bigger than `10`.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 [ 23, 12, 35, 54, 21, 534, 23, 42 ]
-```
\ No newline at end of file
+```
diff --git a/exercises/13-Filter_list/app.py b/exercises/13-Filter_list/app.py
index 52aeae07..0f91fe6c 100644
--- a/exercises/13-Filter_list/app.py
+++ b/exercises/13-Filter_list/app.py
@@ -1,7 +1,10 @@
-allNumbers = [23,12,35,5,3,2,3,54,3,21,534,23,42,1]
+all_numbers = [23,12,35,5,3,2,3,54,3,21,534,23,42,1]
 
 
-def filter_function(items):
-    return items % 2 ==0
-greater_than = list(filter(filter_function, allNumbers))
-print(greater_than)
\ No newline at end of file
+def filter_function(item):
+    # Update here
+    return item % 2 == 1
+    
+greater_than_ten = list(filter(filter_function, all_numbers))
+
+print(greater_than_ten)
diff --git a/exercises/13-Filter_list/solution.hide.py b/exercises/13-Filter_list/solution.hide.py
new file mode 100644
index 00000000..b7dbf791
--- /dev/null
+++ b/exercises/13-Filter_list/solution.hide.py
@@ -0,0 +1,10 @@
+all_numbers = [23,12,35,5,3,2,3,54,3,21,534,23,42,1]
+
+
+def filter_function(item):
+    # Update here
+    return item > 10
+    
+greater_than_ten = list(filter(filter_function, all_numbers))
+
+print(greater_than_ten)
diff --git a/exercises/13-Filter_list/test.py b/exercises/13-Filter_list/test.py
index c84a5ee7..8992795b 100644
--- a/exercises/13-Filter_list/test.py
+++ b/exercises/13-Filter_list/test.py
@@ -1,7 +1,7 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Good!!! 😎 Maybe your are smart!!!")
+@pytest.mark.it("You should only filter numbers greater than 10")
 def test_output(capsys, app):
     import app
     captured = capsys.readouterr()
@@ -12,4 +12,4 @@ def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"filter")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
diff --git a/exercises/13.1-Filter_and_list/README.es.md b/exercises/13.1-Filter_and_list/README.es.md
index 5b34c49a..d7b89f90 100644
--- a/exercises/13.1-Filter_and_list/README.es.md
+++ b/exercises/13.1-Filter_and_list/README.es.md
@@ -1,12 +1,14 @@
-# `13.1` Filtrar Listas
+# `13.1` Filter list
 
-Aquí hay otro ejemplo en el se usa `filter()` en una lista en python. Este algoritmo filtra la lista `all_numbers` y retorna una nueva lista solo con los números impares:
+Aquí hay otro ejemplo donde se usa `filter()` en una lista en Python. 
+
+Este algoritmo filtra la lista `all_numbers` y retorna una nueva lista solo con los números impares:
 
 ```py
 all_numbers = [23,12,35,5,3,2,3,54,3,21,534,23,42,1]
 
-def my_function(numb):
-    return numb % 2 == 0
+def my_function(number):
+    return number % 2 == 1
 
 odd_numbers = list(filter(my_function, all_numbers))
 print(odd_numbers)
@@ -14,11 +16,11 @@ print(odd_numbers)
 
 ## 📝 Instrucciones:
 
-1. Escribe el código necesario para obtener una lista `resulting_names` solo on los nombres que empiezan con la letra R.
+1. Escribe el código necesario para obtener una lista `resulting_names` solo con los nombres que empiezan con la letra "R".
 
 2. Usa la función `filter()`.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 ['Romario', 'Roosevelt']
diff --git a/exercises/13.1-Filter_and_list/README.md b/exercises/13.1-Filter_and_list/README.md
index ce2a4da7..b1b8b871 100644
--- a/exercises/13.1-Filter_and_list/README.md
+++ b/exercises/13.1-Filter_and_list/README.md
@@ -1,14 +1,14 @@
 # `13.1` Filter list
 
-This is another example using `filter()` list in python.
+This is another example using `filter()` list in Python.
 
 For example, this algorithm filters the `all_numbers` list and returns a new list with only the odds numbers:
 
 ```py
 all_numbers = [23,12,35,5,3,2,3,54,3,21,534,23,42,1]
 
-def my_function(numb):
-    return numb % 2 == 0
+def my_function(number):
+    return number % 2 == 1
 
 odd_numbers = list(filter(my_function, all_numbers))
 print(odd_numbers)
@@ -16,13 +16,12 @@ print(odd_numbers)
 
 ## 📝 Instructions:
 
-1. Complete the code to make it fill the `resulting_names` list with only the names that start with letter R.
+1. Complete the code to make it fill the `resulting_names` list with only the names that start with the letter "R".
 
 2. Use the `filter()` function.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
-The console expected:
 ['Romario', 'Roosevelt']
 ```
diff --git a/exercises/13.1-Filter_and_list/app.py b/exercises/13.1-Filter_and_list/app.py
index a8018f5d..b9e376e0 100644
--- a/exercises/13.1-Filter_and_list/app.py
+++ b/exercises/13.1-Filter_and_list/app.py
@@ -1,7 +1,6 @@
+all_names = ["Romario", "Boby", "Roosevelt", "Emiliy", "Michael", "Greta", "Patricia", "Danzalee"]
 
-all_names = ["Romario","Boby","Roosevelt","Emiliy", "Michael", "Greta", "Patricia", "Danzalee"]
-
-#Your code go here:
+# Your code here
 
 print(resulting_names)
 
diff --git a/exercises/13.1-Filter_and_list/solution.hide.py b/exercises/13.1-Filter_and_list/solution.hide.py
new file mode 100644
index 00000000..fef38903
--- /dev/null
+++ b/exercises/13.1-Filter_and_list/solution.hide.py
@@ -0,0 +1,11 @@
+all_names = ["Romario", "Boby", "Roosevelt", "Emiliy", "Michael", "Greta", "Patricia", "Danzalee"]
+
+# Your code here
+
+def filter_function(name):
+    # Update here
+    return name[0].lower() == "r"
+    
+resulting_names = list(filter(filter_function, all_names))
+
+print(resulting_names)
diff --git a/exercises/13.1-Filter_and_list/test.py b/exercises/13.1-Filter_and_list/test.py
index 0e279801..3de4b681 100644
--- a/exercises/13.1-Filter_and_list/test.py
+++ b/exercises/13.1-Filter_and_list/test.py
@@ -1,13 +1,13 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Cool!!! 🤩 You have names only with 'R' ")
+@pytest.mark.it("The output should contain names that begin with "R" only")
 def test_output(capsys, app):
     import app
     captured = capsys.readouterr()
     assert "['Romario', 'Roosevelt']\n" in captured.out
 
-@pytest.mark.it("Using filter function")
+@pytest.mark.it("Use the filter function")
 def test_map():
     f = open(os.path.dirname(os.path.abspath(__file__)) + '/app.py')
     content = f.read()
@@ -18,4 +18,4 @@ def test_map():
 #     try:
 #         app.resulting_names
 #     except AttributeError:
-#         raise AttributeError("The variable 'resulting_names' should exist on app.py")
\ No newline at end of file
+#         raise AttributeError("The variable 'resulting_names' should exist on app.py")
diff --git a/exercises/13.2-filter_done_tasks/README.es.md b/exercises/13.2-filter_done_tasks/README.es.md
index 95ef34bd..fc2639b7 100644
--- a/exercises/13.2-filter_done_tasks/README.es.md
+++ b/exercises/13.2-filter_done_tasks/README.es.md
@@ -1,11 +1,11 @@
-# `13.2` Filtrar las tareas realizadas
+# `13.2` Filter done tasks
 
 ## 📝 Instrucciones:
 
 1. Usa la función `filter()` para eliminar todas las tareas pendientes de la lista de tareas e imprime la nueva lista en la consola.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
 [{'label': 'Eat my lunch', 'done': True}, {'label': 'Replit the finishes', 'done': True}, {'label': 'Read a book', 'done': True}]
-```
\ No newline at end of file
+```
diff --git a/exercises/13.2-filter_done_tasks/README.md b/exercises/13.2-filter_done_tasks/README.md
index 2d7a6e99..2ba97d30 100644
--- a/exercises/13.2-filter_done_tasks/README.md
+++ b/exercises/13.2-filter_done_tasks/README.md
@@ -1,11 +1,11 @@
 # `13.2` Filter done tasks
 
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Use the `filter()` function to remove all the undone tasks from the tasks list and print the new list on the console.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
 [{'label': 'Eat my lunch', 'done': True}, {'label': 'Replit the finishes', 'done': True}, {'label': 'Read a book', 'done': True}]
-  ```
\ No newline at end of file
+```
diff --git a/exercises/13.2-filter_done_tasks/app.py b/exercises/13.2-filter_done_tasks/app.py
index 64bf3925..2a69b63f 100644
--- a/exercises/13.2-filter_done_tasks/app.py
+++ b/exercises/13.2-filter_done_tasks/app.py
@@ -1,4 +1,3 @@
-
 tasks = [
 	{ "label": 'Eat my lunch', "done": True },
 	{ "label": 'Make the bed', "done": False },
@@ -11,5 +10,5 @@
 ]
 
 
-#Your code go here:
+# Your code here
 
diff --git a/exercises/13.2-filter_done_tasks/solution.hide.py b/exercises/13.2-filter_done_tasks/solution.hide.py
new file mode 100644
index 00000000..c6b27533
--- /dev/null
+++ b/exercises/13.2-filter_done_tasks/solution.hide.py
@@ -0,0 +1,19 @@
+tasks = [
+	{ "label": 'Eat my lunch', "done": True },
+	{ "label": 'Make the bed', "done": False },
+	{ "label": 'Have some fun', "done": False },
+	{ "label": 'Finish the replits', "done": False },
+	{ "label": 'Replit the finishes', "done": True },
+	{ "label": 'Ask for a raise', "done": False },
+	{ "label": 'Read a book', "done": True },
+	{ "label": 'Make a trip', "done": False }
+]
+
+
+# Your code here
+def filter_done_tasks(task):
+    return task["done"]
+
+done_tasks = list(filter(filter_done_tasks, tasks))
+
+print(done_tasks)
diff --git a/exercises/13.2-filter_done_tasks/test.py b/exercises/13.2-filter_done_tasks/test.py
index 2d46b0e0..54a22d31 100644
--- a/exercises/13.2-filter_done_tasks/test.py
+++ b/exercises/13.2-filter_done_tasks/test.py
@@ -1,7 +1,7 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Good job!!! 😃 the True tasks are passed")
+@pytest.mark.it("You should only print the tasks that are done")
 def test_output(capsys, app):
     import app
     captured = capsys.readouterr()
@@ -12,4 +12,4 @@ def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"filter")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
diff --git a/exercises/13.3-Filter_list_strings/README.es.md b/exercises/13.3-Filter_list_strings/README.es.md
index 862e2a8e..1551fadd 100644
--- a/exercises/13.3-Filter_list_strings/README.es.md
+++ b/exercises/13.3-Filter_list_strings/README.es.md
@@ -1,4 +1,4 @@
-# `13.3` Filtrar una lista de texto
+# `13.3` Filter list string
 
 ## 📝 Instrucciones:
 
@@ -6,11 +6,10 @@
 
 2. El string es `'am'`
 
-3. La búsqueda NO debería ser sensible a mayúsculas (`case Sensitive`).
+3. La búsqueda NO debería ser sensible a mayúsculas/minusculas (case sensitive).
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
-Resultado:
-['Liam', 'William', 'James', 'Benjamin', 'Samuel', 'Camila']
-```
\ No newline at end of file
+['Liam', 'William', 'James', 'Benjamin', 'Amelia', 'Samuel', 'Camila']
+```
diff --git a/exercises/13.3-Filter_list_strings/README.md b/exercises/13.3-Filter_list_strings/README.md
index 5999378b..87b6459f 100644
--- a/exercises/13.3-Filter_list_strings/README.md
+++ b/exercises/13.3-Filter_list_strings/README.md
@@ -1,16 +1,15 @@
 # `13.3` Filter list string
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Given a list of names called `names` please create a function that filters the list with only the names that contain the given string.
+1. Given a list of `names` please create a function that filters the list with only the names that contain the given string.
 
 2. The given string is `'am'`
 
 3. The search should NOT be Case Sensitive.
 
-## Expected result:
+## 💻 Expected result:
 
 ```py
-Result:
-['Liam', 'William', 'James', 'Benjamin', 'Samuel', 'Camila']
+['Liam', 'William', 'James', 'Benjamin', 'Amelia', 'Samuel', 'Camila']
 ```
diff --git a/exercises/13.3-Filter_list_strings/app.py b/exercises/13.3-Filter_list_strings/app.py
index b9c6af6b..af96ba6c 100644
--- a/exercises/13.3-Filter_list_strings/app.py
+++ b/exercises/13.3-Filter_list_strings/app.py
@@ -1,9 +1,3 @@
+names = ['Liam','Emma','Noah','Olivia','William','Ava','James','Isabella','Logan','Sophia','Benjamin','Mia','Mason','Charlotte','Elijah','Amelia','Oliver','Evelyn','Jacob','Abigail','Lucas','Harper','Michael','Emily','Alexander','Elizabeth','Ethan','Avery','Daniel','Sofia','Matthew','Ella','Aiden','Madison','Henry','Scarlett','Joseph','Victoria','Jackson','Aria','Samuel','Grace','Sebastian','Chloe','David','Camila','Carter','Penelope','Wyatt','Riley']
 
-names = ['Liam','Emma','Noah','Olivia','William','Ava','James','Isabella','Logan','Sophia',
-'Benjamin','Mia','Mason','Charlotte','Elijah','Amelia','Oliver','Evelyn','Jacob','Abigail',
-'Lucas','Harper','Michael','Emily','Alexander','Elizabeth','Ethan','Avery','Daniel','Sofia',
-'Matthew','Ella','Aiden','Madison','Henry','Scarlett','Joseph','Victoria','Jackson','Aria',
-'Samuel','Grace','Sebastian','Chloe','David','Camila','Carter','Penelope','Wyatt','Riley']
-
-
-#Your code go here:
+# Your code here
diff --git a/exercises/13.3-Filter_list_strings/solution.hide.py b/exercises/13.3-Filter_list_strings/solution.hide.py
new file mode 100644
index 00000000..47421438
--- /dev/null
+++ b/exercises/13.3-Filter_list_strings/solution.hide.py
@@ -0,0 +1,6 @@
+names = ['Liam','Emma','Noah','Olivia','William','Ava','James','Isabella','Logan','Sophia','Benjamin','Mia','Mason','Charlotte','Elijah','Amelia','Oliver','Evelyn','Jacob','Abigail','Lucas','Harper','Michael','Emily','Alexander','Elizabeth','Ethan','Avery','Daniel','Sofia','Matthew','Ella','Aiden','Madison','Henry','Scarlett','Joseph','Victoria','Jackson','Aria','Samuel','Grace','Sebastian','Chloe','David','Camila','Carter','Penelope','Wyatt','Riley']
+
+# Your code here
+filtered = list(filter(lambda name: 'am' in name.lower(), names))
+
+print(filtered)
diff --git a/exercises/13.3-Filter_list_strings/test.py b/exercises/13.3-Filter_list_strings/test.py
index ab83c7a8..e7d575b7 100644
--- a/exercises/13.3-Filter_list_strings/test.py
+++ b/exercises/13.3-Filter_list_strings/test.py
@@ -1,14 +1,14 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Awesome!!!🤓You have the persons with parameter include")
+@pytest.mark.it("You should only output the names that contain the string 'am'")
 def test_output(capsys, app):
     import app
     captured = capsys.readouterr()
-    assert "['Liam', 'William', 'James', 'Benjamin', 'Samuel', 'Camila']\n" in captured.out
+    assert "['Liam', 'William', 'James', 'Benjamin', 'Amelia', 'Samuel', 'Camila']\n" in captured.out
 
-@pytest.mark.it("Using filter function")
+@pytest.mark.it("Use the filter function")
 def test_map():
     f = open(os.path.dirname(os.path.abspath(__file__)) + '/app.py')
     content = f.read()
-    assert content.find("filter") > 0
\ No newline at end of file
+    assert content.find("filter") > 0
diff --git a/exercises/13.4-Making_HTML_with_filter_and_maP/README.es.md b/exercises/13.4-Making_HTML_with_filter_and_maP/README.es.md
index 1170098c..8b98fe7d 100644
--- a/exercises/13.4-Making_HTML_with_filter_and_maP/README.es.md
+++ b/exercises/13.4-Making_HTML_with_filter_and_maP/README.es.md
@@ -1,17 +1,15 @@
-# `13.4` Haciendo HTML usando las funciones `filter` y `map`
+# `13.4` Making HTML with `filter` and `map` function
 
 ## 📝 Instrucciones:
 
-1. Crea las funciones `generate_li` y `filter_colors` para hacer que el ejercicio imprima el siguiente HTML solo con colores cuya propiedad sexy sea verdadero.
+1. Crea las funciones `generate_li` y `filter_colors` para hacer que el ejercicio imprima el siguiente HTML solo con colores cuya propiedad `sexy` sea `True`.
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
 ```py
-RedOrangePinkViolet 
-# Rojo - Naranjo - Rosado - Violeta
+['Red', 'Orange', 'Pink', 'Violet']
 ```
 
 ## 💡 Pista:
 
-+ Posiblemente tengas que usar las funciones `filter()` y `map()`
-+ Asigna (`set()`) valores a las nuevas variables.
++ Probablemente sea buena idea utilizar las funciones `filter()` y `map()`.
diff --git a/exercises/13.4-Making_HTML_with_filter_and_maP/README.md b/exercises/13.4-Making_HTML_with_filter_and_maP/README.md
index c6829b61..42e35bca 100644
--- a/exercises/13.4-Making_HTML_with_filter_and_maP/README.md
+++ b/exercises/13.4-Making_HTML_with_filter_and_maP/README.md
@@ -1,19 +1,15 @@
-# `13.4` Making HTML using filter function and map function
+# `13.4` Making HTML with `filter` and `map` function
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Create `generate_li` and `filter_colors` function to make the exercise print the following HTML with only the sexy colors:
+1. Create `generate_li` and `filter_colors` functions to make the exercise print the following HTML with only the sexy colors:
 
-
-## Resultado esperado:
+## 💻 Expected result:
 
 ```py
-Expected:
-RedOrangePinkViolet
+['Red', 'Orange', 'Pink', 'Violet']
 ```
 
 ## 💡 Hint:
 
-+ Maybe you have to use `filter()` and `map()` function
-
-+ `set()` values to the new variables
++ You probably have to use `filter()` and `map()` function.
diff --git a/exercises/13.4-Making_HTML_with_filter_and_maP/app.py b/exercises/13.4-Making_HTML_with_filter_and_maP/app.py
index 9afb26dd..979857d7 100644
--- a/exercises/13.4-Making_HTML_with_filter_and_maP/app.py
+++ b/exercises/13.4-Making_HTML_with_filter_and_maP/app.py
@@ -8,5 +8,5 @@
 	{"label": 'Purple', "sexy": False},
 ]
 
-#Your code go here:
+# Your code here
 
diff --git a/exercises/13.4-Making_HTML_with_filter_and_maP/solution.hide.py b/exercises/13.4-Making_HTML_with_filter_and_maP/solution.hide.py
new file mode 100644
index 00000000..11981acc
--- /dev/null
+++ b/exercises/13.4-Making_HTML_with_filter_and_maP/solution.hide.py
@@ -0,0 +1,21 @@
+all_colors = [
+	{"label": 'Red', "sexy": True},
+	{"label": 'Pink', "sexy": False},
+	{"label": 'Orange', "sexy": True},
+	{"label": 'Brown', "sexy": False},
+	{"label": 'Pink', "sexy": True},
+	{"label": 'Violet', "sexy": True},
+	{"label": 'Purple', "sexy": False},
+]
+
+# Your code here
+def generate_li(color):
+    return f"{color['label']}"
+
+def filter_colors(color):
+    return color["sexy"]
+
+sexy_colors = list(filter(filter_colors, all_colors))
+formatted_colors = list(map(generate_li, sexy_colors))
+
+print(formatted_colors)
diff --git a/exercises/13.4-Making_HTML_with_filter_and_maP/test.py b/exercises/13.4-Making_HTML_with_filter_and_maP/test.py
index 596b9e1e..0766f914 100644
--- a/exercises/13.4-Making_HTML_with_filter_and_maP/test.py
+++ b/exercises/13.4-Making_HTML_with_filter_and_maP/test.py
@@ -1,11 +1,11 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Print the list of color in the console")
+@pytest.mark.it("Print the list of sexy colors in the console wrapped in a  tag")
 def test_output(capsys, app):
     import app
     captured = capsys.readouterr()
-    assert "RedOrangePinkViolet\n" in captured
+    assert "['Red', 'Orange', 'Pink', 'Violet']\n" in captured
 
 @pytest.mark.it("Create the function generate_li")
 def test_variable_exists(app):
@@ -32,4 +32,4 @@ def test_filter():
 def test_map():
     f = open(os.path.dirname(os.path.abspath(__file__)) + '/app.py')
     content = f.read()
-    assert content.find("map")
\ No newline at end of file
+    assert content.find("map")
diff --git a/exercises/14-Loop-dictionary/README.es.md b/exercises/14-Loop-dictionary/README.es.md
index 66d9e192..7a7a33f7 100644
--- a/exercises/14-Loop-dictionary/README.es.md
+++ b/exercises/14-Loop-dictionary/README.es.md
@@ -1,37 +1,47 @@
-# `14` Loop a Dictionary
+# `14` Loop A Dictionary
 
-Puedes pensar en un diccionario como en una lista con posiciones no numéricas:
+Los diccionarios nos permiten identificar cada elemento por una clave `key`, a diferencia de las listas en donde simplemente hay valores e índices. Para definir un diccionario, se encierra el listado de valores entre llaves. Las parejas de clave y valor se separan con comas, y la clave y el valor se separan con dos puntos: 
+
+```py
+{
+    "clave": valor,
+    "otra_clave": otro_valor, 
+    ...
+}
+```
+
+### Puedes pensar en un diccionario como en una lista con posiciones no numéricas:
 
 ```python
-list = ["a","b","c"]
+list = ["a", "b", "c"]
 dictionary = { "one": "a", "two": "b", "three": "c"}
 ```
 
-#### Cómo obtener valores de un diccionario (muy similar a las listas):
+### Cómo obtener valores de un diccionario (muy similar a las listas):
 
 ```python
 person = { "name": "Juan", "lastname": "Contreras" }
-print(person["name"]) # Salida: "Juan"
+print(person["name"])  # Salida: "Juan"
 ```
 
-#### Cómo añadirle un nuevo valor a un diccionario:
+### Cómo añadirle un nuevo valor a un diccionario:
 
 ```python
 person["age"] = 22
-print(person) # Salida: { "name": "Juan", "lastname": "Contreras", "age": 22 }
+print(person)  # Salida: { "name": "Juan", "lastname": "Contreras", "age": 22 }
 ```
 
-#### Para hacerle un bucle en una lista, puedes hacer lo siguiente:
+### Para hacer un bucle en un diccionario, puedes hacer lo siguiente:
 
 ```python
 spanish_translations = { "dog": "perro", "house": "casa", "cat": "gato" }
 
 for key in spanish_translations:
-    print(key) # <- salida: "dog",  "house", "cat"
-    print(spanish_translations[key]) # <- salida: "perro",  "casa", "gato"
+    print(key)  # <-- Salida: "dog", "house", "cat"
+    print(spanish_translations[key])  # <-- Salida: "perro", "casa", "gato"
 ```
 
-## 📝Instrucciones:
+## 📝 Instrucciones:
 
 1. Añade programáticamente las siguientes traducciones al diccionario `spanish_translations`:
 
@@ -40,3 +50,9 @@ love -> amor
 code -> codigo
 smart -> inteligente
 ```
+
+## 💻 Resultado esperado:
+
+```py
+{'dog': 'perro', 'house': 'casa', 'cat': 'gato', 'love': 'amor', 'code': 'codigo', 'smart': 'inteligente'}
+```
diff --git a/exercises/14-Loop-dictionary/README.md b/exercises/14-Loop-dictionary/README.md
index 3cfc2037..9e5c686c 100644
--- a/exercises/14-Loop-dictionary/README.md
+++ b/exercises/14-Loop-dictionary/README.md
@@ -1,43 +1,58 @@
 # `14` Loop A Dictionary
 
-You can think of a dictionary like a list with non-numerical positions:
+The dictionaries allow us to identify each element by a `key`, opposed to lists where there are only values and indexes. To define a dictionary, the list of values is enclosed in curly braces. Key and value pairs are separated by commas, and keys are separated from values by colons: 
+
+```py
+{
+    "key": value,
+    "other_key": other_value,
+    ...
+}
+```
+
+### You can think of a dictionary like a list with non-numerical positions:
 
 ```python
-list = ["a","b","c"]
-dictionary = { "one": "a", "two": "b", "three": "c"}
+list = ["a", "b", "c"]
+dictionary = { "one": "a", "two": "b", "three": "c" }
 ```
 
-#### How to retrieve dictonary values (very similar to lists):
+### How to retrieve dictionary values (very similar to lists):
 
 ```python
 person = { "name": "Juan", "lastname": "Contreras" }
-print(person["name"]) # Output: "Juan"
+print(person["name"])  # Output: "Juan"
 ```
 
-#### How to add new value to dictionary:
+### How to add a new value to the dictionary:
 
 ```python
 person["age"] = 22
-print(person) # Output: { "name": "Juan", "lastname": "Contreras", "age": 22 }
-
+print(person)  # Output: { "name": "Juan", "lastname": "Contreras", "age": 22 }
 ```
 
-In order to loop a list you can do:
+### In order to loop a dictionary, you can do:
 
 ```python
 spanish_translations = { "dog": "perro", "house": "casa", "cat": "gato" }
 
 for key in spanish_translations:
-    print(key) # <- output: "dog",  "house", "cat"
-    print(spanish_translations[key]) # <- output: "perro",  "casa", "gato"
+    print(key)  # <-- Output: "dog", "house", "cat"
+    print(spanish_translations[key])  # <-- Output: "perro", "casa", "gato"
 ```
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Programatically add the following translations to the `spanish_translations` dictionary:
+1. Programmatically add the following translations to the `spanish_translations` dictionary:
 
 ```txt
 love -> amor
 code -> codigo
 smart -> inteligente
 ```
+
+## 💻 Expected output:
+
+```py
+{'dog': 'perro', 'house': 'casa', 'cat': 'gato', 'love': 'amor', 'code': 'codigo', 'smart': 'inteligente'}
+```
diff --git a/exercises/14-Loop-dictionary/app.py b/exercises/14-Loop-dictionary/app.py
index dfd9bcc3..8903bfb0 100644
--- a/exercises/14-Loop-dictionary/app.py
+++ b/exercises/14-Loop-dictionary/app.py
@@ -1,8 +1,7 @@
-
 spanish_translations = { "dog": "perro", "house": "casa", "cat": "gato" }
+# Your code here
 
 
-
-print("Translation", spanish_translations["dog"])
-print("All", spanish_translations)
-
+# Don't touch the code below
+print("Translation:", spanish_translations["dog"])
+print(spanish_translations)
diff --git a/exercises/14-Loop-dictionary/solution.hide.py b/exercises/14-Loop-dictionary/solution.hide.py
new file mode 100644
index 00000000..4db00ee5
--- /dev/null
+++ b/exercises/14-Loop-dictionary/solution.hide.py
@@ -0,0 +1,10 @@
+spanish_translations = { "dog": "perro", "house": "casa", "cat": "gato" }
+# Your code here
+
+spanish_translations["love"] = "amor"
+spanish_translations["code"] = "codigo"
+spanish_translations["smart"] = "inteligente"
+
+# Don't touch the code below
+print("Translation:", spanish_translations["dog"])
+print(spanish_translations)
diff --git a/exercises/14-Loop-dictionary/test.py b/exercises/14-Loop-dictionary/test.py
index f8e131c2..adbec2b9 100644
--- a/exercises/14-Loop-dictionary/test.py
+++ b/exercises/14-Loop-dictionary/test.py
@@ -1,35 +1,29 @@
 import io, sys, os, pytest, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("You should add `love` programatically to the dictionary")
+@pytest.mark.it("You should add `love` programmatically to the dictionary")
 def test_love():
     f = open(os.path.dirname(os.path.abspath(__file__))+'/app.py')
     content = f.read()
-    value = False
-    if(content.find("spanish_translations['love'] = 'amor'") > 0 or content.find('spanish_translations["love"] = "amor"') > 0):
-        value = True
-    assert value == True
+    regex = re.compile(r"spanish_translations\[\s*[\'\"]love[\'\"]\s*\]\s*\=\s*[\'\"]amor[\'\"]")
+    assert bool(regex.search(content)) == True
 
-@pytest.mark.it("You should add `code` programatically to the dictionary")
+@pytest.mark.it("You should add `code` programmatically to the dictionary")
 def test_code():
     f = open(os.path.dirname(os.path.abspath(__file__))+'/app.py')
     content = f.read()
-    value = False
-    if(content.find("spanish_translations['code'] = 'codigo'") > 0 or content.find('spanish_translations["code"] = "codigo"') > 0):
-        value = True
-    assert value == True
+    regex = re.compile(r"spanish_translations\[\s*[\'\"]code[\'\"]\s*\]\s*\=\s*[\'\"]codigo[\'\"]")
+    assert bool(regex.search(content)) == True
 
-@pytest.mark.it("You should add `smart` programatically to the dictionary")
+@pytest.mark.it("You should add `smart` programmatically to the dictionary")
 def test_smart():
     f = open(os.path.dirname(os.path.abspath(__file__))+'/app.py')
     content = f.read()
-    value = False
-    if(content.find("spanish_translations['smart'] = 'inteligente'") > 0 or content.find('spanish_translations["smart"] = "inteligente"') > 0):
-        value = True
-    assert value == True
+    regex = re.compile(r"spanish_translations\[\s*[\'\"]smart[\'\"]\s*\]\s*\=\s*[\'\"]inteligente[\'\"]")
+    assert bool(regex.search(content)) == True
 
-@pytest.mark.it("You should print in the console the dictionary with proper translations")
+@pytest.mark.it("You should print in the console the dictionary with the proper translations")
 def test_multp(capsys, app):
     import app
     captured = capsys.readouterr()
-    assert "All {'dog': 'perro', 'house': 'casa', 'cat': 'gato', 'love': 'amor', 'code': 'codigo', 'smart': 'inteligente'}" in captured.out
\ No newline at end of file
+    assert "{'dog': 'perro', 'house': 'casa', 'cat': 'gato', 'love': 'amor', 'code': 'codigo', 'smart': 'inteligente'}" in captured.out
diff --git a/exercises/14.1-letter_counter/README.es.md b/exercises/14.1-letter_counter/README.es.md
new file mode 100644
index 00000000..80c52038
--- /dev/null
+++ b/exercises/14.1-letter_counter/README.es.md
@@ -0,0 +1,20 @@
+# `14.1` Letter counter
+
+## 📝 Instrucciones:
+
+Nuestro cliente necesita un programa que cuente las repeticiones de las letras en una cadena de caracteres dada.
+
+Por ejemplo, el string `"Hello World"` contiene las siguientes repeticiones: `h=1 e=1 l=3 o=2 w=1 r=1 d=1`.
+
+1. Cuenta las letras usadas en el string `par` e imprime el número de veces que se repite cada letra en el string.
+
+2. Las mayúsculas no deberían afectar el cálculo (por ej.: si hay un string que contiene la mayúscula `A` de igual forma que la minúscula `a` deberían contarse 2).
+
+3. ¡Los espacios deben ignorarse!
+
+## 💻 Resultado esperado:
+
+```py
+print(count("Hello World"))
+# Imprime en la consola: {'h': 1, 'e': 1, 'l': 3, 'o': 2, 'w': 1, 'r': 1, 'd': 1}
+```
diff --git a/exercises/14.1-letter_counter/README.md b/exercises/14.1-letter_counter/README.md
new file mode 100644
index 00000000..37fa005d
--- /dev/null
+++ b/exercises/14.1-letter_counter/README.md
@@ -0,0 +1,20 @@
+# `14.1` Letter counter
+
+## 📝 Instructions:
+
+Our customer needs a program that counts the letter repetitions in a given string, for example:
+
+The string `"Hello World"` contains the following repetitions `h=1 e=1 l=3 o=2 w=1 r=1 d=1`.
+
+1. Count the letters of the string in the variable `par` and print the number of times a letter is repeated throughout the string.
+
+2. Capitalization should not affect the count (i.e. if there is a string that contains a capital `A` as well as a lowercase `a` the count for "a" should be 2).
+
+3. Spaces should be ignored!
+
+## 💻 Expected result:
+
+```py
+print(count("Hello World"))
+# This will print: {'h': 1, 'e': 1, 'l': 3, 'o': 2, 'w': 1, 'r': 1, 'd': 1}
+```
diff --git a/exercises/14.2-letter_counter/app.py b/exercises/14.1-letter_counter/app.py
similarity index 91%
rename from exercises/14.2-letter_counter/app.py
rename to exercises/14.1-letter_counter/app.py
index fec751a7..f4708592 100644
--- a/exercises/14.2-letter_counter/app.py
+++ b/exercises/14.1-letter_counter/app.py
@@ -1,7 +1,8 @@
 par = "Lorem ipsum dolor sit amet consectetur adipiscing elit Curabitur eget bibendum turpis Curabitur scelerisque eros ultricies venenatis mi at tempor nisl Integer tincidunt accumsan cursus"
 
 counts = {}
-#your code go here:
 
-print(counts)
+# Your code here
+
 
+print(counts)
diff --git a/exercises/14.1-letter_counter/solution.hide.py b/exercises/14.1-letter_counter/solution.hide.py
new file mode 100644
index 00000000..af60b8c9
--- /dev/null
+++ b/exercises/14.1-letter_counter/solution.hide.py
@@ -0,0 +1,14 @@
+par = "Lorem ipsum dolor sit amet consectetur adipiscing elit Curabitur eget bibendum turpis Curabitur scelerisque eros ultricies venenatis mi at tempor nisl Integer tincidunt accumsan cursus"
+
+counts = {}
+
+# Your code here
+for letter in par:
+    if letter != ' ':
+        letter = letter.lower()
+        if letter in counts:
+            counts[letter] += 1
+        else:
+            counts[letter] = 1
+
+print(counts)
diff --git a/exercises/14.2-letter_counter/test.py b/exercises/14.1-letter_counter/test.py
similarity index 89%
rename from exercises/14.2-letter_counter/test.py
rename to exercises/14.1-letter_counter/test.py
index 7e3d9d39..59385cc6 100644
--- a/exercises/14.2-letter_counter/test.py
+++ b/exercises/14.1-letter_counter/test.py
@@ -16,9 +16,9 @@ def test_for_loop():
         regex = re.compile(r"for(\s)")
         assert bool(regex.search(content)) == True
 
-@pytest.mark.it("Use if statement")
+@pytest.mark.it("Use an if statement")
 def test_if():
     with open(path, 'r') as content_file:
         content = content_file.read()
         regex = re.compile(r"if(\s)")
-        assert bool(regex.search(content)) == True
\ No newline at end of file
+        assert bool(regex.search(content)) == True
diff --git a/exercises/14.2-letter_counter/README.es.md b/exercises/14.2-letter_counter/README.es.md
deleted file mode 100644
index 0bf20b73..00000000
--- a/exercises/14.2-letter_counter/README.es.md
+++ /dev/null
@@ -1,20 +0,0 @@
-# `14.2` Contador de letras
-
-## 📝 Instrucciones:
-
-Nuestro cliente necesita un programa que cuente las repeticiones de las letras en una cadena de caracteres (`string`) dado.
-
-Por ejemplo el string `"Hello World"` contiene las siguientes repeticiones: `h=1 e=1 l=3 o=2 w=1 r=1 d=1`.
-
-1. Cuenta las letras usadas en el string `par` e imprime el número de veces que es repetida en el string.
-
-2. Las mayúsculas no deberían afectar el cáculo (por ej.: si hay un string que contiene la mayúscula "A" de igual forma que la minúscula "a" deberían comtarse 2).
-
-3. ¡Los espacios deben ignorarse!
-
-## Resultado esperado:
-
-```py
-print(count("Hello World"))
-# Imprime en la consola { "h":1 "e":1 "l":3 "o":2 "w":1 "r":1 "d":1 }
-```
diff --git a/exercises/14.2-letter_counter/README.md b/exercises/14.2-letter_counter/README.md
deleted file mode 100644
index 4ea9d3f7..00000000
--- a/exercises/14.2-letter_counter/README.md
+++ /dev/null
@@ -1,20 +0,0 @@
-# `14.2` Letter counter
-
-## 📝Instructions:
-
-Our customer needs a program that counts the letters repetitions in a given string, for example:
-
-The string "Hello World" contains the following repetitions `h=1 e=1 l=3 o=2 w=1 r=1 d=1`
-
-1. Count the letters in the string used in par and print the number of times it is repeated throughout the string.
-
-2. Capitalization should not affect the count (i.e. if there is a string that contains a capital `A` as well as a lowercase `a` the count for a should be 2).
-
-3. Spaces should be ignored!
-
-## Expected outcome:
-
-```py
-print(count("Hello World"))
-# will print on the console { "h":1 "e":1 "l":3 "o":2 "w":1 "r":1 "d":1 }
-```
diff --git a/exercises/15.1-Matrix_Builder/README.es.md b/exercises/15.1-Matrix_Builder/README.es.md
index 33bb997a..9256dd52 100644
--- a/exercises/15.1-Matrix_Builder/README.es.md
+++ b/exercises/15.1-Matrix_Builder/README.es.md
@@ -1,7 +1,6 @@
-# `15.1` Constructor de Matrix
+# `15.1` Matrix Builder
 
-Después de todo código malicioso, principalmente por parte de Mr. Smith, la Matrix tiene algunos agujeros
-y necesita ayuda para reconstruirse. Crea una matriz 1's basada en un parámetro.
+Después de un código malicioso, creado principalmente por el Sr. Smith, la Matrix tiene algunos agujeros y necesita ayuda para reconstruirse. Crea una matriz con 1's basada en un parámetro.
 
 ## 📝 Instrucciones:
 
@@ -13,9 +12,9 @@ y necesita ayuda para reconstruirse. Crea una matriz 1's basada en un parámetro
 
 2. Esta función debería devolver una lista de listas que represente la matriz. 
 
-## Resultado esperado:
+## 💻 Resultado esperado:
 
-3 debería retornar:
+Con 3 como argumento debería retornar:
 
 ```py
 [
diff --git a/exercises/15.1-Matrix_Builder/README.md b/exercises/15.1-Matrix_Builder/README.md
index 859bc28d..c90fff50 100644
--- a/exercises/15.1-Matrix_Builder/README.md
+++ b/exercises/15.1-Matrix_Builder/README.md
@@ -1,20 +1,21 @@
 # `15.1` Matrix Builder
 
-After some malicious code, mainly by Mr. Smith, the matrix has some gaping hole and it needs some help to rebuild. Create a matrix 1's based on a parameter.
+After some malicious code, mainly by Mr. Smith, the Matrix has some gaping holes, and it needs some help to rebuild. Create a matrix of 1's based on a parameter.
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Create a function called matrixBuilder, which will expect 1 parameter (an integer):
+1. Create a function called `matrix_builder`, which will expect 1 parameter (an integer):
 
 + This number represents the amount of rows and columns for the matrix.
 
 + Example: 5 means that the matrix should be 5x5.
 
-2. This function should return a list of lists that represents the matrix.
+2. This function should return a list of lists that represent the matrix.
 
-## Expected result:
+## 💻 Expected result:
+
+With 3 as an argument it should return:
 
-3 should return:
 ```py
 [
   [1, 1, 1],
diff --git a/exercises/15.1-Matrix_Builder/app.py b/exercises/15.1-Matrix_Builder/app.py
index a81402b2..fce62c1d 100644
--- a/exercises/15.1-Matrix_Builder/app.py
+++ b/exercises/15.1-Matrix_Builder/app.py
@@ -1,3 +1 @@
-#Import random
-
-#Create the function below:
+# Your code here
diff --git a/exercises/15.1-Matrix_Builder/solution.hide.py b/exercises/15.1-Matrix_Builder/solution.hide.py
new file mode 100644
index 00000000..6ffd2d60
--- /dev/null
+++ b/exercises/15.1-Matrix_Builder/solution.hide.py
@@ -0,0 +1,15 @@
+# Your code here
+def matrix_builder(n):
+    matrix = [] 
+
+    for i in range(n):
+        row = []
+        for j in range(n):
+            row.append(1)
+        matrix.append(row)
+
+    return matrix
+
+result = matrix_builder(3)
+
+print(result)
diff --git a/exercises/15.1-Matrix_Builder/test.py b/exercises/15.1-Matrix_Builder/test.py
index eb33fb80..e6d91f8a 100644
--- a/exercises/15.1-Matrix_Builder/test.py
+++ b/exercises/15.1-Matrix_Builder/test.py
@@ -8,9 +8,9 @@
 #         regex = re.compile(r"import(\s)+random")
 #         assert bool(regex.search(content)) == True
 
-exp_fn_name = "matrixBuilder"
+exp_fn_name = "matrix_builder"
 
-@pytest.mark.it("You need to print the matrix as output.")
+@pytest.mark.it("You need to print the matrix as output")
 def test_output(capsys):
     import app
     out, err = capsys.readouterr()
@@ -20,12 +20,12 @@ def test_output(capsys):
         (out.endswith("]]") or out.endswith("]]\n"))
     )
 
-@pytest.mark.it("Create the function with the correct name.")
+@pytest.mark.it("Create the function with the correct name")
 def test_function_exists(app):
     if not hasattr(app, exp_fn_name):
         pytest.fail(f"The function {exp_fn_name} should exist on app.py")
 
-@pytest.mark.it("Matrix should only have one's.")
+@pytest.mark.it("Matrix should only have 1s")
 def test_oneness(app):
     if hasattr(app, exp_fn_name):
         fn = getattr(app, exp_fn_name)    
@@ -34,7 +34,7 @@ def test_oneness(app):
             for element in row:
                 assert element == 1
 
-@pytest.mark.it("Your matrix should be simmetrical.")
+@pytest.mark.it("Your matrix should be symmetrical")
 def test_symmetry(app):
     import random
     side = random.randint(2,10) 
diff --git a/exercises/15.2-Parking_lot_check/README.es.md b/exercises/15.2-Parking_lot_check/README.es.md
index 7954cc6b..fc0b35f2 100644
--- a/exercises/15.2-Parking_lot_check/README.es.md
+++ b/exercises/15.2-Parking_lot_check/README.es.md
@@ -1,10 +1,11 @@
-# `15.2` El Parking
+# `15.2` Parking Lot
 
 Podemos usar una lista bidimensional (matriz) para representar el estado actual de un estacionamiento:
 
-
-```py
+
+  
 
+```py
 parking_state = [
   [1,0,1,1,0,1],
   [2,0,1,1,0,1],
@@ -17,8 +18,7 @@ parking_state = [
 
 ## 📝 Instrucciones:
 
-1. Crea una función `get_parking_lot()` que devuelva un objeto con `total_slots` (cantidad total de estacionamientos), `available_slots` (estacionamientos disponibles) y `occupied_slots`(estacionamientos ocupados) así:
-
+1. Crea una función `get_parking_lot()` que devuelva un diccionario con `total_slots` (cantidad total de puestos), `available_slots` (puestos disponibles) y `occupied_slots`(puestos ocupados) así:
 
 ```py
 state = {
@@ -30,8 +30,8 @@ state = {
 
 ## 💡 Pistas:
 
+- Declara las claves para almacenar los valores.
+  
 - Tienes que hacer un bucle anidado.
 
-- Declara una variable para almacenar el valor.
-
 - Compara los estados (`state`)
diff --git a/exercises/15.2-Parking_lot_check/README.md b/exercises/15.2-Parking_lot_check/README.md
index 77d63a98..f57c4a1e 100644
--- a/exercises/15.2-Parking_lot_check/README.md
+++ b/exercises/15.2-Parking_lot_check/README.md
@@ -1,8 +1,8 @@
 # `15.2` Parking Lot
 
-We can use a 2 dimensional array (matrix) to represent the current state of a parking lot like this:
+We can use a 2 dimensional list (matrix) to represent the current state of a parking lot like this:
 
-
+
 
 ```py
 parking_state = [
@@ -15,9 +15,9 @@ parking_state = [
 ]
 ```
 
-## 📝Instructions:
+## 📝 Instructions:
 
-1. Create a function get_parking_lot() that returns a dictionary with `total_slots`, `available_slots` and `occupied_slots` like the following:
+1. Create a function `get_parking_lot()` that returns a dictionary with `total_slots`, `available_slots` and `occupied_slots` like the following:
 
 ```python
 state = {
@@ -27,7 +27,7 @@ state = {
 }
 ```
 
-## 💡 Hint:
+## 💡 Hints:
 
 - Declare the key names to store the values.
 
diff --git a/exercises/15.2-Parking_lot_check/app.py b/exercises/15.2-Parking_lot_check/app.py
index 61d52fbe..e6f445f8 100644
--- a/exercises/15.2-Parking_lot_check/app.py
+++ b/exercises/15.2-Parking_lot_check/app.py
@@ -4,6 +4,4 @@
   [1,1,2]
 ]
 
-#Your code go here:
-
-
+# Your code here
diff --git a/exercises/15.2-Parking_lot_check/solution.hide.py b/exercises/15.2-Parking_lot_check/solution.hide.py
new file mode 100644
index 00000000..a330195f
--- /dev/null
+++ b/exercises/15.2-Parking_lot_check/solution.hide.py
@@ -0,0 +1,20 @@
+parking_state = [
+  [1,1,1],
+  [0,0,0],
+  [1,1,2]
+]
+
+# Your code here
+def get_parking_lot(matrix):
+  state = {'total_slots': 0, 'available_slots': 0, 'occupied_slots': 0}
+  for i in range(len(matrix)):
+    for j in range(len(matrix[i])):
+      if matrix[i][j] == 1:
+        state["occupied_slots"] += 1
+        state["total_slots"] += 1
+      elif matrix[i][j] == 2:
+        state["available_slots"] += 1
+        state["total_slots"] += 1
+  return state
+
+get_parking_lot(parking_state)
diff --git a/exercises/15.2-Parking_lot_check/test.py b/exercises/15.2-Parking_lot_check/test.py
index cc3af6f1..f58ae909 100644
--- a/exercises/15.2-Parking_lot_check/test.py
+++ b/exercises/15.2-Parking_lot_check/test.py
@@ -1,13 +1,6 @@
 import io, sys, pytest, os, re
 path = os.path.dirname(os.path.abspath(__file__))+'/app.py'
 
-@pytest.mark.it("Print the updated state ")
-def test_output(capsys, app):
-    import app
-    captured = capsys.readouterr()
-    assert "{'total_slots': 6, 'available_slots': 1, 'occupied_slots': 5}\n" in captured.out
-
-
 @pytest.mark.it("Create the function get_parking_lot")
 def test_variable_exists(app):
     try:
@@ -15,9 +8,20 @@ def test_variable_exists(app):
     except AttributeError:
         raise AttributeError("The function get_parking_lot should exist on app.py")
 
+@pytest.mark.it('The function get_parking_lot should return a dictionary with the correct values')
+def test_correct_output(app):
+    value1 = [[1,1,1], [0,0,0], [1,1,2]]
+    result1 = {'total_slots': 6, 'available_slots': 1, 'occupied_slots': 5}
+    try:
+        assert app.get_parking_lot(value1) == result1
+    except AttributeError:
+        raise AttributeError("The function get_parking_lot should exist on app.py")
 
-
-
-
-
-
+@pytest.mark.it('The function get_parking_lot should return a dictionary with the correct values. Testing with a different matrix')
+def test_different_values(app):
+    value1 = [[1,2,1,0], [0,1,0,2], [1,0,1,1]]
+    result1 = {'total_slots': 8, 'available_slots': 2, 'occupied_slots': 6}
+    try:
+        assert app.get_parking_lot(value1) == result1
+    except AttributeError:
+        raise AttributeError("The function get_parking_lot should exist on app.py")
diff --git a/exercises/16-Techno_beat/README.es.md b/exercises/16-Techno_beat/README.es.md
index 24c42cb0..b28cefe6 100644
--- a/exercises/16-Techno_beat/README.es.md
+++ b/exercises/16-Techno_beat/README.es.md
@@ -1,4 +1,4 @@
-# `16` Latidos de tecno
+# `16` Techno Beats
 
 Estás trabajando con un DJ que necesita un programa que pueda crear ritmos para sus canciones.
 
@@ -7,36 +7,29 @@ Estás trabajando con un DJ que necesita un programa que pueda crear ritmos para
 1. Crea una función `lyrics_generator` que reciba una lista. La lista pasada a la función será algo como esto:
 
 ```py
-    [0,0,1,1,0,0,0]
+[0,0,1,1,0,0,0]
 ```
-2. Por cada `0` añade el string `Boom`.
 
-3. Por cada `1` añade el string `Drop the base`.
+2. Por cada `0` añade el string `Boom`.
 
-## ❕ Adicionalmente:
+3. Por cada `1` añade el string `Drop the bass`.
 
-Si encuentras un `1` tres veces seguidas, tambíen debes añadir el string `!!!Break the base!!!`
+4. **Adicionalmente**, Si encuentras un `1` tres veces seguidas, también debes añadir el string `!!!Break the bass!!!`
 
-## 💡 Pista:
+## 💡 Pistas:
 
 - Recuerda usar variables auxiliares.
 
-- Declara una variable para almacenar.
+- Declara una variable para almacenar tus strings.
 
 - Declara una variable para contar y sumar.
 
-## Resultado esperado:
-
-```py
-+ Valor devuelto por la función:
-
-Un string compuesto por `Boom` o `Drop the base` o `!!!Break the base!!!`
-
-+ Salida esperada:
+## 💻 Resultado esperado:
 
-Boom Boom Drop the base Drop the base Boom Boom Boom
-Boom Boom Drop the base Drop the base Drop the base !!!Break the base!!! Boom Boom Boom
+```text
+Boom Boom Drop the bass Drop the bass Boom Boom Boom
+Boom Boom Drop the bass Drop the bass Drop the bass !!!Break the bass!!! Boom Boom Boom
 Boom Boom Boom
-Drop the base Boom Drop the base
-Drop the base Drop the base Drop the base !!!Break the base!!!
+Drop the bass Boom Drop the bass
+Drop the bass Drop the bass Drop the bass !!!Break the bass!!!
 ```
diff --git a/exercises/16-Techno_beat/README.md b/exercises/16-Techno_beat/README.md
index d97910e8..20a31dcb 100644
--- a/exercises/16-Techno_beat/README.md
+++ b/exercises/16-Techno_beat/README.md
@@ -1,37 +1,35 @@
 # `16` Techno Beats
 
-You are working with a DJ and he needs a program that can create a beats for his songs.
+You are working with a DJ, and he needs a program that can create beats for his songs.
 
-## 📝Instructions:
+## 📝 Instructions:
 
 1. Create a function called `lyrics_generator` that receives a list. The list passed to the function will be something like this:
 
 ```py
-    [0,0,1,1,0,0,0]
+[0,0,1,1,0,0,0]
 ```
 
 2. For each Zero you will add to the string `Boom`.
 
-3. For each One you will add to the string `Drop the base`.
+3. For each One you will add to the string `Drop the bass`.
 
-## ❕ In addition:
+4. **In Addition**, if you find the number `1` three times in a row, you should ALSO ADD to the string `!!!Break the bass!!!`
 
-If you find the number `1` three times in a row, you should ALSO ADD to the string `!!!Break the base!!!`
-
-## 💡 Hint:
+## 💡 Hints:
 
 - Remember to use auxiliary variables.
 
-- Declare a variable to store
+- Declare a variable to store your strings.
 
-- Declare a variable to count and sum
+- Declare a variable to count and sum.
 
-## Expected result:
+## 💻 Expected result:
 
-```py
-Boom Boom Drop the base Drop the base Boom Boom Boom
-Boom Boom Drop the base Drop the base Drop the base !!!Break the base!!! Boom Boom Boom
+```text
+Boom Boom Drop the bass Drop the bass Boom Boom Boom
+Boom Boom Drop the bass Drop the bass Drop the bass !!!Break the bass!!! Boom Boom Boom
 Boom Boom Boom
-Drop the base Boom Drop the base
-Drop the base Drop the base Drop the base !!!Break the base!!!
+Drop the bass Boom Drop the bass
+Drop the bass Drop the bass Drop the bass !!!Break the bass!!!
 ```
diff --git a/exercises/16-Techno_beat/app.py b/exercises/16-Techno_beat/app.py
index 725de511..5442b529 100644
--- a/exercises/16-Techno_beat/app.py
+++ b/exercises/16-Techno_beat/app.py
@@ -1,8 +1,8 @@
 
 
-# Your code go above, nothing to change after this line:
+# Your code above, nothing to change after this line
 print(lyrics_generator([0,0,1,1,0,0,0]))
 print(lyrics_generator([0,0,1,1,1,0,0,0]))
 print(lyrics_generator([0,0,0]))
 print(lyrics_generator([1,0,1]))
-print(lyrics_generator([1,1,1]))
\ No newline at end of file
+print(lyrics_generator([1,1,1]))
diff --git a/exercises/16-Techno_beat/solution.hide.py b/exercises/16-Techno_beat/solution.hide.py
new file mode 100644
index 00000000..263105c8
--- /dev/null
+++ b/exercises/16-Techno_beat/solution.hide.py
@@ -0,0 +1,24 @@
+def lyrics_generator(input_list):
+    lyrics = ""
+    count = 0
+
+    for num in input_list:
+        if num == 0:
+            lyrics += "Boom "
+            count = 0
+        elif num == 1:
+            lyrics += "Drop the bass "
+            count += 1
+
+            if count == 3:
+                lyrics += "!!!Break the bass!!! "
+                count = 0
+
+    return lyrics
+
+# Your code above, nothing to change after this line
+print(lyrics_generator([0,0,1,1,0,0,0]))
+print(lyrics_generator([0,0,1,1,1,0,0,0]))
+print(lyrics_generator([0,0,0]))
+print(lyrics_generator([1,0,1]))
+print(lyrics_generator([1,1,1]))
diff --git a/exercises/16-Techno_beat/test.py b/exercises/16-Techno_beat/test.py
index 09b0a97a..13066b12 100644
--- a/exercises/16-Techno_beat/test.py
+++ b/exercises/16-Techno_beat/test.py
@@ -10,12 +10,8 @@ def test_variable_exists(app):
         raise AttributeError("The function lyrics_generator should exist on app.py")
 
 
-@pytest.mark.it("Print the strings like song")
+@pytest.mark.it("Print the expected strings")
 def test_output(capsys, app):
     import app
     captured = capsys.readouterr()
-    assert 'Boom Boom Drop the base Drop the base Boom Boom Boom \nBoom Boom Drop the base Drop the base Drop the base !!!Break the base!!! Boom Boom Boom \nBoom Boom Boom \nDrop the base Boom Drop the base \nDrop the base Drop the base Drop the base !!!Break the base!!! \n' in captured.out
-
-
-
-
+    assert 'Boom Boom Drop the bass Drop the bass Boom Boom Boom \nBoom Boom Drop the bass Drop the bass Drop the bass !!!Break the bass!!! Boom Boom Boom \nBoom Boom Boom \nDrop the bass Boom Drop the bass \nDrop the bass Drop the bass Drop the bass !!!Break the bass!!! \n' in captured.out
diff --git a/learn.json b/learn.json
index e3ff20ce..f359e604 100644
--- a/learn.json
+++ b/learn.json
@@ -1,16 +1,34 @@
 {
-    "language": "python3",
-    "slug": "python-lists-loops",
-    "title": "Learn Python Loops and lists Interactively",
-    "repository": "https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises",
-    "preview": "https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/blob/master/preview.gif?raw=true",
-    "description": "Practice Python Lists and tuples (arrays) with interactive auto-graded exercises and video solutions.",
-    "duration": 10,
-    "difficulty": "easy",
-    "video-solutions": false,
-    "config": {
-        "editor": {
-            "version": "1.0.71"
-        }
+"language": "python3",
+"slug": "python-lists-loops",
+"title": {
+    "us": "Learn Python Loops and lists Interactively",
+    "es": "Aprende listas y bucles de Python Interactivamente"
+},
+"repository": "https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises",
+"preview": "https://github.com/4GeeksAcademy/python-lists-loops-programming-exercises/blob/master/preview.gif?raw=true",
+"description": {
+    "us": "Practice Python Lists and tuples (arrays) with interactive auto-graded exercises and video solutions",
+    "es": "Practica listas y tuplas de Python con ejercicios interactivos, auto-evaluados y con video soluiones"
+},
+"duration": 10,
+"difficulty": "easy",
+"projectType": "tutorial",
+"videoSolutions": true,
+"bugsLink": "https://github.com/learnpack/learnpack/issues/new",
+
+"editor": {
+    "version": "5.0"
+},
+"telemetry": {
+    "batch": "https://breathecode.herokuapp.com/v1/assignment/me/telemetry?asset_id=147"
+},
+"video": {
+    "intro": {
+        "es": "https://www.youtube.com/watch?v=xMg9d0KsYAk",
+        "en": "https://www.youtube.com/watch?v=xMg9d0KsYAk"
     }
 }
+
+
+}