Symfony2 DATEDIFF功能

时间:2014-10-28 10:44:13

标签: php symfony twig datediff

我需要在TWIG中填写数据库中的数据。一切都很好,除了这个:

我需要使用带有DATEDIFF属性的列来获取天数。

  

TODAY-dateFromDateBase

问题是: 如何在树枝中获取循环天数?

这是我的枝条:

<table>
            <thead>
            <tr>
                <form action="" method="post" {{ form_enctype(searchform) }} class="form-index-permits">
                    <td>L.p </td>
                    <td>ID PRZEPUSTKI {{ form_widget(searchform.PermitId) }}</td>
                    <td>Name{{ form_widget(searchform.Permitname) }}</td>
                    <td>Surname {{ form_widget(searchform.Permitsurname) }}</td>
                    <td>Company {{ form_widget(searchform.Company) }}</td>
                    <td>GW {{ form_widget(searchform.Contractor) }}</td>
                    <td>Dayleft {{ form_widget(searchform.Dayleft) }}</td>
                    <td>End date {{ form_widget(searchform.date, { 'attr': {'class': 'datepicker'} }) }}</td>

                </form>
            </tr>

            </thead>
            {% for permit in permitcollection %}
                <tbody>
                <td>{{ loop.index }}</td>
                <td>{{ permit.getPermitid()|number_format(0, '.', ' ') }}</td>
                <td>{{ permit.getPermitname() }}</td>
                <td>{{ permit.getPermitsurname() }}</td>
                <td>{{ permit.getPermitsCompany().getName() }}</td>
                <td>{{ permit.getPermitsContractor().getName() }}</td>
                <td> HERE I WANT TO DISPLAY DAYS LEFT</td>
                <td>{{ permit.getExpirationdate()|date('Y-m-d') }}</td>

                </tbody>
            {% endfor %}
        </table>

这样的事情可能吗?

{{ permit.getExpirationdate()|date('Y-m-d') - "now"|date('Y-m-d')  }}

1 个答案:

答案 0 :(得分:4)

第一个解决方案(推荐)“使用现有库”:

您可以使用KnpTimeBundle

在树枝上: 这与当前日期进行比较:

{# Returns something like "3 minutes ago" #}
{{ time_diff(permit.expirationDate) }}

这与另一个日期比较:

{# Returns something like "3 minutes ago" #}
{{ time_diff(permit.expirationDate, anotherDate) }}

第二个解决方案“自己动手”:

通过php函数制作差异:

$calcFrom = permit.getExpirationdate()

$now = new \DateTime('now');
$now->diff($calcFrom)->format("%a")

并通过Twig extension或直接在实体中的辅助方法中提供。

另一种可能的解决方案是编写注册表custom DQL Function来完成存储库中的工作

希望这个帮助