首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >:数据库对象不可迭代

:数据库对象不可迭代
EN

Stack Overflow用户
提问于 2014-04-03 16:42:40
回答 2查看 1.8K关注 0票数 1

我正在开发一个电子商务网站,使用和Python。以下是我的数据存储中的实体“产品”:

现在,我试图根据用户的喜好过滤掉某些产品。用户可以通过下拉选项选择这些首选项。这里是‘newbooks.html’中相同的代码:

代码语言:javascript
复制
<form method = "post">
        <p>Department: </p>
        <select name = "branch">
            <option></option>
            <option>Computers</option>
            <option>EXTC</option>
            <option>IT</option>
            <option>ETRX</option>
            <option>MECH</option>
        </select>
        <br>
        <br>
        <p>Semester: </p>

        <select name = "semester">
            <option></option>
            <option>1</option>
            <option>2</option>
            <option>3</option>
            <option>4</option>
            <option>5</option>
            <option>6</option>
            <option>7</option>
            <option>8</option>
        </select>

        <br>
        <br>
        <p>Publications: </p>
        <select name = "publications">
            <option></option>
            <option>Techmax</option>
            <option>Nandu</option>
            <option>Pearson</option>
            <option>Tata McGraw Hill</option>
            <option>Technical</option>
        </select>
            <br>
        <br>
        <p>Subject: </p>
        <select name = "subject">
            <option></option>
            <option>System Programming and Compiler Construction</option>
            <option>Advanced Microprocessors</option>
            <option>Microprocessors and Interfacing</option>
            <option>Computer Networks</option>
            <option>Data Warehouse and Data Mining</option>
        </select>    

        <br><br>

        <input type = "submit">   
        </form>   

下面是我的python代码:

代码语言:javascript
复制
class NewBooks(Handler):
    def get(self):
        self.render("newbooks.html")
    def post(self):
        branch = self.request.get("branch")
        semester = self.request.get("semester")
        publications = self.request.get("publications")
        subject = self.request.get("subject")
        if semester:
            yo = int(semester)
        if(branch and semester and publications and subject):
            disp = Products.all().filter("branch =", branch).filter("publisher =", publications).filter("name =", subject).filter("semester =", yo).get()
            self.render("newbooks.html", disp = disp)
        elif(branch and semester and publications):
            disp = Products.all().filter("branch =", branch).filter("publisher =", publications).filter("semester =", yo).get()
            self.render("newbooks.html", disp = disp) 
        elif(branch and semester and subject):
            disp = Products.all().filter("branch =", branch).filter("name =", subject).filter("semester =", yo).get()
            self.render("newbooks.html", disp = disp)  
        elif(branch and publications and subject):
            disp = Products.all().filter("branch =", branch).filter("publisher =", publications).filter("name =", subject).get()
            self.render("newbooks.html", disp = disp)
        elif(semester and publications and subject):
            disp = Products.all().filter("publisher =", publications).filter("name =", subject).filter("semester =", yo).get()
            self.render("newbooks.html", disp = disp)
        elif(branch and semester):
            disp = Products.all().filter("branch =", branch).filter("semester =", yo).get()
            self.render("newbooks.html", disp = disp)
        elif(semester and publications):
            disp = Products.all().filter("publisher =", publications).filter("semester =", yo).get()
            self.render("newbooks.html", disp = disp)  
        elif(publications and subject):
            disp = Products.all().filter("publisher =", publications).filter("name =", subject).get()
            self.render("newbooks.html", disp = disp)
        elif(branch and subject):
            disp = Products.all().filter("branch =", branch).filter("name =", subject).get()
            self.render("newbooks.html", disp = disp) 
        elif(branch and publications):
            disp = Products.all().filter("branch =", branch).filter("publisher =", publications).get()
            self.render("newbooks.html", disp = disp)
        elif(semester and subject):
            disp = Products.all().filter("name =", subject).filter("semester =", yo).get()
            self.render("newbooks.html", disp = disp) 
        elif(branch):
            disp = Products.all().filter("branch =", branch).get()
            self.render("newbooks.html", disp = disp) 
        elif(semester):
            disp = Products.all().filter("semester =", yo).get()
            self.render("newbooks.html", disp = disp)
        elif(publications):
            disp = Products.all().filter("publisher =", publications).get()
            self.render("newbooks.html", disp = disp)  
        elif(subject):
            disp = Products.all().filter("name =", subject).get()
            self.render("newbooks.html", disp = disp)  

但是,在用户选择并提交他/她的首选筛选条件后,我将得到以下错误:

代码语言:javascript
复制
TypeError: 'Products' object is not iterable

我的代码有什么问题?为什么我的数据库中的条目不可迭代?

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2014-04-03 16:49:48

使用fetch()返回实体列表。get()只返回与查询匹配的第一个实体,因此它是不可迭代的。

票数 4
EN

Stack Overflow用户

发布于 2014-04-03 16:47:38

您正在调用得到(),它只返回“第一个结果”。相反,您应该调用取(),它返回一个结果列表。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/22843919

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档