如何将喜欢的数字转换为百分数,Flask?

时间:2017-04-03 06:15:51

标签: python flask rate

我有一个小问题,也就是说,我想将客户端喜欢的数量转换为管理面板内的百分比,最大浮点数最多为5.0,因此他获得了5颗星,如果没有,则向下告诉0.0喜欢已经成立。

这是我的 model.py

appointment_upvotes = db.Table('appointment_upvotes',
    db.Column('appointment_id', db.Integer, db.ForeignKey('appointment.id')),
    db.Column('rate_appo_id', db.Integer, db.ForeignKey('rate_appo.id'))
)

class Appointment(db.Model):
    id = db.Column(db.Integer(), primary_key=True)
    start_time = db.Column(db.Integer(), nullable=False)
    end_time = db.Column(db.Integer(), nullable=False)
    timezone = db.Column(db.String(TIMEZONE_LEN_MAX), nullable=False)
    note = db.Column(db.String())
    status = db.Column(db.Boolean(), default=False)

    is_accepted = db.Column(db.Boolean(), default=False)
    is_not_accepted = db.Column(db.Boolean(), default=True)

    client_id = db.Column(db.Integer(), db.ForeignKey('client.id'))
    user_id = db.Column(db.Integer(), db.ForeignKey('user.id'))
    service_id = db.Column(db.Integer(), db.ForeignKey('service.id'))

    rates = db.relationship('RateAppo', backref='appointment', lazy='dynamic')

class RateAppo(db.Model):
    id = db.Column(db.Integer(), primary_key=True)
    rate_punctuality = db.Column(db.Integer(), default=0)
    rate_nonconf = db.Column(db.Integer(), default=0)
    rate_solvency = db.Column(db.Integer(), default=0)
    text = db.Column(db.Text(), default=None)

    appo_id = db.Column(db.Integer(), db.ForeignKey('appointment.id'))

    def __repr__(self):
        return "Comment: {}".format(self.text)[0:15]

    def has_voted(self, appointment_id):
        select_votes = appointment_upvotes.select(
                db.and_(
                    appointment_upvotes.c.appointment_id == appointment_id,
                    appointment_upvotes.c.rate_appo_id == self.id
                )
        )
        rs = db.engine.execute(select_votes)
        return False if rs.rowcount == 0 else True

    def vote(self, appointment_id, typevote):
        already_voted = self.has_voted(appointment_id)
        vote_status = None
        if not already_voted:
            if typevote == 'rate_punctuality':
                db.engine.execute(
                appointment_upvotes.insert(),
                    appointment_id = appointment_id,
                    rate_appo_id = self.id
                )
                self.rate_punctuality = self.rate_punctuality + 1
                vote_status = True
            elif typevote == 'rate_nonconf':
                db.engine.execute(
                appointment_upvotes.insert(),
                    appointment_id = appointment_id,
                    rate_appo_id = self.id
                )
                self.rate_nonconf = self.rate_nonconf + 1
                vote_status = True
            else:
                db.engine.execute(
                appointment_upvotes.insert(),
                    appointment_id = appointment_id,
                    rate_appo_id = self.id
                )
                self.rate_solvency = self.rate_solvency + 1
                vote_status = True
        db.session.commit()
        return vote_status

在“管理”面板中,费率将如下所示:

平均评分:4.5

并不重要他有多少喜欢,让我说他有100个喜欢,我不想通过计数来展示他们,只需要将价值提高到标记5.0

我忘记提及的另一件事,也许在我的jinja模板中,我可以使它工作?

以下是一个例子:

守时:100赞百分比可能会 4.52

偿付能力:63 以百分比计,可能是3.23

所以在准时中会有4颗星,而偿付能力将是3颗星等等。

最后一件事是在一行中显示所有这些喜欢的完整统计数据,例如在我的面板中,我会得到这样的内容:

click me to see an example

所以在我的模板中我可以输入这样的内容:

<div class="col-sm-8"><h2>Average Rating: <strong> {{ "%.2f" % user.rate_appo.count }} </strong></h2>
    <div class="table-responsive">
    <table class="table table-striped text-center">
      <thead>
        <tr>
          <th class="text-center">Punctuality</th>
          <th class="text-center">Non-Conflict</th>
          <th class="text-center">Solvency</th>



        </tr>
      </thead>
      <tbody>
        <tr>
          <td>{{ "%.2f" % user.rate_appo.rate_punctuality.count}} </td>
          <td>{{ "%.2f" % user.rate_appo.rate_nonconf.count}} </td>
          <td>{{ "%.2f" % user.rate_appo.rate_solvency.count}} </td>


        </tr>



      </tbody>
    </table>
</div>

我真的不确定上面输入的内容,我使用%。2f 只是为了简化示例,让所有人都更清楚。

最终,它正在开展的一个项目,请任何建议都会受到赞赏:)。

1 个答案:

答案 0 :(得分:0)

我无法找到你的模型中的“喜欢的数量”,但我认为你的问题是“将一个数字转换为另一种格式在flask-Admin面板中”。

如果是这样,这可能会有所帮助:

An example 自定义表单 - flask-Admin 。它使用自定义模型视图将文件路径转换为HTML标记<img>

这是关键代码:

https://github.com/flask-admin/flask-admin/blob/master/examples/forms/app.py#L110

编辑:

假设有一个名为convertLikes的python函数可以将喜欢的数字转换为星号,例如:convertLikes(100)将返回4.52。然后将其定义为jinja2的过滤器,并替换您的代码:

<td>{{ "%.2f" % user.rate_appo.rate_punctuality.count}} </td>

使用:

<td>{{ user.rate_appo.rate_punctuality.count | convertLikes }} </td>

过滤器语法将调用convertLikes(user.rate_appo.rate_punctuality.count)并将星号返回<td>标记。

例如:

在python中定义过滤函数:

def convertLikes(count):
    # do the convertion
    return stars_number

在模板环境中注册:

app = Flask(__name__)
app.jinja_env.filters['convertLikes'] = convertLikes

在jinja2模板中使用它:

<td>{{ user.rate_appo.rate_punctuality.count | convertLikes }} </td>