def applejuice(q):
print THE FUNCTION NAME!
It should result in "applejuice" as a string.
def applejuice(**args):
print "Running the function 'applejuice'"
pass
or use:
myfunc.__name__
>>> print applejuice.__name__
'applejuice'
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.
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)
def applejuice(): print "thefunctionname"; orangejuice = applejuice; del applejuice; orangejuice();