我试图在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')
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)
答案 0 :(得分:2)
api.retrieve_category()
正在返回一个列表。你期待它回归什么?
您需要检查您的API返回的内容。可能您可以访问返回列表中的第一项,以便这可能有效:
return {'category_name': category[0].category_name}
但是,如果API实际上返回一个空列表([]
)以表示没有结果,那么您需要检查它而不是None
:
if not category:
raise HTTPNotFound()