渲染列表对象的问题:AttributeError:'list'对象没有属性'...'

时间:2015-09-24 05:20:08

标签: python json rest pyramid traceback

我试图在views.py文件中通过return {'category_name': category.category_name}渲染好的'JSON'。我正在使用Pyramid Web Framework。我在SQLALCHEMY数据库中使用自定义RESTful Web api和CRUD设计。

出于某种原因,我不断获得Traceback error

views/views.py", line 112, in get_category
    return {'category': category.category_name}
AttributeError: 'list' object has no attribute 'category_name'

我想要做的就是将其打印到HTML或将其呈现为HTML,以便我可以看到创建的内容。类别确实具有属性category_name ...这令人困惑。也许要返回一个列表值,我必须使用特殊的语法?我在网上找不到任何对我有意义的东西(这是most relevant),但任何指导都会非常感激!我确信这很简单。

GET方法:返回对象的站点(意味着稍后在Jinja2模板上呈现):

@view_config(route_name='category', request_method='GET', renderer='json')
def get_category(request):
    with transaction.manager:
        category_id = int(request.matchdict['id'])
        category = api.retrieve_category(category_id)
        if category is None:
            raise HTTPNotFound()
        return {'category_name': category.category_name}

这就是POST方法的样子(非常类似于DB api中的Create函数):

@view_config(route_name='categories', request_method='POST', renderer='json')
def post_category(request):
    with transaction.manager:
        category_name = request.params['category_name']
        category = api.create_category(category_name)
        return HTTPCreated(location=request.route_url('category',id=id))

用于创建类别的数据库API(这与评估有多对多关系,因此列表):

def create_category(self, category_name):
    new_category = Category(category_name)
    self.session.add(new_category)
    print(new_category)
    self.session.commit()

检索方法:

def retrieve_category(self, something_unique):
    if isinstance(something_unique, int):
        return self.session.query(Category).\
        filter(Category.category_id == something_unique).all() # multiple categories
    elif isinstance(something_unique, basestring):
        print(something_unique) # added
        return self.session.query(Category).\
        filter(Category.category_name == something_unique).one()
        print(something_unique)
        if NoResultFound:
            raise NotFoundError('No results found')
        elif MultipleResultsFound:
            raise MultipleResultsFound('Too many results found')
    elif isinstance(something_unique, Category):
        return something_unique
    else:
        raise ValueError('Value being passed is an object')

便利api(继承):

def create_assessment(self, name, text, username, videoname, category_names):
    user = self.retrieve_user(username)
    video = self.retrieve_video(videoname)
    cat_objects = [self.retrieve_category(category_name) for category_name in category_names]
    return super(ConvenienceAPI, self).create_assessment(name, text, user, video, cat_objects)

1 个答案:

答案 0 :(得分:2)

正如例外所示,

api.retrieve_category()正在返回一个列表。你期待它回归什么?

您需要检查您的API返回的内容。可能您可以访问返回列表中的第一项,以便这可能有效:

return {'category_name': category[0].category_name}

但是,如果API实际上返回一个空列表([])以表示没有结果,那么您需要检查它而不是None

if not category:
    raise HTTPNotFound()