this post was submitted on 28 May 2025
721 points (96.3% liked)

Programmer Humor

23585 readers
2905 users here now

Welcome to Programmer Humor!

This is a place where you can post jokes, memes, humor, etc. related to programming!

For sharing awful code theres also Programming Horror.

Rules

founded 2 years ago
MODERATORS
 

Also, do y'all call main() in the if block or do you just put the code you want to run in the if block?

you are viewing a single comment's thread
view the rest of the comments
[–] [email protected] 86 points 3 days ago (6 children)

What kind of psychopath would put the code in the if block.

[–] [email protected] 74 points 3 days ago* (last edited 3 days ago) (2 children)

Looks at all the Python scripts in my bin folder that I wrote.

[–] [email protected] 63 points 3 days ago* (last edited 3 days ago) (3 children)

Never heard of

def main():
    pass

if __name__ == '__main__':
    main()

?

[–] [email protected] 49 points 3 days ago (3 children)

I remember how weird this looked the first time I saw it and while I may now understand it, it still looks jank af

[–] [email protected] 8 points 3 days ago

Python: I'm so readable that I'm practically executable pseudo-code

Also Python: if __name__ == '__main__': . . .

[–] [email protected] 4 points 3 days ago (3 children)

I still wonder why.

unless it's for something that you want to work as an importable module and a standalone tool, then why do you need that?

[–] [email protected] 2 points 3 days ago

The main two reasons that I can think of to include this even when you have no intention of importing this as a library are:

  1. For unit testing you will need to import as a module.
  2. Sometimes I will run a python interactive interpreter and then import my script so that I can do some manual testing without needing to change my main function or if stmt.
[–] [email protected] 1 points 3 days ago* (last edited 3 days ago)

This is exactly why the conditional is used. It allows the script to function both as a standalone application and a library.

ETA: Probably would make sense to just treat it as default behavior in the interpreter and only require the conditional to overwrite in cases where main is not the main function and/or pre-processing is needed.

[–] [email protected] 1 points 3 days ago

Oh that is a good point actually. It's been a while since I have done any serious Python, so I'm not sure why you couldn't just use convention instead of this conditional.

For my part, if a Python script is meant to be executed, then I'll give it a shebang, drop the .py, and simply mark it as executable in the filesystem. 🤷‍♂️

[–] [email protected] 6 points 3 days ago (1 children)

Now think about this, you have logic that doesn't make sense when run directly, but you need it to be a library.

You have multiple name=main statements in some of your functions

[–] [email protected] 3 points 3 days ago (1 children)

I'm not sure I'm following the implication. Name=main is for scripts primary, is it not?

I've never thought to add more than one of these conditionals anyway...

[–] [email protected] 2 points 2 days ago

So you might have a script that does stuff as a library, and it should get environment variables and other info from the calling script. You use the same script for doing one off stuff on different computers.

So you make it do something slightly different or make it set it's path and look into the current folder when you run it directly. This change in logic could be in a few points in the script.

[–] [email protected] 23 points 3 days ago* (last edited 3 days ago)

Heard of it, was too lazy to do it that way.

To be fair I now do it that way, but not when I was learning Python.

[–] firelizzard 4 points 3 days ago (1 children)
[–] [email protected] 7 points 3 days ago (2 children)

Not having tons of code in one if statement, but in a function.

[–] [email protected] 11 points 3 days ago

And scope. Variables declared in the if can be read everywhere, variables declared in the function are limited to that function.

[–] firelizzard 2 points 2 days ago (1 children)

I thought you were saying to literally use def main(): pass, that’s why I was confused

[–] [email protected] 1 points 2 days ago

Oh, no, that's just the usual placeholder. Though, ... would also be valid iirc, and would fit better as a "TODO" placeholder

[–] [email protected] 11 points 3 days ago (1 children)

custom bin folders are a realm no God dares to tread

[–] [email protected] 2 points 3 days ago* (last edited 3 days ago)

I can and I do

*trollface*

[–] [email protected] 33 points 3 days ago* (last edited 3 days ago) (3 children)

I work in an academic / research environment. Depending who wrote it, even seeing a __name__ == "__main__" is a bit of a rare thing...

[–] [email protected] 23 points 3 days ago (1 children)

Academic code is absolutely horrific.

Fortunately, it is possible to translate it for practical applications.

[–] [email protected] 13 points 3 days ago

As someone in academia who writes code, I can confirm.

[–] [email protected] 16 points 3 days ago (1 children)

Do you also have nothing but love for those 50+ cell Jupyter notebooks that don't use a single function and have everything in the global scope?

[–] [email protected] 15 points 3 days ago (1 children)

the best thing is when not even the author knows the correct order of running the cells; because of course it isn't top-to-bottom.

[–] [email protected] 11 points 3 days ago

Yeah, and also zero dependency management, so you are free to figure out what combination of Python, Tensorflow and Keras will make it not throw random exceptions.

And don't forget the number one rule: you must use all the graphing libraries, all the time.

[–] brian 4 points 3 days ago

python isn't the only language to do "execute everything imported from a particular file and all top level statements get run". both node and c# (but with restrictions on where top level statements can be) can do that type of thing, I'm sure there's more.

python conventions are unique because they attempt to make their entrypoint also importable itself without side effects. almost no one needs to do that, and I imagine the convention leaked out from the few people that did since it doesn't hurt either.

for instance in node this is the equivalent, even though I've never seen someone try before:

if (path.resolve(url.fileURLToPath(import.meta.url)).includes(path.resolve(process.argv[1])))
{
  // main things
}
[–] [email protected] 14 points 3 days ago

Why would you waste a function call on something so completely redundant?

~For real though, arg parsing goes in the if, then gets dispatched to whatever function call is needed to run the proper script.~

[–] [email protected] 10 points 3 days ago

I definitely do for quick scripts, but I try to break this habit. The biggest advantage of def main() is that variables are local and not accessible to other functions defined in the same script, which can sometimes help catch bugs or typos.

[–] [email protected] 8 points 3 days ago* (last edited 3 days ago)

If the file is just a class I usually put example usage with some default arguments in that block by itself. There is no reason for a "main" function. It's a nice obvious block that doesn't run when someone imports the class but if they're looking at the class there is a really obvious place to see the class usage. No confusion about what "main()" is meant to do.

if __name__ == '__main__':
    # MyClass example Usage
    my_object = MyClass()
    my_object.my_method()
[–] [email protected] 2 points 3 days ago

you can, no one stopping you