Fetching Web Resources with urllib in MicroPython

Feb 6, 2024 ยท 2 min read

The urllib module in MicroPython provides a simple interface for fetching resources from the web. Whether you want to grab some JSON data to parse or download an image, urllib handles the HTTP requests and responses for you.

Making Requests

To make a request, first import urllib:

import urllib

Then open a request to a URL. This returns a urequest object:

response = urllib.request('https://example.com')

You can pass headers in a dictionary and data to send in the request body:

headers = {'User-Agent': 'MicroPython'}
data = {'key': 'value'}
response = urllib.request('https://example.com', headers=headers, data=data)

Handling Responses

The response object has several useful properties:

print(response.status) # status code
print(response.headers) # response headers
print(response.read()) # response body

You can iterate through the response line by line:

for line in response:

Or read a specified number of bytes:

data = response.read(100) # read 100 bytes

Always close the response when finished:


Practical Examples

Fetch and parse some JSON:

import urllib.json

response = urllib.request('https://api.example.com')
data = urllib.json.loads(response.read())


Download an image to a file:

with open('image.jpg', 'wb') as f:

So in just a few lines, you can make web requests and handle responses using MicroPython's handy urllib module.

Browse by tags:

Browse by language:

Tired of getting blocked while scraping the web?

ProxiesAPI handles headless browsers and rotates proxies for you.
Get access to 1,000 free API credits, no credit card required!