python 通过PyCharm运行shell_plus?

v1uwarro  于 2023-02-15  发布在  Python
关注(0)|答案(8)|浏览(113)

有没有办法配置PyCharm来运行shell_plus而不是默认的shell?
我试着把管理命令的文本放在“启动脚本”中,但是我得到了下面的django_manage_shell.run(“/Users/cmason/counsyl/code/website/counsyl/product”)导入操作系统导入系统

if __name__ == "__main__":
    os.environ.setdefault("DJANGO_SETTINGS_MODULE", "settings")

    # The new Django 1.4 default manage.py wants "from django..." before
    # importing settings, but we usually tinker with sys.path in
    # settings_local.py, which is called from settings.py. Importing
    # settings.py works but does mean some double importing. Luckily that
    # module does very little work.
    import settings
    # appease pyflakes; don't ever do this in
    # non-super-meta-namespace-trickery code
    settings

    from django.core.management import execute_from_command_line

    execute_from_command_line("shellplus")

它还没有真正运行shell_plus。
看起来“启动脚本”是在默认情况下发生的,而不是代替默认情况。
Shell_plus会自动导入所有Django模型类。

5ssjco0h

5ssjco0h1#

我通过挂接shell_plus代码来自动加载模型对象,并将其附加到Preferences > Build, Execution, Deployment > Console > Django Console中的默认启动脚本:

from django_extensions.management import shells
from django.core.management.color import color_style
imported_items = shells.import_objects({}, color_style())
for k, v in imported_items.items():
    globals()[k] = v

这是在PyCharm 2018.3.3 Pro上
为完整起见,以下是启动脚本的完整内容:

import sys; print('Python %s on %s' % (sys.version, sys.platform))
import django; print('Django %s' % django.get_version())
sys.path.extend([WORKING_DIR_AND_PYTHON_PATHS])
if 'setup' in dir(django): django.setup()
import django_manage_shell; django_manage_shell.run(PROJECT_ROOT)

from django_extensions.management import shells
from django.core.management.color import color_style
imported_items = shells.import_objects({}, color_style())
for k, v in imported_items.items():
    globals()[k] = v
vsaztqbk

vsaztqbk2#

我一直在寻找解决这个问题的方法,结果我找到了这里。我尝试了其他人提出的解决方案,但似乎没有一个能解决这个问题。所以我决定寻找另一个解决方案。下面是我的想法:
下面的代码块是***PyCharm 2019.2***的原始Django控制台启动脚本:

import sys, django
print('Python %s on %s' % (sys.version, sys.platform))
print('Django %s' % django.get_version())
sys.path.extend([WORKING_DIR_AND_PYTHON_PATHS])
if 'setup' in dir(django):
    django.setup()
import django_manage_shell
django_manage_shell.run(PROJECT_ROOT)

安装***IPython***并将最后两行更改为如下所示,可以以最正确的方式完成此操作:

from IPython.core.getipython import get_ipython
ipython = get_ipython()
from django_extensions.management.notebook_extension import load_ipython_extension
load_ipython_extension(ipython)

要使其发挥作用:打开PyCharm设置(CTRL+S)并进入Django控制台部分。2然后在 * 启动脚本 * 窗口中进行更改并应用。3最后,启动新的 *Python控制台 * 示例。

lnxxn5zx

lnxxn5zx3#

我查看了shell_plus的源代码,注意到可以在Command类上使用一个名为get_imported_objects({})的方法
在PyCharm中,转到:构建、执行、部署〉控制台〉Django控制台〉启动脚本
将以下代码添加到该框中的现有代码中:

from django_extensions.management.commands.shell_plus import Command
globals().update(Command().get_imported_objects({}))

**注意:**您可能需要重新启动PyCharm才能看到效果。

vq8itlhq

vq8itlhq4#

解决这个问题的一种方法是创建一个新的Python运行配置。将目标设置为module,并为项目选择manage.py文件。然后将shell_plus放入Parameters字段。将Working Directory设置为project目录。最后,将Execution设置为Run with Python Console。应用更改,然后运行新配置。

rkttyhzu

rkttyhzu5#

这不是一个完整的答案,但我发现这个脚本至少加载了所有的应用模型。把这个放在设置〉控制台〉Django控制台〉启动脚本:

import sys
import logging
logging.basicConfig(format="%(levelname)-8s %(asctime)s %(name)s %(message)s", datefmt='%m/%d/%y %H:%M:%S', stream=sys.stdout )
log = logging.getLogger("root")

from django.db.models import get_models
from django.conf import settings
from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned

logging.config.dictConfig(settings.LOGGING)
log.debug("Logging has been initialized at DEBUG")
log.setLevel( logging.DEBUG)
log.disabled = False

for _class in get_models():
    if _class.__name__.startswith("Historical"): continue
    log.debug("Registering model {}".format(_class.__name__))
    globals()[_class.__name__] = _class

def debug_sql():
    from debug_toolbar.management.commands import debugsqlshell
    return

我还提交了一个feature request to JetBrains.

pxq42qpu

pxq42qpu6#

在Django 1.7中,以下脚本可以作为PyCharm 3.4的一个解决方案:
文件-〉设置-〉控制台-〉Django控制台和manage.py选项
Starting script中,输入:

import sys
import django
django.setup()

from django.db.models import get_models

for _class in get_models():
    globals()[_class.__name__] = _class
kt06eoxx

kt06eoxx8#

由于django.db.models.get_models不再存在,这里有一个更新的版本,它将完成与Christopher Mason的版本相同的任务。

import sys; print('Python %s on %s' % (sys.version, sys.platform))
import django; print('Django %s' % django.get_version())
import logging
logging.basicConfig(format="%(levelname)-8s %(asctime)s %(name)s %(message)s", datefmt='%m/%d/%y %H:%M:%S', stream=sys.stdout )
log = logging.getLogger("root")

from django.apps import apps
from django.conf import settings  
from django.core.exceptions import ObjectDoesNotExist, MultipleObjectsReturned

logging.config.dictConfig(settings.LOGGING)
log.debug("Logging has been initialized at DEBUG")
log.setLevel( logging.DEBUG)
log.disabled = False

for _configs in apps.get_app_configs():
    for _class in _configs.get_models():
        if _class.__name__.startswith("Historical"): continue
        log.debug("Registering model {}".format(_class.__name__))
        globals()[_class.__name__] = apps.get_model(_configs.label, _class.__name__)

def debug_sql():
    from debug_toolbar.management.commands import debugsqlshell
    return

相关问题