118

Is it possible to call a function without first fully defining it? When attempting this I get the error: "function_name is not defined". I am coming from a C++ background so this issue stumps me.

Declaring the function before works:

def Kerma():
        return "energy / mass"    

print Kerma()

However, attempting to call the function without first defining it gives trouble:

print Kerma()

def Kerma():
    return "energy / mass"

In C++, you can declare a function after the call once you place its header before it.

Am I missing something here?

10
  • 9
    In Python there's no "declare". There's the definition (which must be complete) or there's nothing. Commented Sep 20, 2010 at 18:35
  • 2
    You say, "it gives trouble". Can you elaborate on that? Commented Sep 20, 2010 at 18:51
  • 2
    I know this is super old, but why has no one recommended putting the functions in a separate .py file and importing that? Is there some unintended consequences? Commented Apr 13, 2017 at 20:01
  • 1
    @Kyle Importing just pastes the imported code before the current code at compile time, so it's the same as defining the functions in the current code before calling them xD Commented May 1, 2019 at 18:41
  • 1
    A vast oversight in python, it should read the file before executing so all functions are available, suggest they fix it fer pete's sake in 4x Commented Feb 12, 2021 at 11:08

5 Answers 5

194

One way that is sort of idiomatic in Python is writing:

def main():
    print Kerma()

def Kerma():
    return "energy / mass"    

if __name__ == '__main__':
    main()

This allows you to write you code in the order you like as long as you keep calling the function main at the end.

Sign up to request clarification or add additional context in comments.

8 Comments

@Muhammad: while this is a viable approach, it surely isn't idiomatic in Python. Quite the opposite, you'll notice most main functions are usually placed at the end.
@Eli Bendersky: I'd submit that the if __name__ == '__main__': switch is the common idiomatic part.
@Eli: the idiomatic part is the if clause at the end: no code at the top level of the module, then at the end invoke a main function if the module is main.
@Eli: The idiomatic part is the if ... __main__':. I didn't say that the main should be placed above the rest of the code. I said the important part is calling _\_main__ at the end, and it doesn't matter where you place its definition then.
With the if name == 'main': switch it becomes irrelevant how you order your functions. That's the right thing(TM) to do.
|
21

When a Python module (.py file) is run, the top level statements in it are executed in the order they appear, from top to bottom (beginning to end). This means you can't reference something until you've defined it. For example the following will generate the error shown:

c = a + b  # -> NameError: name 'a' is not defined
a = 13
b = 17

Unlike with many other languages, def and class statements are executable in Python—not just declarative—so you can't reference either a or b until that happens and they're defined. This is why your first example has trouble—you're referencing the Kerma() function before its def statement has executed and body have been processed and the resulting function object bound to the function's name, so it's not defined at that point in the script.

Programs in languages like C++ are usually preprocessed before being run and during this compilation stage the entire program and any #include files it refers to are read and processed all at once. Unlike Python, this language features declarative statements which allow the name and calling sequence of functions (or static type of variables) to be declared (but not defined), before use so that when the compiler encounters their name it has enough information to check their usage, which primarily entails type checking and type conversions, none of which requires their actual contents or code bodies to have been defined yet.

1 Comment

It's not that a dynamic language can't do that. Perl is a dynamic language and you can call a function before you define it. That's because it has a compile phase and an execute phase (though oddly, but usefully, you can arrange to execute code during the compile phase). This works: doit(); sub doit { print("I'm doing it!\n"); }
15

This isn't possible in Python, but quite frankly you will soon find you don't need it at all. The Pythonic way to write code is to divide your program into modules that define classes and functions, and a single "main module" that imports all the others and runs.

For simple throw-away scripts get used to placing the "executable portion" at the end, or better yet, learn to use an interactive Python shell.

Comments

11

If you are willing to be like C++ and use everything inside a functions. you can call the first function from the bottom of the file, like this:

def main():
    print("I'm in main")
    #calling a although it is in the bottom
    a()

def b():
   print("I'm in b")

def a():
   print("I'm in a")
   b()

main()

That way python is first 'reading' the whole file and just then starting the execution

Comments

6

Python is a dynamic programming language and the interpreter always takes the state of the variables (functions,...) as they are at the moment of calling them. You could even redefine the functions in some if-blocks and call them each time differently. That's why you have to define them before calling them.

Comments

Start asking to get answers

Find the answer to your question by asking.

Ask question

Explore related questions

See similar questions with these tags.