Add an OLED Stats Display to Raspberry Pi OS Bullseye

Raspberry Pi OS Bullseye has recently been released and with it comes a number of improvements, but most of them are under the hood. There aren’t that many visual differences, the most noticeable is probably the new default desktop background which is now a sunset over a dam or lake.

Raspberry Pi OS Bullseye

With this operating system upgrade, we’ve also got the usual bugs and software incompatibilities. These have caused my previous OLED stats display tutorial, that I used for my Raspberry Pi Desktop Case, to no longer work correctly. If you follow the previous tutorial, you’ll be presented with a host of errors.

Errors Running I2C OLED Stats Display

So in this tutorial, I’ll take you through the installation and setup process to get the same 128×64 I2C OLED display running on Raspberry Pi OS Bullseye.

Here’s the video tutorial, read on for the written steps and commands.

What You Need For This Tutorial

Connecting Your OLED Stats Display To Your Raspberry Pi

To start out, we’re going to go through the same process to connect the OLED stats display to our Raspberry Pi. To do this, you’ll need a 4 wire female to female jumper cable. The colours don’t matter, they’re just there to help you keep track of which wire goes to which terminal.

4 Wire Connector Cable and I2C OLED Display

The OLED display’s terminals are labelled on the front, which seems to confuse a lot of people since the pins extend out the back of the display.

128x64 I2C OLED Display Pinout

This is especially difficult to spot once the display has been installed into the case and the front area of the display is no longer visible. So make sure that you jot them down before installing the display into a case or holder.

Pin Labels Hidden By Case

The pin arrangement is most commonly GND, VCC, SCL and SDA. Don’t just copy this arrangement, make sure you check your own display as there are versions of these displays with the VCC and GND pins switched around. If you connect power to them incorrectly they’ll most likely be damaged and will no longer work, even if you correct the wiring afterwards.

Different VCC and GND Pinout On Display

Plug your ribbon cable into these four pins and then take note of which colour you’ve got connected to which pin. If you’re installing the display into your case before connecting it to your Raspberry Pi then it’s a good idea to write down which colour is connected to which pin so that you don’t forget.

Plug in the Ribbon Cable

Next we can plug the other ends of the jumpers into the Raspberry Pi’s GPIO pins. The Pi’s GPIO pinout diagram can be found quite easily online and is available from the official website.

Raspberry Pi 4 Pinout
Source: RaspberryPi.org

Make sure that your Pi is off and the power is disconnected before plugging or unplugging jumpers from the GPIO pins. You don’t want to short a connection or plug a lead into the incorrect pin by mistake and not have a chance to check your connections before powering it up.

Raspberry Pi GPIO Pins

You’ve got a few options for the GND and VCC jumpers. I usually plug the GND jumper into Pin 9 (you can use any pin labelled GND). And I plug the VCC jumper into Pin 1, which is a 3.3V power pin. These displays can operate on 3.3V or 5V inputs, so any power pins on the Pi’s GPIO header will work.

VCC and GND Connections To Raspberry Pi

Next, we need to connect the communication jumpers SCL and SDA, which just get plugged into the corresponding GPIO pins. Plug SCL into Pin 5 and SDA into Pin 3. Don’t get confused between the GPIO numbers and the Pin numbers, ignore the GPIO numbers on the diagram and just go by the SDA and SCL labels and the corresponding pin numbers.

SDA and SCL Connections To Raspberry Pi

Check all of your connections again and you’re then ready to power your Pi up and get started with programming the display.

Completed I2C OLED Display Connections

Programming The OLED Stats Display

Now that we’ve got the display connected, we can look at programming our Raspberry Pi to display the performance stats. I’m going to be doing this on a fresh install of Raspberry Pi OS Bullseye by using the Raspberry Pi Imager utility to flash the operating system image to a new microSD card.

Put the SD card into your Pi’s SD card slot and plug in your power adaptor. Once you’ve booted up your Pi, you should be on the Raspberry Pi OS desktop. It’s possible to do this installation on a headless Pi as well using the same steps.

Raspberry Pi OS Bullseye

Update Your Pi and Install The CircuitPython Library

Open up a new terminal window and start by making sure that your Pi’s software is all up to date by running the following commands:

sudo apt-get update
sudo apt-get full-upgrade
sudo reboot
sudo apt-get install python3-pip
sudo pip3 install --upgrade setuptools
Updating The Raspberry Pi

Next, we’re going to install the Adafruit CircuitPython library using the following commands:

cd ~
sudo pip3 install --upgrade adafruit-python-shell
wget https://raw.githubusercontent.com/adafruit/Raspberry-Pi-Installer-Scripts/master/raspi-blinka.py
sudo python3 raspi-blinka.py

Hit yes to any prompts which may come up and yes (Y) to reboot at the end.

Installing The Adafruit Circuit Python Libraries

Check That Your Display Can Be Seen

This previous installation script should also have enabled I2C communication, which is needed to communicate with the display. You can check that it is enabled and your Pi is able to see the connected display by entering the following command:

sudo i2cdetect -y 1

You should then see a table, similar to the one shown below, which has a single set of characters in it (typically 3c for these displays). This code indicates the I2C address of your display.

Checking The I2C Display Address

If it hasn’t shown up then either I2C communication isn’t turned on, which can be done through the configuration utility, or your wiring is not correct. If you get a table full of characters (all addresses shown) then you’ve probably made a wiring mistake as this happens if SDA is shorted to ground. Go back and re-check your connections to your Pi and display and re-check that you’ve got I2C communication enabled after a reboot.

To enable I2C communication, use the configuration utility by entering:

sudo raspi-config

Don’t proceed with trying to get the script to work if you don’t get the correct response in this step. If your Raspberry Pi isn’t able to see the display that is connected to it then it won’t be able to communicate with it to get anything displayed.

Install The OLED Stats Display Script

Next, we need to install the CircuitPython libraries specific to the display. Start by entering the following commands:

sudo pip3 install adafruit-circuitpython-ssd1306
sudo apt-get install python3-pil

Now we just need to download the actual script. Rather than trying to edit it on the Pi, I’ve made it available on Github in its completed form, so you just need to run the following line to copy it to your Pi:

git clone https://github.com/mklements/OLED_Stats.git
Installing The Stats Display Script

Navigate to the new cloned directly by entering:

cd OLED_Stats

Then run the script by entering:

python3 stats.py
I2C OLED Stats Display Running

Automating The Script To Run On Start-up

Now we’ve got the display running, but it’ll stop as soon as we close the terminal window and we’d like it to run automatically on startup. We’re going to do this using crontab.

Open up crontab by entering the following command:

crontab –e

If this is the first time you’re opening crontab then you’ll be prompted to select an editor, select 1 and hit enter.

Add the following line to the end of the file to run the script:

@reboot python3 /home/pi/stats.py &

Don’t forget the “&” at the end to tell the Pi to continue starting up and to run the script in the background.

Adding The Script To Crontab For Automatic Startup

We’ll also need to copy the stats.py script and font into the home directory. You can also just reference the correct path in the previous step, but I find that this is less reliable.

Make sure that you copy both the stats.py script and the PixelOperator font into the /home/pi directory.

cd OLED_Stats
cp PixelOperator.ttf ~/PixelOperator.ttf
cp stats.py ~/stats.py
cp fontawesome-webfont.ttf ~/fontawesome-webfont.ttf
Copy The Script To The Home Directory

If you do leave them in the downloaded directory, you’ll need to amend the crontab command to read:

@reboot cd /home/pi/OLED_Stats && python3 stats.py &

Save the crontab file when you exit and then try rebooting your Pi to see if it is working correctly.

If you’ve followed the process correctly, you should now have a working OLED stats display that starts up automatically each time your Pi boots up. You can now go ahead and install it into your case if you haven’t done so already.

I2C Stats Display Running On Raspberry Pi OS Bullseye

Finish Off Your Pi Desktop Case Build

If you’re using an Ice Tower with your OLED stats display, plug the fan’s power cables into the 5V and GND GPIO pins next to the display’s connections as I’ve done.

Connecting The Ice Tower Fan To The GPIO Pins

Close up your case and your Raspberry Pi Desktop Case build is now complete.

Let me know how you find this tutorial in the comments section below. I’d love to hear your feedback and suggestions.

Stats Displays Running One Raspberry Pis
Michael Klements
Michael Klements
Hi, my name is Michael and I started this blog in 2016 to share my DIY journey with you. I love tinkering with electronics, making, fixing, and building - I'm always looking for new projects and exciting DIY ideas. If you do too, grab a cup of coffee and settle in, I'm happy to have you here.

110 COMMENTS

  1. I am having issues to run the script

    python3 /home/pi/OLED_Stats/stats.py
    Traceback (most recent call last):
    File “/home/pi/OLED_Stats/stats.py”, line 41, in
    font = ImageFont.truetype(‘PixelOperator.ttf’, 16)
    File “/usr/lib/python3/dist-packages/PIL/ImageFont.py”, line 852, in truetype
    return freetype(font)
    File “/usr/lib/python3/dist-packages/PIL/ImageFont.py”, line 849, in freetype
    return FreeTypeFont(font, size, index, encoding, layout_engine)
    File “/usr/lib/python3/dist-packages/PIL/ImageFont.py”, line 209, in __init__
    self.font = core.getfont(
    OSError: cannot open resource

    If i try to run the script as follows it works
    pi@raspberrypi:~ $ cd OLED_Stats/
    pi@raspberrypi:~/OLED_Stats $ python3 stats.py

    • It looks like it isn’t seeing the font in the same directory (or isn’t looking in that directory for the font). Either use the default font or just put the script and font into the default directory.

  2. Hi Michael !
    Great job but BLINKA just only works in Raspberry PI OS, how can I install it in other Distro (ubuntu mate) ?

    I tried with your other videos but I could not get it

    • You’ll need to use a library for your distro that allows you to run an OLED display. Each distribution has different package requirements, so you won’t find a single solution to all.

  3. Michael, Thank you so much for this. As a complete newbie to Pi i spent several days trying to figure out what i was doing wrong. This updated guide now works perfectly. Only slight issue i had being a newbie, was trying to work out how to save the crontab file. you may want to add “press control X to save”.
    Many thanks.

  4. Hi, i read the article Mini Raspberry Pi Server With Built In UPS, and the script you supplied with UPS stats, does not work with this method of installation. I tried to make one my self, but i’m not so good at programming. Please can you make another script, working with this new method?

  5. Help please!
    I’m trying this on a R-Pi 3B but the display is showing almost all pixels On and some Off.
    On the top of the display it shows some “Disk” stuff.
    I’m using a 128×64 display and Raspberry Pi OS.
    All the wiring is correct.
    I even tried another display to check if the previous was faulty.

  6. getting this message when i try to run the script:

    pi@raspberrypi:~/OLED_Stats $ sudo python3 stats.py
    Traceback (most recent call last):
    File “/home/pi/OLED_Stats/stats.py”, line 6, in
    import board
    ModuleNotFoundError: No module named ‘board’

  7. If you leave the contents in the original folder and want to run the script on boot, nano into stats.py then locate
    “font = ImageFont.truetype(‘PixelOperator.ttf’, 16)”
    and change it to
    “font = ImageFont.truetype(‘/home/pi/OLED_Stats/PixelOperator.ttf’, 16)”
    or the full path to the folder you have it in. Save and then try again. Should fix you up

    • Sorry I do not understand what you mean by this. Wording is too complicated, how do you locate the font or full paths and save them?

    • Thank you, much appreciated.
      I was currently working on this and my code was very similar to your code but I forgot to import a library and was searching forever for the error.

    • Hi Ed,

      can you re-link or email a copy of the stats.py? I am attempting to build the diy rpi 4 with bullseye and could really us it.

      thanks.

    • Hi Ed Street,
      I’m happy to hear you’ve managed to get the UPS version working as well. Are you happy with me putting the code you’ve linked to into a GitHub repository and linking to it on this page and the UPS page?

    • You would need to fetch that information from another application and you can then add a line to the display from within this script.

  8. I got it somewhat working. When I run the script it works, but Im having trouble with the final couple steps to make it work on boot and in the background. After I run the script, its just….. running. Im not sent back to # to enter any more commands. You dont mention anything about this, so I hit Ctrl+C and get back to #.

    I then enter the command crontab –e, but then I get:
    “–e: No such file or directory”

    Is this the correct command, because it doesnt seem to work?

    • If you’re running it in the Lite version (no desktop) then you need to add an & at the end of the command otherwise it’ll just keep “running” as you’ve said and you won’t be able to do anything else until it is stopped.
      The issue with crontab is most likely related to you working in the wrong directory. If you’ve navigated to the directory containing the script then you need to return to the home directory to modify the crontab file.

  9. Hello, I make this project, but I want to see same info like disk but for my external drive (/dev/sda1). Can you tell me script? Thank you!

  10. Hello Michael,
    I have no RPi and Python experience. With your description it was no problem to put the status display into operation.
    Thank you very much.

    same questions and comments
    1.) After a shutdown the content on the OLED remains. Is there any way to clear the content of the OLED without turning off the RPi?
    2.) What does board.D4 need to be defined for if the reset is not used at all. (To satisfy the adafriut lib?).
    3.) Is there a possibility to rotate the screen content? I didn’t find it in the lib of Adafruit.
    4.) Some time ago I had bought OLEDs SSD1306 (multicolor) from China. My first line is yellow and the next 3 lines are white. Is the font color configurable?
    5.) I want to use the RPi in continuous operation. The operating time for OLEDs is limited. What is your experience? I have an additional PIR – sensor planned. Even without Python experience I will try to include the code.

  11. Hi, if you run ‘df -h’ (without the quotes) in the terminal you’ll see in the final column (mounted on) the mount point of your external drive.
    You just need to alter this line in the script:
    “df -h | awk ‘$NF==\”/\”{printf \”Disk: %d/%dGB %s\”, $3,$2,$5}'”
    In my case I swapped out the / in “/\” to “/mnt/Media\” to display its usage, as that’s what I have mounted to /dev/sda1

    • Thanks a lot! It took me some trial and error to figure out what you meant. Basically after doing the df -h command I looked at the path that the dev/sda1 is mounted on. like for you it was just /mnt/Media and mine was like /srv/dev-disk-by-uuid-####A-#AA##-##AA… (where # means specific numbers and A means specific letters.)

  12. This script configures your
    Raspberry Pi and installs Blinka

    RASPBERRY_PI_ZERO detected.

    Updating System Packages
    Blinka Hit:1 http://raspbian.raspberrypi.org/raspbian bullseye InRelease
    Blinka Hit:2 http://archive.raspberrypi.org/debian bullseye InRelease
    Blinka Reading package lists…
    Upgrading packages…
    Blinka E: Broken packages

    Blinka Reading package lists…
    Blinka Building dependency tree…
    Blinka Reading state information…
    Blinka Calculating upgrade…
    Blinka Some packages could not be installed. This may mean that you have
    Blinka requested an impossible situation or if you are using the unstable
    Blinka distribution that some required packages have not yet been created
    Blinka or been moved out of Incoming.
    Blinka The following information may help to resolve the situation:
    Blinka
    Blinka The following packages have unmet dependencies:
    Blinka vlc-bin : Depends: libvlc-bin (= 3.0.16-1+rpi1+rpt1) but 3.0.16-1+rpi1+rpt2 is to be installed
    Blinka vlc-plugin-skins2 : Depends: vlc-plugin-qt (= 3.0.16-1+rpi1+rpt2) but 3.0.16-1+rpi1+rpt1 is to be installed
    Blinka Exiting due to error: Apt failed to install software!
    pi@raspberrypi:~ $

    ?????

  13. Hello Michael, I’m running Ubuntu server 64 bit on my Pi and I’m trying to get the OLED to work. Up until now no success. I can seed the the display is connected and I have the address, but then that’s it. the rest of instruction won’t work. I you could help that we be nice.

  14. It is working but on the line with cpu and temp it is displaying the cpu info twice and interfering with the temp so it just looks jumbled, it reads: cpu 1.21cpujumbled mess

  15. So I figures out there is an error on the code somewhere. I tool out the IP address and moved cpu line up in its location. Now I can see cpu temp. The CPU line reads : cpu 1.62 cpu 20%. The example you show here doesnt look that way. So the part that says cpu 20% was running into the cpu temp. So you know what in the code need to be changes to remove the cpu 20% part? I would like to have the IP address displayed

    • Hi Aaron,
      The code that I’ve got on github is the repository that I use to install this script on all of my Pi’s and I’ve never seen this issue come up. Could you share some details on what Pi you’re running it on and what operating system you’re running? Unless a recent OS update has caused a change to the data that this script pulls from, there shouldn’t be any difference.

        • Yeah, that’s likely why you’ve got a different layout. It’s probably reporting the stat back in a slightly different format to Raspberry Pi OS and that’s why its overwriting the same line on the display. You’ll need to see what exactly is being stored in each variable when putting together the display output and then work out how that fits best onto the display.

    • As far as I know, Umbrel runs on a version of Debian that they’ve modified to run their software on. You could probably get the display working on it, but you’d need to install a lot of libraries and dependencies that likely aren’t there by default. You’re probably better off getting a mini desktop display for the Pi and displaying the Umbrel dashboard on it.

  16. My OLED display is hard mounted to a NAS unit and it is currently displaying information upside-down. How or where can I make a change in the software to invert my display?

  17. don´t work :/

    pi@octopi:~ $ cd OLED_Stats
    pi@octopi:~/OLED_Stats $ python3 stats.py
    Traceback (most recent call last):
    File “stats.py”, line 11, in
    import adafruit_ssd1306
    File “/home/pi/.local/lib/python3.7/site-packages/adafruit_ssd1306.py”, line 17, in
    from adafruit_bus_device import i2c_device, spi_device
    File “/home/pi/.local/lib/python3.7/site-packages/adafruit_bus_device/i2c_device.py”, line 26, in
    class I2CDevice:
    File “/home/pi/.local/lib/python3.7/site-packages/adafruit_bus_device/i2c_device.py”, line 65, in I2CDevice
    self, buf: WriteableBuffer, *, start: int = 0, end: Optional[int] = None
    NameError: name ‘WriteableBuffer’ is not defined
    pi@octopi:~/OLED_Stats $ cd ..

    • This tutorial is written for Raspberry Pi OS Bullseye – it hasn’t been tested on other operating systems (like Octopi). These might be missing libraries or dependencies that this script relies on in order to run.

  18. Hey Michael,
    Thaks for this great writeup – it worked right away on my first Pi 4b, next one, everything installed fine, the screen teset shows blank and 3c in 1 field as expected. Running your script produces an error:

    Traceback (most recent call last):
    File “stats.py”, line 11, in
    import adafruit_ssd1306
    File “/home/pi/.local/lib/python3.7/site-packages/adafruit_ssd1306.py”, line 17, in
    from adafruit_bus_device import i2c_device, spi_device
    File “/home/pi/.local/lib/python3.7/site-packages/adafruit_bus_device/i2c_device.py”, line 26, in
    class I2CDevice:
    File “/home/pi/.local/lib/python3.7/site-packages/adafruit_bus_device/i2c_device.py”, line 65, in I2CDevice
    self, buf: WriteableBuffer, *, start: int = 0, end: Optional[int] = None
    NameError: name ‘WriteableBuffer’ is not defined

    Do you have any clues for me?

    • It seems like you might have some sort of communication issue. Id try reconnecting the display and re-run through the software setup to make sure all libraries are installed and enabled.

      • So i actually loosened my screws up a bit, ran the whole install again, and bob is your uncle 🙂 im running it on the latest Octopi, for reference – only crontab is acting up in this setup, i do have to have a terminal window open for each octopi i have to have the screens live updated – any ideas to a workaround would be much appreciated 🙂

  19. I have manged to get everything up and running but I notice the the CPU usage does not get above 9.99%.
    I have looked through your pictures in this page and yours does not seem to go very high either, mostly about 1-5%
    I have times when I am using 90% of CPU. Is there not enough digits in the coding to allow for higher amounts of CPU usage ?

  20. This is an awesome rundown!
    However, my display is constantly flashing. Is there a reason this is occuring and something i can fix?
    Thanks!

  21. Hi Michael! With RPiOS 64-bit officially released now, I am trying this on my own Pi4!

    However, I have hit a snag….the default Pi I2C bus on my Pi is set up for my power button to use, so I have a custom second I2C bus set up on my Pi that my screen is connected to (Bus 4)

    How do I go about changing your stats.py script to specify using a different I2C bus (in my case, Bus 4) other than the default bus (Bus 1)? 🙂

    Thanks so much for the awesome videos/articles and all the hard work!

    • Also stuck here! I have a PiJuice connected that won’t seem to allow me to have another device on the bus, despite different addresses! Have configured the i2c display on bus 2 but can’t seem to make any headway on readdressing for a different bus!

    • Hey Rally and Sven!

      In case you didn’t get it working, I found it after a day of searching:
      https://github.com/adafruit/Adafruit_Python_Extended_Bus

      use this library instead of board to set up the i2c connection on an alternate bus.

      Example:
      from adafruit_extended_bus import ExtendedI2C as I2C

      # Use for I2C.
      i2c = I2C(4) # creates an i2c connection on bus 4
      oled = adafruit_ssd1306.SSD1306_I2C(WIDTH, HEIGHT, i2c, addr=0x3C, reset=oled_reset)

      Hope you get yours working too!

  22. Great explanation, thank you!

    How can I prevent burn in the OLED screen?
    (screen off on certain time, at night for example)

    The CPU will be always 1.00%
    But when I do: top -n 1 -b | awk ‘/^%Cpu/{print $2}’ the percentage of the CPU is 15-20%
    How can I fix this?

    • If you’re worried about burn-in because you leave the Pi on for long periods of time then you could implement a timer in the code that only displays the text during the day (as you’ve suggested). These displays are also relatively cheap, $5-8, so you could just replace them every 6-12 months if this becomes an issue.

      I’m not really sure what you mean with regards to the CPU percentage?

  23. He seguido el tutorial y me funciona bien, no obstante después instalé una cámara raspi y, si bien la cámara funciona, la pantalla no funciona cuando apago y enciendo el raspberrypi.

  24. I have followed the tutorial and it works fine for me, however after installing a raspi camera and while the camera works, the screen does not work when I turn the raspberrypi off and on.
    (traducción del español con Google)

  25. Hey Michael,
    Have got the script working, awesome, thankyou!
    However, i’ve added a hat that will not allow a second device on the default i2c bus. I’ve used dtoverlay to move my display to bus 3, using different pins, and they are recognised in i2cdetect.
    I’m hoping you could tell me how to adjust your code to import the software bus to use bus 3!

    Cheers

  26. Hi Michael, great job and great design i love it! I tried it with a RP3 and everything works fine(Rp4 nowhere available) but on RP3 the network adaptor is on the other site then a RP4. Do you have also a design for the RP3 or something i can adapt to a RP3? Thank you

  27. So, this is fantastic! Up and running in 5 minutes.

    Question (and I’m surprised this wasn’t asked) how do we go about converting temp to Fahrenheit here?

    I know the formula is fahrenheit = celsius * 1.8 + 32

    But not sure where this would be placed in the actual code.

    cmd = “vcgencmd measure_temp |cut -f 2 -d ‘='”
    temp = subprocess.check_output(cmd, shell = True )

    My only python experience like this was reading sensors like so:

    reading = sensor_temp.read_u16() * conversion_factor
    temperature = 27 – (reading – 0.706)/0.001721
    temperature = temperature * 9 / 5 + 42 # Should be 9 / 5 + 32
    print(temperature)

    Any ideas?

    • Hi Rickles,
      This is something that a couple of people have looked at before, I can’t recall if it was on one of my other blog posts or in the comments of the Youtube video. What you’ve suggested is technically correct but you’d need to get the script to first convert the temperature into an actual number. At the moment the reported temperature value is just a text field, so you can’t apply the above conversion maths to it directly.

  28. For those that commented on CPU shoeing percentage when it’s really Load Average, yeah – it bugged the hell out of me too 🙂

    A quick fix in stats.py is to change line 63 to read like this::

    draw.text((0, 16), str(CPU,’utf-8′) + “LA”, font=font, fill=255)

    All I did was remove the “%” and replace it with “LA” for “Load Average”. Cheesy, but it turned off the OCD! 🙂

  29. Hi friend, congratulations for the post. really enjoyed.

    I have 4 lte 4g modems and I also have internet and local network in Ethernets Interfaces.

    how do i show the data bandwidth consumed by these devices?

    would you have any suggestions?

    I don’t know which commands I should use.

    Sorry for the translation, I only speak Portuguese and I use the translator to write.

    thanks.

    • Hi Seu João,
      You would need to find a python script, either from the manufacturer or some open-source repository, that gives you access to that data. You could then easily merge that with this script and adjust the displayed information to include all of the contents.

  30. Hi Michael,
    I just finished building your stats Raspberry Pi case with stats display and SSD, which I purchased off you via etsy recently. A great kit!
    One thing I realised after the build, was that the OLED display is set up for a standard OS install. I’ve set up this Pi as a Home Assistant host, which of course uses its own OS. So the display will remain dark for now. (can’t install the python features your instructions refer to)
    Any links or advice on an addin to set up the display in HA? Not the end of the world if it isn’t possible.

    Regards,
    Paul

  31. Hi Michael !
    Great job but

    pip3 install adafruit-circuitpython-ssd1306

    should be
    sudo pip3 install adafruit-circuitpython-ssd1306

    if not, jobs at crontab will not run

    regards
    Norbert

  32. I’m using the most current version of retropie, and I am able to get the stats display to show up but am unsuccessful at getting them to start up at boot. Is there anything else I could try ? or that I may be doing incorrectly .

    also after I enter python3 stats.py the Pi@retropi disappears all the text is white and commands wont work

    • instrad of
      pip3 install adafruit-circuitpython-ssd1306

      try this
      sudo pip3 install adafruit-circuitpython-ssd1306

      stats at boot works now for me

  33. Hi Michael! The case is amazing, thanks! (still would like to kick customs in the shin)

    I got the OLED display working (sort of). It doesn’t appear to be updating. The stats never change. No errors. Any idea?

  34. I ran through your instructions this evening and ran into one snag. It doesnt seem that the git function is installed on a fresh build. I am running the x64 lite version of Raspbian. This was resolved with a simple

    sudo apt-get install git

    Dont know if anyone else is having that issue.

    • Are you sure git isn’t just left out of the ‘lite’ build of Raspbian? I don’t recall having to install it with the normal full version? (I am running 64-bit Raspberry Pi OS with the Twister OS mod)

  35. Michael,
    I love this tutorial. I had no major issue getting it running. Like other users I couldn’t (at first work out the CPU information and was expecting this to be shown as a %.
    I played about with using other fonts and font sizes successfully with the intent of adding an additional line for Network (accumulative data use) which I would like to have shown for an ADSB monitoring project using a PiAware image. This would be mounted remotely at a “non technical” persons house whereby this information would be great to be shown on the display.

    I managed to cobble together the following.. but it seems it does not run under python I believe due to the additional awk statements and formatting.

    #Shell script (section)

    cmd = “ip -s -h link show eth0 | awk ‘/RX:/{getline; rx=$1} /TX:/{getline; tx=$1; printf “%s / %s\n”, rx, tx}'”
    Net = subprocess.check_output(cmd, shell = True )

    #Pi Stats Display (section)
    ….
    draw.text((0, 48), “RX/TX: ” + str(Net,’utf-8’), font=font, fill=255)

    Would anyone have any ideas as to whether it is possible to run such a command within python? And if so how would it be done?

  36. Michael,
    I love this tutorial. I had no major issue getting it running. Like other users I couldn’t (at first work out the CPU information and was expecting this to be shown as a %.
    I played about with using other fonts and font sizes successfully with the intent of adding an additional line for Network (accumulative data use) which I would like to have shown for an ADSB monitoring project using a PiAware image. This would be mounted remotely at a “non technical” persons house whereby this information would be great to be shown on the display.

    I managed to cobble together the following.. but it seems it does not run under python I believe due to the additional awk statements and formatting.

    #Shell script (section)

    cmd = “ip -s -h link show eth0 | awk ‘/RX:/{getline; rx=$1} /TX:/{getline; tx=$1; printf “%s / %s\n”, rx, tx}'”
    Net = subprocess.check_output(cmd, shell = True )

    #Pi Stats Display (section)
    ….
    draw.text((0, 48), “RX/TX: ” + str(Net,’utf-8’), font=font, fill=255)

    Would anyone have any ideas as to whether it is possible to run such a command within python? And if so how would it be done?

  37. Any body wanting to know the format of the awk comand that refers to the disc reporting … just a FYI

    my example is
    cmd = “df -h | awk ‘$NF==\”/srv/dev-disk-by-uuid-E096-7FA2\”{printf \”1> %s %s Used\”,$2,$5,$4,$5}'”

    the end statement $2,$5,$4,$5
    this refers to the columns of the df -u command
    $2 = Size of the drive
    $3 = Used
    $4 = Avail
    $5 = Use%
    the order you place them in is the order you will display the info
    usage is %s — the ‘s’ will read and display both the drive size number nd capacity in Gig , MB , or T
    if you use %d — this will just read and display the number value of the drive , this will allow you to set your own extension

    if you have built a NAS server with OMV with multiple drives, there is a way to setup your stats.py to display pages to show the rest of the drives and scroll through them every 5 or so seconds on repeat. If anybody is interested , pop a comment and ill upload a sample of my stats.py

  38. FYI the new RaspberryPi OS “Bookworm” breaks this tutorial as python packages like pip are now recommended to run in their own virtual environment.

  39. Thanks for the project. I purchased the 52Pi case put everything in the case, installed the software following your instructions and has everything working. Glued the screen into place and then I closed up the case with the supplied sides.

    Now when I run the script, I get the following:
    Traceback (most recent call last):
    File “/home/scott/stats.py”, line 73, in
    oled.show()
    File “/usr/local/lib/python3.9/dist-packages/adafruit_ssd1306.py”, line 219, in show
    self.write_framebuf()
    File “/usr/local/lib/python3.9/dist-packages/adafruit_ssd1306.py”, line 287, in write_framebuf
    self.i2c_device.write(self.buffer)
    File “/usr/local/lib/python3.9/dist-packages/adafruit_bus_device/i2c_device.py”, line 100, in write
    self.i2c.writeto(self.device_address, buf, start=start, end=end)
    File “/home/scott/.local/lib/python3.9/site-packages/busio.py”, line 206, in writeto
    return self._i2c.writeto(address, memoryview(buffer)[start:end], stop=True)
    File “/home/scott/.local/lib/python3.9/site-packages/adafruit_blinka/microcontroller/generic_linux/i2c.py”, line 60, in writeto
    self._i2c_bus.write_bytes(address, buffer[start:end])
    File “/usr/local/lib/python3.9/dist-packages/Adafruit_PureIO/smbus.py”, line 303, in write_bytes
    self._device.write(buf)
    TimeoutError: [Errno 110] Connection timed out

    Any suggestions?

  40. hello michael, good tutorials for beginners like me.i had install fresh new raspbian bullseye lite 64 and followed your tutorial and managed to get the lcd working.i only can managed to set to auto start after reboot.and i found some error on this line:-
    rpi4@pi4:~/OLED_Stats $ cp fontawesome-webfont.ttf ~/fontawesome-webfont.ttf
    cp: cannot stat ‘fontawesome-webfont.ttf’: No such file or directory
    any help on why the script does not start on boot?

  41. avg42slot review If you are a person who likes playing games and doing online pg slot or is looking for a new way to have fun with online slot games. Recommended to try playing AVG42slot.

  42. Hello Michael. I have a slightly longer display at .91 inches and is 128×38. If I change the parameters in stats.py should everything work and fit the screen dimensions? What do I need to do to make sure this works properly? Thanks in advance!

  43. ดูหนังออนไลน์ หนังใหม่ชนโรง ดูหนังhd หนังมาสเตอร์ พากย์ไทย ซับไทย ดูซีรี่ย์เกาหลี ซีรี่ย์ฝรั่ง Netflix ดูบอล ดูฟรีไม่เสียค่าใช้จ่าย ไม่ต้องสมัครสมาชิก ได้ที่ ดูหนัง.live

  44. I successfully installed and had this running since 2021, but due to Bookworm and virtual environments etc I am struggling to get my head around installing.
    Can anyone assist?

    Thank you

  45. Hi,

    Thank you for your tutorial. It helped me to wake up my mini oled screen. I´m doing a project (rasptank) where I use an mini oled screen connected to an Robot HAT 3.0. Everything works and displayed correctly after use command “python3 stats.py” but when I restart the raspberry, it does the autorun but won´t display correctly anymore, it is like refreshing or somehting, you can read some display text but not all. If i use the command “python3 stats.py” everything displays correctly again.
    Any tip?

    Greetings

LEAVE A REPLY

Please enter your comment!
Please enter your name here

Latest posts

N97 vs N100 vs Raspberry Pi 5: Which Is Right For You?

I recently did some testing to compare the performance and features of an N100 mini PC as a replacement for a Raspberry Pi 5....

Raspberry Pi 5 Case With An Integrated Water-Cooling Loop

A while back, I built a water-cooled Raspberry Pi 4 computer using a Pi CM4 module and the official IO board. This computer and...

Add an OLED Stats Display to Raspberry Pi OS Bookworm

Raspberry Pi OS Bookworm has been out for a little over a year now. It comes with a few visual changes like a Wayland...

Related posts