5
submitted 4 days ago* (last edited 4 days ago) by bravemonkey@lemmy.ca to c/learnpython@lemmy.ml

Hello,

I've come across an unexpected issue that may be hard to diagnose due to required hardware, but here goes.

I have a Raspberry Pi connected to an LCD display that I'm testing turning the screen on and off (not worrying about displaying text, I've previously written a program that uses a DHT22 sensor to display the temperature & humidity and external weather conditions using the Pirate Weather API).

While trying to write a simple program just to turn the display on or off, I run into an issue.

Here's the code:

import board
import datetime
# I2C driver from:
# https://gist.github.com/vay3t/8b0577acfdb27a78101ed16dd78ecba1
import I2C_LCD_driver
import argparse
parser = argparse.ArgumentParser()
parser.add_argument("state", help="'on' to turn on the screen, 'off' to turn off",type=str)
args = parser.parse_args()

mylcd = I2C_LCD_driver.lcd()

match args.state:
    case "on":
        power = 1
    case "off":
        power = 0
    case _:
        print("Please enter 'on' or 'off'")
        power = None

if power != None:
    print(power) # this is just to test
    mylcd.backlight(power)

What's happening that I don't understand is if power == None, the if statement will not trigger but the display will turn on.

The only way I've been able to keep the display off is if I add an else statement:

else:
    pass

This is using Python 3.10. My understanding is the else should not be needed at all. Any suggestions as to why the display might be turning on, or a better suggestion on how to handle the match statement?

--EDIT--

So it turns out initializing the display is turning it on at the same time. For a community that had no activity for ~2 years before this post, I'm pleasantly surprised with the amount of responses I've gotten - you all are awesome!

you are viewing a single comment's thread
view the rest of the comments
[-] MoonMelon@lemmy.ml 2 points 4 days ago* (last edited 4 days ago)

I think some of the other responses about there being a hidden "on" default are probably right, but if I was writing this code I would skip using "None" completely. Seems you want it either on or off, considering your "print" statement instructing the user? So either exit the program after bad input and do nothing:

    case _:
        print("Please enter 'on' or 'off'")
        return

or restrict this up front by not allowing invalid command line args in the first place:

parser.add_argument("state", help="'on' to turn on the screen, 'off' to turn off",type=str, choices=['on','off'])

Alternatively you could make on a flag, and when it is present you assume "on" and absent you assume "off":

parser.add_argument('--on', action='store_true')

Another options is to logically default to "0" and always set to either on or off yourself. There is no need to use None:

power = 0  # This always evaluates
if args.state == 'on':
    power = 1
mylcd.backlight(power)  # This always evaluates

This will have the side effect of turning the light off if the user enters anything besides "on", not just the word "off" but also "0", "ON", "coconut", etc. This may or may not be desirable, it's up to you.

Just as side note if you do use None it's idiomatic to use is when checking None for reasons discussed here.. This isn't your problem just thought I would mention it.

[-] bravemonkey@lemmy.ca 2 points 4 days ago

Reading this again too, I like the suggestion to default power to 0. A lot of this was testing to see how to do it at a dumbed-down level; the Python file I was testing in is a lot messier as is!

[-] bravemonkey@lemmy.ca 2 points 4 days ago

Found the problem, as mentioned in another reply. I really appreciate your response here though - I'm coming from a PowerShell scripting background with my day job, and learned about arguments in Python just this morning. I didn't know about 'choices', but that's super handy.

I had tried 'is not None' and didn't have any luck so then tried == with the same outcome.

this post was submitted on 15 Jan 2025
5 points (100.0% liked)

learnpython

234 readers
1 users here now

Rules

1: Be polite

2: Posts to this community must be requests for help learning python.

3: Replies in this community must be pertinent to the question OP asked.

4: No replies copy / pasted from ChatGPT or similar.

5: No advertising. No blogs/tutorials/videos/books/recruiting attempts.

This means no posts advertising blogs/videos/tutorials/etc, no recruiting/hiring/seeking others posts. We're here to help, not to be advertised to.

Please, no "hit and run" posts, if you make a post, engage with people that answer you. Please do not delete your post after you get an answer, others might have a similar question or want to continue the conversation.

founded 2 years ago
MODERATORS