简体   繁体   中英

How to print the function name as a string in Python from inside that function

def applejuice(q):
   print THE FUNCTION NAME!

It should result in "applejuice" as a string.

This also works:

import sys

def applejuice(q):
    func_name = sys._getframe().f_code.co_name
    print func_name
def applejuice(**args):
    print "Running the function 'applejuice'"
    pass

or use:

myfunc.__name__

>>> print applejuice.__name__
'applejuice'

Also, see how-to-get-the-function-name-as-string-in-python

import traceback

def applejuice(q):
   stack = traceback.extract_stack()
   (filename, line, procname, text) = stack[-1]
   print procname

I assume this is used for debugging, so you might want to look into the other procedures offered by the traceback module . They'll let you print the entire call stack, exception traces, etc.

Another way

import inspect 
def applejuice(q):
    print inspect.getframeinfo(inspect.currentframe())[2]

You need to explain what your problem is. Because the answer to your question is:

print "applejuice"

This site gave me a decent explanation of how sys._getframe.f_code.co_name works that returns the function name.

http://code.activestate.com/recipes/66062-determining-current-function-name/

def foo():
    # a func can just make a call to itself and fetch the name
    funcName = foo.__name__
    # print it
    print 'Internal: {0}'.format(funcName)
    # return it
    return funcName

# you can fetch the name externally
fooName = foo.__name__
print 'The name of {0} as fetched: {0}'.format(fooName)

# print what name foo returned in this example
whatIsTheName = foo()
print 'The name foo returned is: {0}'.format(whatIsTheName)

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM