如何从查询中取消“无”

2024-04-29 02:49:39 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在用python/flask构建一个梦幻棒球网站,使用Bulma作为css。我对烧瓶的开发还不熟悉。MySql是后端数据库。我正在构建的页面将显示草稿结果。除了这个小麻烦,我都搞定了。我已经做了很多搜索,但还没有找到我的具体答案,所以请求一点帮助。。。在

该页面显示草稿结果表。每一行将包含一个大联盟棒球运动员或一个小联盟球员,但不能同时包含两者。换言之,最后2列中的一列应该是空白的,其中一列应该有一个球员的名字和链接到他的mlb/milb页面。我得到的是:

enter image description here

“我不想成为空白”的价值观。以下是我的相关代码:

在应用程序副本在

    @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)

初稿结果中_上一页.html,我有这张桌子:

^{pr2}$

我觉得我需要一些“if”循环来检查最后2列的值是否为null,但我不确定语法。任何建议都将不胜感激!在


根据kungpho的回答编辑如下:

如果我这样做:

^{3}$

我明白了:

enter image description here

这正是我想要的米尔布选择栏。所以我试着对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

呜呜!在


Tags: textnameidaslinkleftteamclass
1条回答
网友
1楼 · 发布于 2024-04-29 02:49:39

在您的例子中,是的,看起来一个简单的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 ^{} filtertrue这里将它应用于假值,而不仅仅是未定义的变量):

^{pr2}$

相关问题 更多 >