Ответы:
Благодаря mcandre, ответ таков:
#python3
from inspect import currentframe, getframeinfo
frameinfo = getframeinfo(currentframe())
print(frameinfo.filename, frameinfo.lineno)
import inspect inspect.getframeinfo(inspect.currentframe()).lineno
currentframe()
вызывается, что означает, что вы не можете упростить это более чем getframeinfo(currentframe()).lineno
(если вас интересует только номер строки, а не имя файла). См. Docs.python.org/2/library/inspect.html#inspect.currentframe
Используете ли вы, currentframe().f_back
зависит от того, используете ли вы функцию или нет.
Вызов инспектора напрямую:
from inspect import currentframe, getframeinfo
cf = currentframe()
filename = getframeinfo(cf).filename
print "This is line 5, python says line ", cf.f_lineno
print "The filename is ", filename
Вызов функции, которая делает это за вас:
from inspect import currentframe
def get_linenumber():
cf = currentframe()
return cf.f_back.f_lineno
print "This is line 7, python says line ", get_linenumber()
Удобно, если используется в общем файле - выводит имя файла, номер строки и функцию вызывающего:
import inspect
def getLineInfo():
print(inspect.stack()[1][1],":",inspect.stack()[1][2],":",
inspect.stack()[1][3])
Имя файла :
__file__
# or
sys.argv[0]
Линия :
inspect.currentframe().f_lineno
(не inspect.currentframe().f_back.f_lineno
как указано выше)
NameError: global name '__file__' is not defined
на моем интерпретатора: Python 2.7.6 (default, Sep 26 2014, 15:59:23)
. См stackoverflow.com/questions/9271464/...
Лучше также использовать sys-
print dir(sys._getframe())
print dir(sys._getframe().f_lineno)
print sys._getframe().f_lineno
Результат:
['__class__', '__delattr__', '__doc__', '__format__', '__getattribute__', '__hash__', '__init__', '__new__', '__reduce__', '__reduce_ex__', '__repr__', '__setattr__', '__sizeof__', '__str__', '__subclasshook__', 'f_back', 'f_builtins', 'f_code', 'f_exc_traceback', 'f_exc_type', 'f_exc_value', 'f_globals', 'f_lasti', 'f_lineno', 'f_locals', 'f_restricted', 'f_trace']
['__abs__', '__add__', '__and__', '__class__', '__cmp__', '__coerce__', '__delattr__', '__div__', '__divmod__', '__doc__', '__float__', '__floordiv__', '__format__', '__getattribute__', '__getnewargs__', '__hash__', '__hex__', '__index__', '__init__', '__int__', '__invert__', '__long__', '__lshift__', '__mod__', '__mul__', '__neg__', '__new__', '__nonzero__', '__oct__', '__or__', '__pos__', '__pow__', '__radd__', '__rand__', '__rdiv__', '__rdivmod__', '__reduce__', '__reduce_ex__', '__repr__', '__rfloordiv__', '__rlshift__', '__rmod__', '__rmul__', '__ror__', '__rpow__', '__rrshift__', '__rshift__', '__rsub__', '__rtruediv__', '__rxor__', '__setattr__', '__sizeof__', '__str__', '__sub__', '__subclasshook__', '__truediv__', '__trunc__', '__xor__', 'bit_length', 'conjugate', 'denominator', 'imag', 'numerator', 'real']
14
Просто чтобы внести свой вклад,
есть linecache
модуль в python, вот две ссылки, которые могут помочь.
документация модуля
linecache исходный код linecache
В некотором смысле вы можете «выгрузить» целый файл в его кеш и прочитать его с данными linecache.cache из класса.
import linecache as allLines
## have in mind that fileName in linecache behaves as any other open statement, you will need a path to a file if file is not in the same directory as script
linesList = allLines.updatechache( fileName ,None)
for i,x in enumerate(lineslist): print(i,x) #prints the line number and content
#or for more info
print(line.cache)
#or you need a specific line
specLine = allLines.getline(fileName,numbOfLine)
#returns a textual line from that number of line
Для получения дополнительной информации для обработки ошибок вы можете просто использовать
from sys import exc_info
try:
raise YourError # or some other error
except Exception:
print(exc_info() )
import inspect
file_name = __FILE__
current_line_no = inspect.stack()[0][2]
current_function_name = inspect.stack()[0][3]
#Try printing inspect.stack() you can see current stack and pick whatever you want
__file__
: См stackoverflow.com/questions/3056048/...
В Python 3 вы можете использовать вариант:
def Deb(msg = None):
print(f"Debug {sys._getframe().f_back.f_lineno}: {msg if msg is not None else ''}")
Затем в коде вы можете использовать:
Deb("Some useful information")
Deb()
Производить:
123: Some useful information
124:
Где 123 и 124 - линии, с которых совершаются звонки.
Вот что у меня работает, чтобы получить номер строки в Python 3.7.3 в VSCode 1.39.2 ( dmsg
это моя мнемоника для сообщения отладки):
import inspect
def dmsg(text_s):
print (str(inspect.currentframe().f_back.f_lineno) + '| ' + text_s)
Чтобы вызвать отображение переменной name_s
и ее значения:
name_s = put_code_here
dmsg('name_s: ' + name_s)
Результат выглядит так:
37| name_s: value_of_variable_at_line_37