15

Django dumpdata 命令被破坏,因为它不支持任何合理的方法来缩小转储的数据量。我需要创建各种查询集的固定装置(而且我不需要关心从外部模型关系中转储对象)。限制这些查询集的项目数量,比如 django-test-utils makefixture 是不够的。试图通过使用带有自定义管理器的代理模型来实现这一点,但这种方法不起作用 - dumpdata 省略了代理模型(这是合理的)。

4

4 回答 4

43

如果dumpdata不起作用,您可以通过Django Serializing data来做同样的事情。

from django.core import serializers
data = serializers.serialize("json", SomeModel.objects.all())

然后写data在一个文件上。

于 2012-07-20T13:27:29.120 回答
8

以下步骤将有助于完成解决方案,为创建各种查询集的固定提供支持。

from django.core import serializers
from django.core.management.commands.dumpdata import sort_dependencies

app_list = {}

# Add all your querysets here. The key for the dictionary can be just a 
# unique dummy string (A safe hack after reading django code)
app_list['app1_name'] = FirstModel.objects.all()
app_list['app2_name'] = SecondModel.objects.all()

# The sort_dependencies will ensure that the models are sorted so that
# those with foreign keys are taken care. If SecondModel has a fk to FirstModel,
# then sort_dependencies will take care of the ordering in the json file so that
# FirstModel comes first in the fixture thus preventing ambiguity when reloading
data = serializers.serialize("json", sort_dependencies(app_list.items()))
f = open('output.json', 'w')
f.write(data)
f.close()

现在输出将在output.json文件中可用。从 json 文件重建模型:

from django.core import serializers

for obj in serializers.deserialize('json', open('output.json').read()):
    obj.save()

编辑:奇怪的是, sort_dependencies 没有按预期工作。所以我最终使用了 python ordereddict 并自己决定了顺序。

import collections

app_list = collections.OrderedDict()
于 2014-08-24T06:54:20.213 回答
2

如果要将 json 数据直接保存到文件中,可以使用:

from django.core import serializers


data = YourModel.objects.all()
with open("fixtures.json", "w") as out:
    serializers.serialize("json", data, stream=out)
于 2020-12-08T14:48:18.127 回答
-1

我不确定您所说的“外部模型关系”是什么意思,也许举个例子会有所帮助,但是您可以将 dumpdata 传递给您感兴趣的模型...

manage.py dumpdata --help
Usage: ./manage.py dumpdata [options] [appname appname.ModelName ...]

还有排除开关:

-e EXCLUDE, --exclude=EXCLUDE
                    An appname or appname.ModelName to exclude (use
                    multiple --exclude to exclude multiple apps/models).
于 2012-07-20T13:54:28.717 回答