自定义ModelResource中的字段以下载数据

时间:2015-09-23 12:36:12

标签: django django-import-export

使用Django Import/Export library,我目前正在使用以下代码创建resource,可用于以多种格式从Django项目下载数据(例如csv,excel,json等) ):

from import_export import resources

class Resource1(resources.ModelResource):
    class Meta:
        model = Person
        fields = ('First_Name', 'Last_Name')

resource = Resource1()
dataset = resource.export(queryset)

我现在正在创建具有不同属性(例如,不同字段)的多个资源版本。是否可以动态更改Meta(或_meta),以便使用所需的属性创建它?

class Resource2(resources.ModelResource):
    def __init__(self, fields):
        self.Meta.fields = fields
        # self._meta.fields = fields
    class Meta:
        model = Person

resource = Resource2(['First_Name', 'Last_Name', 'Address'])
dataset = resource.export(queryset)

当我尝试这个时,结果下载是空的。

2 个答案:

答案 0 :(得分:1)

我不确定我的问题是否正确,但我认为你不能让Meta选项“动态”。

但是,你可以做的是拥有一个抽象基类(Resource1)并从中继承它,例如:资源2?这是django文档的链接:

https://docs.djangoproject.com/en/1.8/topics/db/models/#abstract-base-classes

答案 1 :(得分:1)

我找到了一种直接的方法来动态更改类实例内部class Meta部分内的字段。下面的create_resource函数根据需要创建类的自定义版本,然后返回一个实例:

def create_resource(django_model, model_fields):
    class model_resource(resources.ModelResource):
        class Meta:
           model = django_model
           fields = model_fields
    return model_resource()

resource = create_resource(Person, ['First_Name', 'Last_Name', 'Address'])

然后我可以使用该资源导出数据:

dataset = resource.export(queryset)