我有一个小问题,也就是说,我想将客户端喜欢的数量转换为管理面板内的百分比,最大浮点数最多为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颗星等等。
最后一件事是在一行中显示所有这些喜欢的完整统计数据,例如在我的面板中,我会得到这样的内容:
所以在我的模板中我可以输入这样的内容:
<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 只是为了简化示例,让所有人都更清楚。
最终,它正在开展的一个项目,请任何建议都会受到赞赏:)。
答案 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>