cProfile for Python не распознает имя функции
В приложении есть функция электронной почты, которую я хочу профилировать. Когда я пытаюсь сделать что-то подобное, это взрывается
from django.core.management import BaseCommand
import cProfile
class Command(BaseCommand):
def handle(self, *args, **options):
from email.modname import send_email
cProfile.run('send_email(user_id=1, city_id=4)')
Когда я запускаю эту команду управления, она выдает следующую ошибку:
exec cmd in globals, locals
File "<string>", line 1, in <module>
NameError: name 'send_email' is not defined
Что мне здесь не хватает? Как cProfile оценивает строку (ищет имена функций в глобальном / локальном пространстве имен)?
1 ответ
Решение
Проблема в том, что вы импортировали send_email
внутри вашего определения метода.
Я предлагаю вам использовать runctx
:
cProfile.runctx('send_email()', None, locals())
cProfile.runctx(command, globals, locals, filename=None)
Эта функция аналогична run() с добавленными аргументами для предоставления глобальных и локальных словарей для командной строки.