Install MicroPython on your ESP32 board
(Updated at 03/16/2023)
Follow this step-by-step installation guide to install and use MicroPython on your ESP32 board.
What is MicroPython?
MicroPython is a Python interpreter optimized for microcontrollers like ESP32 boards. You can write Python scripts that will be directly executed on an ESP32 board. To do so, you have to flash the ESP32 board with MicroPython on it and use an IDE (for example, Thonny IDE ) to code Python scripts and send them to the ESP32.
The MicroPython firmware is available on the official website . You should use the most recent stable version and take the file with the .bin extension.
data:image/s3,"s3://crabby-images/5fe8a/5fe8aa3f16178c5bc533f66bfe6e699231a8ef73" alt="micropython download page for esp32"
The latest version of MicroPython at the time of writing this tutorial is v1.17
Note
To use the extra 4 MB of RAM on the uPesy ESP32 Wrover DevKit board, you will need to go to the download page specially designed for SPIRAM support .
There are two ways to install MicroPython on your ESP32 board: a beginner-friendly one with Thonny IDE and another one for more advanced with the command line.
Install MicroPython on an ESP32 board with Thonny IDE
For beginners, the easiest way to install MicroPython on the ESP32 is through the Thonny IDE interface.
data:image/s3,"s3://crabby-images/72495/724951622fe3a1b151d100deb6883dabf1bc4b2b" alt="Change the language in Thonny IDE"
You will use both Thonny to install MicroPython and to write all your Python scripts. To install Thonny IDE, you must go to the official website thonny.org and choose and install the correct executable according to your operating system.
The installation of Thonny is straightforward.
Tip
During the first launch, you can choose the language.
You get a classic code editor with a Python interpreter.
data:image/s3,"s3://crabby-images/4ecc6/4ecc6f328b97c7515c36de4c5651f4b952bcf40d" alt="Thonny IDE Home Page"
Warning
Before installation, remember to close the serial monitor of the Arduino IDE if the software is open; otherwise, you will be confronted with the error Unable to connect to COM5: could not open port 'COM5': PermissionError(13, 'Access is denied.', None, 5)
:
data:image/s3,"s3://crabby-images/720a5/720a5e53d92cbb9480e806bfc73c75665f063e8d" alt="serial port access denied"
Indeed, two software cannot access the same serial COM port simultaneously.
To install MicroPython on the ESP32, go to Run → Select interpreter
data:image/s3,"s3://crabby-images/2fc61/2fc610bcecea48c1bd3b47d0de162c1e92638e6e" alt="select the interpreter in thonny ide"
Choose the interpreter “MicroPython (ESP32) and click on “Install or update the firmware”.
data:image/s3,"s3://crabby-images/df8c0/df8c016fb5b2fe4db847ba87008395efd18679d8" alt="click on install micropython on esp32 from thonny ide"
If your ESP32 board does not appear in the drop-down list, check that it is connected and click on “Reload “ to update the list. Then enter the path to the MicroPython binary file, and click on click on “Install” to update the list
The complete installation is illustrated in the following animation:
data:image/s3,"s3://crabby-images/d87c9/d87c9cf5562f0885a6556a53f01d294f912d5bd4" alt="installation of micropython on the ESP32 via Thonny IDE"
Summary of the installation of Micro Python on the ESP32 in video
If all has gone well, MicroPython is properly installed on the ESP32. However, you need to ensure that Thonny uses the MicroPython interpreter on the ESP32. Just go back to the Run → Select interpreter and change it if necessary.
data:image/s3,"s3://crabby-images/93b1f/93b1fe599a3b6aecfc06c262cc5e28bb8b09a512" alt="select the micropython interpreter esp32"
Make sure Thonny IDE uses the correct MicroPython interpreter
The MicroPython interpreter for your ESP32 board should appear in Thonny:
data:image/s3,"s3://crabby-images/688d6/688d6770b9b1d9ff5f39a97beba1a910f2ceb9d7" alt="select the micropython interpreter esp32"
Note
If nothing happens, you can try clicking the STOP button, which restarts the interpreter.
data:image/s3,"s3://crabby-images/113c2/113c2a2ab2510d4e1ba318af65853a11b6dc06b3" alt="restart the micropython interpreter in thonny ide"
Install MicroPython directly on the ESP32 with esptool
For advanced users who don’t want to use Thonny IDE, you can use the communication tool directly with the ESP32 esptool.py . It is a python tool that allows, among other things, to upload a program to the ESP32 .
data:image/s3,"s3://crabby-images/4b544/4b544134acc6e74abd2e4c3cf6aff81796b95e4e" alt="esptool.py download on the ESP32 the Arduino sketches"
The esptool.py software takes care of uploading the sketches from Arduino IDE to the ESP32
You can install it with the terminal with the package manager pip .
pip install esptool
Before using it, you need to know the COM port of your ESP32 board: plug in your ESP32 and go to the Device Manager of Windows.
data:image/s3,"s3://crabby-images/4cdf0/4cdf047575faa256fe9ec1572fce1ad2fc22db27" alt="find the COM number in the device manager"
Look at the COM number of your ESP32 in the Ports (COM and LPT)
data:image/s3,"s3://crabby-images/5e884/5e88489b3b2206cb0bcaa87d33626182cadd4415" alt="find the COM number in the device manager"
Note
The following command must be run in the folder containing the MicroPython binary. If access to the serial COM port is denied, the command may have to be run in Administrator mode.
Then, we enter the command below in the terminal to flash the firmware with esptool and press Enter :
esptool --chip esp32 --port COM8 --baud 460800 write_flash -z 0x1000 esp32-20220618-v1.19.1.bin
data:image/s3,"s3://crabby-images/21f4b/21f4ba04db660c4cf1fdcf8e6899a0f6bff8480c" alt="open cmd terminal from windows files"
See also
There are extensions for MicroPython on VS Code and Pycharm. You can also use tools like RSHELL to upload Python scripts directly from a terminal.
Your first MicroPython script on ESP32
Now that all the tools are installed, we can write our first Python script (on Thonny IDE): The famous code makes the LED of your ESP32 board (present on the GPIO2 pin) blink.
import time
from machine import Pin
print("Hello World")
p2 = Pin(2,Pin.OUT)
while True:
p2.on()
time.sleep_ms(250)
p2.off()
time.sleep_ms(250)
To run the script on your ESP32 board, press the green “Run” button. I suggest you changing the flashing time of the LEDs to see how fast it is to load a new code !
data:image/s3,"s3://crabby-images/69444/694446531ff737f74d292eeabd5448a6bcc82f53" alt="Example of Python script on Thonny IDE for ESP32 board"