flask-如何从查询中取消“无”

时间:2018-11-13 04:48:16

标签: python mysql flask bulma

我正在用python / flask建立一个幻想棒球网站,并使用Bulma作为CSS。我是烧瓶开发的新手。 MySql是后端数据库。我正在构建的页面用于显示草稿结果。除了这个烦人的小问题,我已经完成了。我已经做了很多搜索,但是还没有找到具体的答案,所以需要一点帮助...

该页面显示草稿结果表。每行将包含大联盟的棒球运动员或小联盟的运动员,但不能同时包含两者。换句话说,最后两列之一应为空白,一列应具有播放器名称,并带有指向其mlb / milb页面的链接。我得到的是这样的:

enter image description here

我想要的是“无”值是空白。这是我的相关代码:

app.py

    @app.route('/draft_results_prior/<string:yr>/')
def draft_results_prior(yr)
    try:
        conn = mysql.connect()
        cursor = conn.cursor(pymysql.cursors.DictCursor)
        cursor.execute("SELECT dr.draft_round, dr.pick_no, (SELECT af.city FROM act_franchise as af WHERE af.team_id = dr.original_team_id) orig_team, (SELECT af2.city FROM act_franchise as af2 WHERE af2.team_id = dr.traded_team_id) trade_team, dr.mlb_id, CONCAT('http://m.mlb.com/player/',dr.mlb_id) as Link, (SELECT concat(mlbr.name_first,' ', mlbr.name_last) FROM mlb_rosters as mlbr WHERE mlbr.mlb_id = dr.mlb_id) mlb_name, dr.milb_id, CONCAT('http://www.milb.com/player/index.jsp?sid=milb&player_id=',dr.milb_id) as milb_Link, (SELECT concat(milbr.name_first,' ', milbr.name_last) FROM milb_players as milbr WHERE milbr.milb_id = dr.milb_id) milb_name, dr.intl_id FROM draft_results as dr WHERE dr.ibc_year = %s",(yr))
        thisDraft = cursor.fetchall()`

        return render_template('draft_results_prior.html', thisDraft=thisDraft, yr=yr)
    except Exception as e:
        print(e)
    finally:
        cursor.close() 
        conn.close()
    return render_template('draft_results_prior.html', thisDraft=thisDraft)

在draft_results_prior.html中,我有此表:

<table class="table table-bordered is-fullwidth is-striped is-hoverable">
        <thead>
        <tr>
            <th class= "yellowones">Round #</th>
            <th class= "yellowones">Pick #</th>
            <th class= "yellowones">Team</th>
            <th class= "yellowones">Traded To</th>
            <th class= "yellowones">MLB Pick</th>
            <th class= "yellowones">MiLB Pick</th>
        </tr>
        </thead>
        {% for dr in thisDraft %}
            <tbody>
                <td class= "greenones has-text-left">{{dr.draft_round}}</td>
                <td class= "greenones has-text-left">{{dr.pick_no}}</td>
                <td class= "greenones has-text-left">{{dr.orig_team}}</td>
                <td class= "greenones has-text-left">{{dr.trade_team}}</td>
                <td class= "greenones has-text-left"><a href="{{dr.Link}}">{{dr.mlb_name}}</a></td>
                <td class= "greenones has-text-left"><a href="{{dr.milb_Link}}">{{dr.milb_name}}</a></td>
            </tbody>
        {% endfor %}
    </table>

我感觉我需要在最后两列周围进行某种“ if”循环,以检查该值是否为null,但是我不确定语法。任何指针将不胜感激!


根据以下kungpho的答案进行编辑:

如果我这样做:

<td class= "greenones has-text-left"><a href="{{dr.Link}}">{{dr.mlb_name}}</a></td>
{% if dr.milb_name %}
<td class= "greenones has-text-left"><a href="{{dr.milb_Link}}">{{dr.milb_name}}</a></td>
{% else %}
&nbsp;
{% endif %}

我明白了:

enter image description here

这正是我想要的MiLB Pick栏。因此,我尝试对MLB列进行相同的操作,但是它将两列合并为一个:

{% if dr.mlb_name %}
<td class= "greenones has-text-left"><a href="{{dr.Link}}">{{dr.mlb_name}}</a></td>
{% else %}
&nbsp;
{% endif %}
{% if dr.milb_name %}
<td class= "greenones has-text-left"><a href="{{dr.milb_Link}}">{{dr.milb_name}}</a></td>
{% else %}
&nbsp;
{% endif %}

这就是它的作用:

enter image description here

如何保留这两列?

编辑#2-正确答案

这是正确的答案:

{% if dr.mlb_name %}
<td class= "greenones has-text-left"><a href="{{dr.Link}}">{{dr.mlb_name}}</a></td>
{% else %}
<td class= "greenones has-text-left"><a href=""></a></td>
{% endif %}
{% if dr.milb_name %}
<td class= "greenones has-text-left"><a href="{{dr.milb_Link}}">{{dr.milb_name}}</a></td>
{% else %}
<td class= "greenones has-text-left"><a href=""></a></td>
{% endif %}

收益:

enter image description here

哇!

1 个答案:

答案 0 :(得分:1)

是的,是的,看起来简单的if应该可以解决问题。您仍将要呈现列本身,而不是内容,因此您的HTML保持有效(浏览器通常会容忍该列,但如果不这样做,则它最好保持尽可能的干净)。

示例:

<td class="greenones has-text-left">
    {% if dr.milb_Link %}
        <a href="{{ dr.milb_Link }}">{{ dr.milb_name }}</a>
    {% else %}
        &nbsp;
    {% endif %}
</td>

如果您只是显示一个值而不是一个HTML元素,那么Jinja2会有一个built-in default filtertrue在这里将它应用于虚假值,而不仅仅是未定义的变量):

{{ dr.milb_name|default('&nbsp;', true) }}