9

我想运行一个脚本来填充我的数据库。我想通过 Django 数据库 API 访问它。

唯一的问题是我不知道我需要导入什么才能访问它。

如何做到这一点?

4

5 回答 5

13

也导入您的设置模块

import os
os.environ["DJANGO_SETTINGS_MODULE"] = "mysite.settings"

from mysite.polls.models import Poll, Choice

应该做的伎俩。

于 2008-10-08T11:55:46.883 回答
6

这就是我的数据加载脚本顶部的内容。

import string
import sys
try:
    import settings # Assumed to be in the same directory.
    #settings.DISABLE_TRANSACTION_MANAGEMENT = True
except ImportError:
    sys.stderr.write("Error: Can't find the file 'settings.py' in the directory containing %r. It appears you've customized things.\nYou'll have to run django-admin.py, passing it your settings module.\n(If the file settings.py does indeed exist, it's causing an ImportError somehow.)\n" % __file__)
sys.exit(1)

#Setup the django environment with the settings module.
import django
import django.core.management
django.core.management.setup_environ(settings)

from django.db import transaction

这应该在您在脚本中执行许多其他操作之前全部执行。

另一种方法是使用fixtures 和manage.py。虽然如果您只是尝试完成批量数据加载以初始化数据库,这应该可以正常工作。

此外,根据您在做什么,您可能希望或可能不想在一次交易中完成所有操作。取消注释上面的事务行并像这样构建您的代码。

transaction.enter_transaction_management()
try:
    #Do some stuff
    transaction.commit()
finally:
    transaction.rollback()
    pass
transaction.leave_transaction_management()
于 2008-10-08T21:00:46.767 回答
5

如果您在项目目录中使用脚本的shell参数,则manage.py不必手动导入设置:

$ cd mysite/
$ ./manage.py shell
Python 2.5.2 (r252:60911, Jun 10 2008, 10:35:34) 
[GCC 4.0.1 (Apple Inc. build 5465)] on darwin
Type "help", "copyright", "credits" or "license" for more information.
>>> from myapp.models import *
>>>

对于非交互式使用,您可以实现自定义命令并使用manage.py.

于 2008-10-08T13:38:07.160 回答
1

最干净的解决方案是添加 django 扩展。

(virt1)tsmets@calvin:~/Documents/prive/rugby-club/proposal/kitu$ yolk -l
Django - 1.3.1 - 活跃
Pygments - 1.4 - 活跃
Python - 2.6.5 - 积极开发 (/usr/lib/python2.6/lib-dynload)
django-extensions - 0.7.1 - 活跃
pip - 1.0.2 - 活跃
setuptools - 0.6c11 - 活动
wsgiref - 0.1.2 - 积极开发 (/usr/lib/python2.6)
蛋黄 - 0.4.1 - 活跃

然后使用 runscript 命令扩展可能的命令列表。

于 2011-10-24T00:21:03.750 回答
0

除了您自己的模型文件之外,您还需要导入您的设置模块。

于 2008-10-08T11:37:18.433 回答