фляга - как подавить "None" из запроса - PullRequest
0 голосов
/ 13 ноября 2018

Я создаю фэнтезийный сайт по бейсболу в python / flask, используя Bulma для css. Я довольно новичок в разработке колб. MySql - это внутренняя база данных. Страница, которую я создаю, должна показать черновики результатов. Я сделал за исключением этой маленькой неприятной проблемы. Я много занимался поиском, но не нашел своего конкретного ответа, поэтому просил небольшой помощи ...

На странице отображается таблица черновиков результатов. В каждом ряду будет либо игрок бейсбола высшей лиги, либо игрок низшей лиги, но не оба. Другими словами, один из последних 2 столбцов должен быть пустым, в нем должно быть имя игрока со ссылкой на его страницу 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>

Мне кажется, что мне нужен какой-то цикл "если" вокруг последних 2 столбцов, чтобы проверить, является ли значение нулевым, но я не уверен в синтаксисе. Любые указатели будут очень благодарны!


ИЗДАНО НА ОСНОВАНИИ ответа кунгфо ниже:

Если я сделаю это:

<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

Woohoo!

1 Ответ

0 голосов
/ 13 ноября 2018

В вашем случае, да, похоже, простое 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 имеет встроенный default фильтр (true здесь применяет его к значениям Falsey, а не только к неопределенным переменным):

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