Raspberry Pi Pico W

Raspberry Pi Pico W

August 15, 2025

TL;DR We will get few IoT scripts working via PicoW + MQTT + HA

Intro

Two years ago I was tinkering with microcontrollers.

But still, I have not put together all my learnings in a proper way.

Actually… in any readable way.

So lets get the PicoW part sorted out.

We will see:

  1. How to connect the PicoW
  2. Using the IDE

Raspberry Pi Pico W

Ideas for Readme’s - https://github.com/STJRush/handycode/tree/master/Raspi%20Pico

The W version (brings wifi), see the official docs

PiW 101

You can get familiar via this post with the picoW: https://picockpit.com/raspberry-pi/everything-about-the-raspberry-pi-pico/

We are going to see few working examples:

  1. Playing with the Led
  2. Connect the PicoW to Wifi
  3. Reading the internal temp sensor
  4. Reading an external temp sensor - MLX90614
  5. MQTT and the PicoW

But basically, you will want to connect it to your laptop:

ls /dev/tty*

sudo apt-get update
sudo apt-get install screen

screen /dev/ttyACM0

Confirm that the device is plugged:

ls -l /dev/ttyACM0

Connect to the PicoW:

ls -l /dev/serial/by-id; ls -l /dev/ttyACM* 2>/dev/null

newgrp dialout
mpremote connect /dev/ttyACM0 repl

You can connect to your PiW console logs:

sudo apt install picocom
picocom -b 115200 /dev/ttyACM0
# picocom v3.1

# port is        : /dev/ttyACM0
# flowcontrol    : none
# baudrate is    : 115200
# parity is      : none
# databits are   : 8
# stopbits are   : 1
# escape is      : C-a
# local echo is  : no
# noinit is      : no
# noreset is     : no
# hangup is      : no
# nolock is      : no
# send_cmd is    : sz -vv
# receive_cmd is : rz -vv -E
# imap is        : 
# omap is        : 
# emap is        : crcrlf,delbs,
# logfile is     : none
# initstring     : none
# exit_after is  : not set
# exit is        : no

Then just:

picocom -b 115200 /dev/ttyACM0

If you press ctrl+c twice, you will access te python terminl inside the picow

MicroPython v1.20.0 on 2023-04-26; Raspberry Pi Pico W with RP2040
Type "help()" for more information.
>>>  #the program will stop executing in loop while u are here

IDE for PicoW

This repository: https://github.com/ajgquional/rpi-picow-micropython

Is great to get your started!

You can try with Thony or ArduinoIDE (I prefer the latter)

#sudo apt-get install -y thonny
flatpak install flathub cc.arduino.IDE2

When installing arduinoIDE:

installing arduino IDE Linux

You will see a message like: The “Arduino Mbed OS RP2040 Boards [v 4.4.1]” core has to be installed for the currently selected “Raspberry Pi Pico” board.

Do you want to install it now?

alt text

I said yes!

You will also have to:

alt text

alt text

Then the PicoW will be visible at arduinoIDE:

alt text

For Thonny installation:

alt text

On Windows it was quite simple and the portable Thonny worked

You will need to do sudo usermod -aG dialout $USER so that Thonny wont have permissions

Thonny Permission Error

You will have to restart ubuntu so that id -nG | grep dialout will provide output and Thonny’s error will be gone!

You could also check the serial access to the PicoW via:

screen /dev/ttyACM0 115200 #this will show the prints of your picoW scripts

Go to Thonny -> View -> Select Files: Then, go to the bottom right and select your PicoW

alt text

Now you will be able to see your old scripts if any inside your picoW:

alt text

Also, VSCode + extensions can work for your IoT projects:

flatpak install flathub com.visualstudio.code
#ext install ms-vscode.vscode-serial-monitor
code --install-extension ms-vscode.vscode-serial-monitor

VSCode Serial Monitor Extension

ℹ️
Thonny+W11 was the best combo for me

PicoW and MicroPython

The PicoW supports few languages.

But if you are confortable with Python, just stick to this one: MicroPython

alt text

Thanks to core-electronics

I was using Windows11 to make this one time setup:

  1. Hold the BOOTSEL button on the Pico W
  2. Connect the Pico W to your computer via the USB cable
  3. Release the BOOTSEL button -> you will see a new device in the PC.
  4. Download this and move it to the Pico folder: https://github.com/micropython/micropython/releases
import mip
mip.install(PACKAGE_NAME, index="https://USERNAME.github.io/micropython-lib/mip/BRANCH_NAME")

Unplug usb and plug

To install libraries, i have observed that recently upip has been depricated in favour of mip

You can see whats the micropython code running inside your picoW by:

#stop anything reading
#screen -ls
kill -9 9096
mpremote connect /dev/ttyACM0 fs ls

Using the Built in Led

The led is the pin 25 as per the PicoW schema.

  1. Run -> Configure Interpreter -> Interpreter -> MicroPython (Raspberry Pi Pico)

  2. View -> files

The Pico will look for a main.py to execute in loop

  1. View -> plotter

Press CTRL+D for soft reboot and load the new program!

Reading internal temp sensor

Required library: https://pypi.org/project/machine/

Connecting the Pico to Wifi

Thanks to the video:

Name the file different than main.py to avoid the automatic execution.

You can connect your picoW to Wifi and blik the led while attempting to do so with this script.

Even reading html webcontent, with this other script.

You will get something like:

#Starting Wi-Fi connection process...
#Already connected. Network config: ('192.168.1.15', '255.255.255.0', '192.168.1.1', '192.168.1.1')

Pico W with MLX90614

Connect the sensor properly as per:

GND is pin38 3v3 out is pin 36

11 (GP8) is I2C0 SDA 12 (GP9) is I2C0 SCL

https://www.youtube.com/watch?v=FsdSkhdfOqY&t=24s

And they are giving their own library: https://github.com/embeddedclub/micropython

We need to install: https://github.com/mcauser/micropython-mlx90614

It is not available in mip, the new package manager

So cloned the repo and copied into /lib/mlx/mlx90614.py

I did not compiled the .py file of the repo into .mpy

In this way, we can import with

from mlx.mlx90614 import MLX90614 #(we import the class)

PicoW and MQTT

The Message Queue Telemetry Transport!

I was writing on the Pi Blog a post about MQTT.

But its the time to play with MQTT and the PicoW.

Connect to the UI via: http://192.168.1.11:18083

The MQTT Architecture operates on a client-server model, and the core of MQTT communication revolves around two main components:

  • MQTT Broker (Server): This is the central hub of the system. It’s a server that receives all messages from clients, filters them by topic, and then distributes them to other clients who have subscribed to those specific topics.

A Pi 4 or an ASRock DeskMini X300 acting as a homelab, running an MQTT server like EMQX, fills this role.

  • MQTT Client: These are the devices that connect to the broker to either publish messages (send data) or subscribe to topics (receive data). Your Raspberry Pi Pico W, configured to read sensor data and send it to the broker, is the perfect example of an MQTT client.

It will publish its sensor readings to a specific topic on the server. Other devices, which are also clients, can then subscribe to that same topic to receive the data.

This separation of roles is what makes MQTT so efficient and scalable for IoT applications.

The clients don’t need to know anything about each other; they only need to know how to connect to the central broker.

The RPI and mqttx/mosquitto 🌍

If you want to bring the bigger Pi4 to the MQTT game:

https://mqttx.app/ https://github.com/emqx/MQTTX

sudo apt install -y mosquitto
sudo apt install -y mosquitto-clients

#sudo apt install python3-pip
sudo pip3 install paho-mqtt

sudo systemctl status mosquitto.service

In the absence of a direct configuration entry for the port, the port used by Mosquitto could be the default port (1883 for MQTT or 8883 for MQTT over TLS/SSL).

You can check which one is in used with:

netstat -tuln

https://www.youtube.com/watch?v=GQOqvvei5Do #also hivemq

Without hivemq, just using this GREAT VIDEO: explaining the umqtt.simple library!

To be used mqttx and emqx

PicoW to EMQX Server

Having your EMQX ready and accessing its UI at 192.168.1.11:18083

alt text

Login via admin/public and you will be prompted to change the pass

Create a topic via EMQX so that the PicoW will push data 🌍

Yes, you can temporarily allow anonymous clients to publish to a topic. However, this is not recommended for a production environment as it creates a significant security vulnerability. Anyone who can reach your server can then publish data to that topic.

This is primarily useful for initial testing and quick development to confirm that your Pico W’s code and network configuration are correct.

Here’s how to do it in EMQX:

  1. Enable Anonymous Authentication By default, EMQX allows anonymous access. However, if you’ve previously configured a password-based authentication, you may have disabled it. You can check this in the EMQX dashboard.

  2. Navigate to Access Control -> Authentication.

  3. If you see an “anonymous” entry, ensure it is enabled.

  4. If it’s not present or disabled, you may need to add or enable it, but in most default setups, it’s already there.

  5. Configure Anonymous Authorization This is the most critical step. You need to create an Access Control List (ACL) rule that explicitly allows unauthenticated (anonymous) users to publish to your desired topic.

  6. Navigate to Access Control -> Authorization.

  7. Add a new rule.

  8. Set the Type to All Users.

  9. Enter the Topic Filter (e.g., house/living_room/sensor_data).

  10. Set the Action to Publish.

  11. Set the Permission to Allow.

  12. Save the rule.

This rule will apply to any client that connects without a username and password. Now, your Pico W can connect to the broker using its IP address and port without needing to provide any credentials.

Again, please remember to set up proper authentication and authorization with specific users and passwords before you deploy your project for real-world use.

You don’t need to manually create a topic in EMQX.

Topics are created automatically the first time a client publishes a message to them. You just need to specify the topic name in your Pico W’s code.

How it Works

The MQTT broker operates on a publish-subscribe model. When a client (your Pico W) sends a message, it includes a topic in the message header.

The broker, upon receiving the message, checks if that topic already exists.

If it doesn’t, the broker creates it and then routes the message to any clients that are subscribed to that topic.

What You Need to Do

  1. Define the Topic Name: In your Pico W’s code, simply decide on a logical and hierarchical topic name. Good examples are:
    • sensor/livingroom/temperature
    • device/picow_01/status
    • home/kitchen/light
  2. Publish to the Topic: When your Pico W’s code publishes its first message, it will automatically create that topic on the EMQX broker.
  3. Subscribe to the Topic: Any other client (e.g., another Pico W, a dashboard on your computer, or a smartphone app) that wants to receive that data will need to subscribe to the exact same topic name.

This dynamic topic creation is a key feature of MQTT that makes it flexible and easy to use.

Lets make sure that EMQX is ready.

Testing EMQX from W11 with random messages

This did not work:

#snap install mosquitto
choco install mosquitto

So I went and download it as in old school fashion: https://mosquitto.org/download/

And configure the new path variable:

For setting a Windows System Environment Variable, the variable name and value are distinct.

  • The variable name you need to edit is Path. This is a system variable that tells Windows where to look for executable files.
  • The variable value you need to add is the path to the Mosquitto installation folder: C:\Program Files\mosquitto.

When you add this value to the existing Path variable, you’re not changing its name. You are simply appending the Mosquitto directory to the list of folders Windows checks for commands.

So that this works:

mosquitto -h #I got mosquitto version 2.0.22

And just send a message: from W11 to EMQX at the x300

mosquitto_pub -h 192.168.1.11 -p 1883 -t test/data -m "Hello, World!"

EMQX UI - Watch random topic message

So now that we got that, EMQX works and receives messages from clients, lets continue.

Getting the PicoW ready for MQTT 🌍

Adding the Language of IoT (MQTT) πŸ—£οΈ

Being online is one thing, but how does your Pico W “talk” to your other devices? It needs a common language, and for IoT, that language is MQTT.

  • What is MQTT? πŸ—£οΈ MQTT stands for Message Queuing Telemetry Transport. It’s a super lightweight and efficient protocol specifically designed for devices with limited power and bandwidth. Unlike a standard web request where one device talks directly to another, MQTT uses a “central hub” model.

    • The Broker (Server): This is the central hub. In your case, this is the EMQX server running on your Ubuntu machine. It’s the post office of your IoT system.
    • Clients (Publishers & Subscribers): These are the devices that want to send or receive data. Your Pico W is a client.

    A client publishes a message to a topic (like putting a letter in a specific mailbox), and any other client that has subscribed to that same topic receives the message. The clients never talk to each other directly; they only communicate with the broker.

  • Installing the Library πŸ“š Your Pico W needs a special library to understand and speak MQTT. Your notes point out two ways to install them: upip and the newer mip.

    #install libraries for mqtt
    ##with mip
    mip.install("umqtt.robust")
    mip.install("umqtt.simple")

    The mip.install() commands download the necessary library files directly onto your Pico W’s flash memory. You’re installing two variants:

    • umqtt.simple: A very basic MQTT client.
    • umqtt.robust: A more powerful version that includes features like automatic re-connection if the Pico W loses its Wi-Fi signal. This is highly recommended for any real-world project.

Once these steps are completed, you’ve laid the groundwork.

Your Pico W is connected to the internet, and it has the tools to start sending and receiving data using the MQTT protocol. You are now ready to build the next part of your project: writing the code that actually publishes your sensor data!

#connect to wifi
import network   # handles connecting to WiFi
import urequests # handles making and servicing network requests

# Connect to network
wlan = network.WLAN(network.STA_IF)
wlan.active(True)

# Fill in your network name (ssid) and password here:
ssid = 'HUAWEI P30'
password = 'mokradupa68'
wlan.connect(ssid, password)

#install libraries for mqtt

##with upip
#upip.install("micropython-umqtt-robust")
#upip.install("micropython-umqtt-simple")

##with mip
#https://github.com/micropython/micropython-lib 
#https://github.com/micropython/micropython-lib/tree/master/micropython/umqtt.robust
mip.install("umqtt.robust")

#https://github.com/micropython/micropython-lib/tree/master/micropython/umqtt.simple
mip.install("umqtt.simple")

then the code https://github.com/donskytech/micropython-raspberry-pi-pico/tree/main/umqtt.simple

Upip vs MPIP Package Managers

Both upip and mip are package managers for MicroPython.

The key difference is that mip is the new, recommended tool, while upip is the older, deprecated one. mip offers several advantages that make it a better choice for installing libraries on your Pico W.

The Old Way: upip

upip (MicroPython’s Package Installer) was the original tool for downloading and installing libraries from the web.

It worked by fetching the library files from a remote URL, such as micropython-lib, and placing them on your device.

Key Characteristics:

  • Simpler Protocol: upip used a basic HTTP request to download packages.
  • Deprecation: It’s no longer actively maintained. If you try to use it with newer MicroPython firmware versions, you may encounter errors or discover that it can’t find the necessary packages.
  • No __init__.py files: The packages weren’t properly structured, which could cause issues with module imports.

The New Way: mip ✨

mip (MicroPython Installation Program) is the modern package manager. It was introduced to address the limitations of upip and provide a more robust and reliable way to manage libraries.

Key Characteristics:

  • Improved Architecture: mip uses a better-designed protocol that ensures more stable installations.
  • Package Source: It primarily fetches libraries from the MicroPython community library on GitHub, which hosts many pre-compiled, optimized packages.
  • Dependency Handling: mip can automatically handle dependencies, meaning if a library requires another library to function, mip will install that too. upip could not do this.
  • Standardized Installation: It ensures that packages are installed correctly, with all necessary files (__init__.py, etc.) properly placed for seamless imports.

In summary, mip is the modern, more reliable, and feature-rich way to install libraries on your Pico W, and upip is a legacy tool that you should avoid.

Then, we just need this kind of main.py script to push just random data (from 1 to 20).

And this main.py to push the internal temp sensor to the MQTT server (EMQX):

This creates and pushes the pico/temperature MQTT topic, which we can suscribe via EMQX:

alt text

Your Data is now ready at your MQTT server or you to play with it!


Conclusions

I took longer than expected to write this post.

And almost forgot all the things I learnt about the PicoW, just bc I did not document it while learning.

Things of 2023.

To visualize the MQTT Data:

Many business intelligence (BI) tools can connect to MQTT, but usually not directly.

The most common and robust approach is to use an intermediary service to get the MQTT data into a database, which the BI tool can then query.

This is the exact setup we discussed with Grafana:

  • MQTT Broker (EMQX): Collects the data from your Pico W.
  • MQTT-to-Database Bridge: Listens to a topic and pushes the data into a database.
  • Database (e.g., InfluxDB): Stores the time-series data.
  • BI Tool (e.g., Grafana): Queries the database to create visualizations.

Th> is model is standard because BI tools are designed for analyzing historical data from databases, not for processing real-time message streams.

  1. Try HomeAssistant via HA container

  2. Try ThingsBoard

ThingsBoard is an Open-source IoT Platform - Device management, data collection, processing and visualization.

  1. DYI with Flask!
Flask x MQTT 101

For a simple app to just monitor the internal temperature, the Flask application would be relatively simple.

You’d primarily need to set up the communication channels and a basic web page to display the data.

The Backend (Flask)

The Flask side of the application would be the “server” that receives the MQTT messages. You would:

  1. Initialize the Flask app and an MQTT client.
  2. Define an MQTT callback function that gets triggered whenever a new temperature message arrives from your Pico W.
  3. Inside this callback, you would store the most recent temperature value and then broadcast it to any connected web clients using a library like Flask-SocketIO.

This backend script would be continuously running, listening for both MQTT data and requests from web browsers.

The Frontend (HTML/JavaScript)

The frontend is the simple web page that displays the data. You would create a single HTML file with:

  1. A heading (e.g., “Pico W Temperature Monitor”).
  2. A space (like a <div>) to display the temperature value.
  3. A JavaScript script that connects to your Flask server via SocketIO.
  4. Once connected, the script would listen for the temperature data broadcast from the server and update the content of the <div> with the new temperature value.

This setup is efficient because it avoids traditional page reloads. Instead, the server pushes new data to the browser as soon as it’s available, creating a real-time, dynamic display.

HA is Great

Dont trust me, see what people do:

alt text

alt text

Setup Home assistant with:

sudo docker compose up -d

Connect to HA via http://192.168.1.11:8123

HA x MQTT

How about connecting HA via MQTT to the PicoW so that we can receive the data into a cool dashboard?

HA Create user and pwd

You will see this dashboard by default: later we will create one

alt text

Setup the MQTT Integration and configure your dashboard

For recent Home Assistant versions, you configure the MQTT broker through the UI, not in the configuration.yaml file. The broker, port, username, and password options were deprecated for manual YAML configuration.

Here’s the correct two-step process to get everything running:

  1. Configure the MQTT Broker in the UI:
    • Go to Settings > Devices & Services.
    • Click the "+ Add Integration" button.
    • Search for and select “MQTT”.
    • A pop-up will guide you to enter the broker’s IP address (192.168.1.11), port (1883), and any credentials you have set.

Adding mqtt integration in HA

  1. Add the Sensor Configuration to YAML:
    • After the broker is configured, you’ll add the sensor block to your configuration.yaml file. The part you provided is exactly what’s needed.
    • This tells Home Assistant to create a new entity (sensor.pico_w_temperature) that will listen for incoming data from the broker on the specified topic.

After you’ve done both of these steps and restarted Home Assistant, it will automatically connect to your EMQX broker and start listening for the temperature data.

1. Configure the MQTT Broker in the UI

First, you connect Home Assistant to your EMQX broker. This is done entirely through the UI and you should never add the mqtt: broker: details to your YAML file.

2. Add the Sensor Configuration in YAML

This is where you define the entities that listen for data. The error message you received happens when you try to use the old YAML format for the sensor. The correct, modern method is to define the sensor directly under the mqtt: key, like so: 3. Restart Home Assistant

After you save the configuration.yaml file with the correct code, you must restart Home Assistant to apply the changes.

The history integration relies on the recorder integration to actually save the data.

To fix this, you should explicitly enable the recorder in your configuration.yaml file.

How It Works HA to add the MQTT historical temperatura data plot:

  1. Card Selection: You’ve correctly chosen the History Graph card. This card is perfect for visualizing time-series data like temperature readings.
  2. Configuration: The card’s configuration panel allows you to customize the graph.
    • Title: You’ve given it a title, “Internal T,” which makes it easy to identify on your dashboard.
    • Hours to show: You’ve set the time range to 6 hours, which is good for viewing recent data trends.
    • Entities: This is the most crucial part. You’ve correctly selected Pico W Temperature from the list of available entities. This tells the card to get its data from the sensor you created using the MQTT integration.

Once you click Save, the card will be added to your dashboard and will start plotting the temperature data as it arrives from your Pico W. The “History integration disabled” message you see in the screenshot is a common temporary state; the graph will populate with data as soon as the integration begins collecting it.

Once ready, the data will start flowing:

alt text

HA has a buildint SQLite to store and plot MQTT Data!
cd ~/Docker/HomeAssistant
sqlite3 home-assistant_v2.db
#.tables

Create a new HA dashboard with the sensor info:

alt text

alt text

alt text

ℹ️
As we are reading the PicoW Internal sensor, for me it was showing ~+8C than a regular temp sensor

Home Assistant dashboard with temperature from MQTT


FAQ

Interesting Resources

  1. Pico to Pico Wifi communication

https://www.youtube.com/watch?v=ACAmVg6MakI

  1. Pico W web server:

See https://www.youtube.com/watch?v=ufK_knxWn08 and also https://www.youtube.com/watch?v=AK8UYh7pMGM

Pico w web server via C, instead of Micropython - https://www.youtube.com/watch?v=C_O0MXGBHsw

  1. MQTT to NodeRed: NodeRed will subscribe to the MQTT topic.

Supported Languages

Yes, the Raspberry Pi Pico W supports all of the languages and the OS you listed.


Languages

  • C/C++: This is the primary language supported by the Raspberry Pi Pico, with an official SDK (Software Development Kit) provided by the Raspberry Pi Foundation. It offers the fastest performance and the most direct control over the hardware.

  • MicroPython: A lean and efficient implementation of the Python 3 programming language optimized for microcontrollers. It’s an excellent choice for beginners and for rapid prototyping because of its simpler syntax and a large number of available libraries.

  • TinyGo: This is an implementation of the Go programming language that is designed for microcontrollers. The Raspberry Pi Pico W is officially supported by the TinyGo project, making it a viable option for those who prefer the Go ecosystem.

  • CircuitPython: A fork of MicroPython created by Adafruit, it is also well-supported on the Raspberry Pi Pico W. It focuses on ease of use for beginners and has a large collection of hardware-specific libraries.

  • FreeRTOS: While not a full-fledged operating system in the traditional sense, FreeRTOS is a Real-Time Operating System (RTOS) kernel. It is supported on the Raspberry Pi Pico W, allowing you to run multiple tasks concurrently and manage resources in a time-sensitive manner, which is crucial for complex embedded applications.

Even with RUST?

If you liked the MQTT section, you could also play with HiveMQ

Checking micropython files inside PicoW via RShell

python3 -m pip install --user rshell
ls -l /dev/serial/by-id/
#fuser -v /dev/ttyACM0 || true
#kill 48470 || kill -9 48470
#fuser -v /dev/ttyACM0 || true
#rshell -p /dev/serial/by-id/usb-MicroPython_Board_in_FS_mode_e66141040370772c-if00 -b 115200
rshell -p /dev/serial/by-id/usb-MicroPython_Board_in_FS_mode_e66141040370772c-if00 --buffer-size 512 -b 115200

How can you see what code is currently inside the microcontroller (Pico W)?

If you used ArduinoIDE…

You cannot directly view or retrieve the code that’s already been uploaded to a microcontroller like the Pico W from the ArduIDE.

Once code is uploaded, it’s compiled into machine code and stored in flash memory β€” not easily readable or reversible.


Why?

When you upload a sketch to the Pico W through Arduino IDE:

  • The human-readable code (.ino) is compiled into a binary format (.uf2, .bin, or similar).
  • This binary is uploaded to the Pico W.
  • The microcontroller runs that compiled code, but it does not retain the original .ino sketch or any comments.

So, unless you have the original source code saved locally, there’s no official or easy way to recover it from the Pico.

βœ… If you just want to know whether there is a sketch on it:

You can check that the board is running something:

  • Open the Serial Monitor in Arduino IDE (Ctrl+Shift+M or use the magnifying glass icon).
  • Set the correct baud rate (commonly 9600 or 115200).
  • Press the reset button on the Pico W and see if anything is printed.

This only helps if the uploaded sketch sends serial output (like using Serial.println()).

πŸ”„ If you want to start fresh:

You can always re-upload your own code. The old code will be overwritten.

Bonus: Using File System (for MicroPython users)

If you were using MicroPython instead of Arduino IDE, and your Pico W was running MicroPython firmware, you could:

  • Access the file system using Thonny or rshell.
  • Download the main.py or other files from the device.

But since you’re using Arduino IDE, that’s not applicable here.

In Summary:

GoalCan You Do It?
View the original Arduino sketch code inside Pico W❌ Not possible
Check if the Pico W is running codeβœ… Via Serial Monitor
Retrieve readable code❌ Unless you have the original
Overwrite with new codeβœ… Always possible

If you used a MicroPython script, not Arduino….

What if the Pico W was running MicroPython

This boot.py script would have been uploaded to the internal file system of the board.

Let’s break this down and help you check whether this code is still there and how to retrieve or edit it.


βœ… Step-by-Step: Check if Your Script is Still on the Pico W

  1. Install & Open Thonny

Thonny is the recommended editor for MicroPython on the Pico W.

  • Download: https://thonny.org/

  • Open Thonny and:

    • Go to Tools > Options > Interpreter

    • Select:

      • MicroPython (Raspberry Pi Pico)
      • The correct port (it often auto-detects)

⚠️ If Thonny says it can’t find the Pico, try holding the BOOTSEL button while plugging in the board, then reflash the MicroPython firmware.


πŸ’Ύ 2. Browse the File System

Once connected:

  • On the left side of Thonny, you should see:

    • Files on this computer
    • Files on Raspberry Pi Pico

If your script (boot.py) is still there, you’ll see it listed. Double-click to open and view it.

  1. What If You Flashed Arduino Code?

If you uploaded an Arduino sketch to the Pico W, the MicroPython firmware would have been overwritten. That means:

  • The script is gone.
  • The Pico no longer runs MicroPython, so Thonny won’t detect it as a MicroPython device.

To get back to MicroPython:

  • Re-flash the MicroPython firmware: This is MicroPython dragnDrop install!

    1. Unplug the Pico W.
    2. Hold the BOOTSEL button and plug it in.
    3. It appears as a USB drive.
    4. Download the .uf2 MicroPython firmware from here.
    5. Drag and drop the .uf2 file onto the Pico’s USB drive.
    6. It will reboot into MicroPython.

Now, you can reconnect using Thonny and upload scripts like boot.py again.

πŸ” Bonus Tip: Hide Credentials in Production

Your current script hardcodes the Wi-Fi credentials β€” that’s fine for testing, but for more security:

  • Store them in a separate secrets.py file.
  • Or use environment variables if working with more complex setups.

For me, the easiest was with Thonny + Windows11.