This Is How To Connect Your Pico W To The Internet And Control It From The Web

With Nothing But Python

Coding With Ryan
Geek Culture


I recently made a new video showing how to take your brand new Pico W, connect it securely to the internet, and control it from a web interface — all in Python with Anvil.

Check out the video or the text version of the video below.

Video Tutorial Showing How To Connect An Anvil App To A Pico W
Want to connect?Follow me for more software development content!

Text Version

The next evolution of the hugely popular Raspberry Pi Pico microcontroller is here. The Raspberry Pi Pico W adds on-board wifi making it perfect for creating IoT devices.

In 3 steps, I’m going to teach you how to create and deploy a simple web app, so you can learn how to control your Pico W remotely.

The app will be a simple online app with a single button that makes the LED on the Pico flash.

Step 1 — Creating an Anvil app to control our Pico

We’ll build the web app with Anvil, the platform for building web apps with nothing but Python.

For the first step, we’ll start by creating the Anvil app that will wirelessly control our Pico. We’ll go to and create a new blank app.

Creating a new blank app

Click the name of the app at the top of the editor and change it to “Pico App”.

Renaming the app

Next, let’s enable the Uplink. We’ll use the Uplink to connect to our Pico.

Click the add features button in the editor’s side bar and select the Uplink.

Next, we’ll click the ‘Enable server Uplink’ button.

Copy the Uplink key, we’ll be using this in a Python Script on our Pico later to establish the connection between our App and the Pico.

Enabling the Uplink and copying the Uplink key

Now the Uplink is enabled in our Anvil app let’s move on to step 2 and set up our Pico.

Step 2 — Setting up our Pico

To setup our Pico we need to install the Anvil firmware.

To start, we’ll hold down the BOOTSEL button on the Pico and plug it into our computer.

Release BOOTSEL once the Pico’s drive appears on your computer.

Connecting the Pico to our computer

Then, we’ll download Anvil’s Pico firmware file (pico-w-anvil-v<version-number>-complete.uf2) from the following link:

Once it’s downloaded, copy the file onto the Pico’s drive. Our Pico will reboot once the files are copied over.

Adding the `pico-w-anvil-v0.1.2-complete.uf2` firmware file to our pico

Open the Pico’s drive and edit the and the file.

In the file, edit the Wifi connection credentials to match your Wifi network.

Editing and adding our wifi credentials

Then, in the file, underneath the import statements, add the Uplink key we copied earlier.

Adding the Uplink kay to

The is where any functions you want to run on your Pico device are stored.

As a default, Anvil’s file for the Pico includes a pico_fn function. It’s a simple function that makes the light on the Pico flash and demonstrates that you can pass Python objects from your Anvil app to your Pico.

The @anvil.pico.callable decorator lets your Anvil app know that this function is available to call from the web. The pico_fn function is the one we’ll be calling from our web app.

The default `pico_fn` function in

Save both and

Reboot the Pico to save the updates by ejecting the disk and reconnecting the Pico.

Rebooting the Pico W

The Pico will flash a few times to indicate it is connected to the internet.

Let’s go back to the Anvil app we created earlier

Step 3— Creating a UI and publishing to the web

In the designer, we’ll drag and drop a button into our app’s form. We’ll change the text to ‘Flash the lights’ and style it by changing its role to primary-color.

Next, we’ll add a text box and set its type to number. This will let the users of our app input a number and pass the data to our Pico.

Adding a Button component and a TextBox component

Double click the button in the designer. This will add a function to our client-side code which will be called every time the button is clicked.

Adding a click event function to the button

Inside the function, let’s call the pico_fn function which is inside our pico’s file.

We’ll pass our Pico function the number the user of our web app enters.

Calling the `pico_fn` function in our click event function
The finished Button click event function

Now we’ve got the functionality sorted, we can deploy this app online by clicking the publish button in the top right of the editor. Let’s select the ‘Add public URL’ and change the URL to meaningful.

If we navigate to the URL we chose and press our apps button, the LEDs on the Pico will now flash.

That’s it! We now have our Pico microcontroller connected to the internet with a deployed web app that controls it. Check out the link below to see the finished Anvil app:


I’ve just shown you how to control your Pico W from the web with nothing but Python and Anvil.

Anvil is free to use — head on over to today to see more examples and the full documentation.

Want to connect?Follow me for more software development content!



Coding With Ryan
Geek Culture

I’m Ryan and I'm a software developer. I write about Python, Anvil and developer relations. Follow me to see high quality tutorials.