flask- 如何从查询中抑制 "None"
flask- how to suppress "None" from a query
我正在 python/flask 建立一个梦幻棒球网站,使用 Bulma 作为 css。我对烧瓶开发还很陌生。 MySql 是后端数据库。我正在构建的页面是为了显示草稿结果。除了这个讨厌的小问题,我已经完成了。我做了很多搜索,但没有找到我的具体答案,所以寻求一点帮助...
页面显示 table 草稿结果。每行将包含一名大联盟棒球运动员或一名小联盟球员,但不能同时包含两者。换句话说,最后两列之一应该是空白的,一个玩家的名字应该在他的 mlb/milb 页面上带有 link。我得到的是:
我想要的是 "None" 值是空白的。这是我的相关代码:
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:
<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>
我觉得我需要围绕最后 2 列进行某种 "if" 循环来检查该值是否为空,但我不确定语法。任何指针将不胜感激!
根据以下 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 %}
{% endif %}
我明白了:
这正是我想要的 MiLB Pick 专栏。所以我尝试对 MLB 列做同样的事情,但它把两列合并为一个:
{% if dr.mlb_name %}
<td class= "greenones has-text-left"><a href="{{dr.Link}}">{{dr.mlb_name}}</a></td>
{% else %}
{% endif %}
{% if dr.milb_name %}
<td class= "greenones has-text-left"><a href="{{dr.milb_Link}}">{{dr.milb_name}}</a></td>
{% else %}
{% endif %}
这是它所做的:
如何保留两列?
编辑 #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 %}
产量:
哇哦!
在您的情况下,是的,看起来简单的 if
应该可以解决问题。您仍然希望呈现列本身,而不是内容,因此您的 HTML 保持有效(如果您不这样做,浏览器通常会容忍它,但最好尽可能保持干净)。
示例:
<td class="greenones has-text-left">
{% if dr.milb_Link %}
<a href="{{ dr.milb_Link }}">{{ dr.milb_name }}</a>
{% else %}
{% endif %}
</td>
如果您只是显示一个值而不是 HTML 元素,Jinja2 有一个 built-in default
filter(这里的 true
将它应用于虚假值,而不仅仅是未定义的变量):
{{ dr.milb_name|default(' ', true) }}
我正在 python/flask 建立一个梦幻棒球网站,使用 Bulma 作为 css。我对烧瓶开发还很陌生。 MySql 是后端数据库。我正在构建的页面是为了显示草稿结果。除了这个讨厌的小问题,我已经完成了。我做了很多搜索,但没有找到我的具体答案,所以寻求一点帮助...
页面显示 table 草稿结果。每行将包含一名大联盟棒球运动员或一名小联盟球员,但不能同时包含两者。换句话说,最后两列之一应该是空白的,一个玩家的名字应该在他的 mlb/milb 页面上带有 link。我得到的是:
我想要的是 "None" 值是空白的。这是我的相关代码:
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:
<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>
我觉得我需要围绕最后 2 列进行某种 "if" 循环来检查该值是否为空,但我不确定语法。任何指针将不胜感激!
根据以下 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 %}
{% endif %}
我明白了:
这正是我想要的 MiLB Pick 专栏。所以我尝试对 MLB 列做同样的事情,但它把两列合并为一个:
{% if dr.mlb_name %}
<td class= "greenones has-text-left"><a href="{{dr.Link}}">{{dr.mlb_name}}</a></td>
{% else %}
{% endif %}
{% if dr.milb_name %}
<td class= "greenones has-text-left"><a href="{{dr.milb_Link}}">{{dr.milb_name}}</a></td>
{% else %}
{% endif %}
这是它所做的:
如何保留两列?
编辑 #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 %}
产量:
哇哦!
在您的情况下,是的,看起来简单的 if
应该可以解决问题。您仍然希望呈现列本身,而不是内容,因此您的 HTML 保持有效(如果您不这样做,浏览器通常会容忍它,但最好尽可能保持干净)。
示例:
<td class="greenones has-text-left">
{% if dr.milb_Link %}
<a href="{{ dr.milb_Link }}">{{ dr.milb_name }}</a>
{% else %}
{% endif %}
</td>
如果您只是显示一个值而不是 HTML 元素,Jinja2 有一个 built-in default
filter(这里的 true
将它应用于虚假值,而不仅仅是未定义的变量):
{{ dr.milb_name|default(' ', true) }}