Comment formater les dates avec Liquid ?

Dans certains cas, il se peut que vous souhaitiez modifier la façon dont Looker formate les dates.

Par exemple, si vous créez des explorations et des tableaux de bord pour des utilisateurs en Europe, toutes les dates au format numérique doivent apparaître dans l'ordre Jour-Mois-Année. Par exemple, le 7 juin 2019 doit être au format 07/06/2019 ou Jun 07, 2019. Le format par défaut de Looker affiche la date au format 2019-06-07. Bien que vous puissiez utiliser des fonctions SQL telles que DATE_FORMAT() pour modifier un format de date, vous ne souhaiterez peut-être pas tout écrire en SQL brut.

Utiliser Liquid dans le paramètre html

Vous pouvez utiliser la mise en forme Liquid dans le paramètre html d'une dimension pour modifier le format de tout champ utilisant un format de date valide. Étant donné que Liquid attend une date valide, il est préférable d'utiliser les périodes d'un groupe de dimensions existant. Vous ne pouvez pas modifier les numéros de semaine ou de mois, car ils sont renvoyés sous forme d'entiers.

Par exemple, vous pouvez formater ${created_date} pour qu'il effectue le rendu Aug 23 22 au lieu du 2022-08-23 par défaut de Looker:


  dimension: date_formatted {
    sql: ${created_date} ;;
    html:{{ rendered_value | date: "%b %d, %y" }};;
  }


Le format de la syntaxe de chaîne "%b %d, %y" est identique à celui de strftime.

Étant donné que le paramètre html utilise la mise en forme Liquid, la valeur d'origine de la période n'est pas modifiée, mais uniquement la façon dont elle est affichée pour l'utilisateur. Cela garantit que l'ordre dans lequel les dates apparaissent dans une requête ne changera pas.

Voici d'autres exemples que vous pouvez utiliser. Vous trouverez la liste des formats disponibles en bas de cette page.

Préréglage Exemple
%m/%d/%Y 06/05/2013
%A, %B %e, %Y Mercredi 5 juin 2013
%b %e %a Mer. 5 juin

Exemple

L'exemple de requête d'exploration suivant affiche un format différent pour la Date des articles de la commande et la Semaine des articles de la commande sous un libellé de groupe Date de création pour simuler un groupe de dimensions "Date" dans le sélecteur de champs d'exploration.

Le format personnalisé indique aux utilisateurs la date et le numéro de la semaine de l'année qui correspondent aux valeurs Nombre d'articles les plus élevées, par ordre décroissant.

Consultez la page de documentation sur group_label pour en savoir plus sur l'utilisation du paramètre group_label.

Une requête d'exploration affiche des résultats de mise en forme personnalisée des dates pour la date des articles commandés et la semaine des articles commandés, triés par nombre d'articles dans l'ordre décroissant.

Le code LookML

L'exemple d'exploration utilise le code LookML suivant:



# The original dimension group - hidden so that users can only choose from the formatted dates date and week timeframes
  dimension_group: created {
    hidden: yes
    type: time
    timeframes: [
      raw,
      time,
      date,
      hour,
      hour_of_day,
      time_of_day,
      week,
      month,
      quarter,
      year
    ]
    sql: ${TABLE}.created_at ;;
  }

# The customized timeframes, organized in the Explore field picker under the group label Created date
  dimension: date_formatted {
    group_label: "Created date"
    label: "Date"
    type: date_raw
    sql: ${created_date} ;;
    html: {{ rendered_value | date: "%b %d, %y" }};;
  }

  dimension: week_formatted {
    group_label: "Created date"
    label: "Week"
    type: date_raw
    sql: ${created_week} ;;
    html: {{ rendered_value | date: "Week %U (%b %d)" }};;
  }


strftime Reference

Le tableau suivant répertorie les différents formats strftime. Veuillez noter que tous les formats peuvent ne pas s'afficher comme prévu dans Looker.

spécifieur Remplacé par Exemple
%a Nom abrégé du jour de la semaine * Jeu
%A Nom complet du jour de la semaine * Jeudi
%b Nom abrégé du mois * Août
%B Nom complet du mois * Août
%c Représentation de la date et de l'heure* Jeu. 23 août 14:55:02 2001
%C Année divisée par 100 et tronquée à l'unité (00-99) 20
%d Jour du mois, rempli par zéro (01-31) 23
%D Date JJ/MM/AA courte (équivalent à %m/%d/%y) 23/08/01
%e Jour du mois, complété par un espace ( 1-31) 23
%F Date courte AAAA-MM-JJ, équivalente à %Y-%m-%d 2001-08-23
%g Année basée sur la semaine, deux derniers chiffres (00-99) 1
%G Année basée sur les semaines 2001
%h Nom abrégé du mois * (identique à %b) Août
%H Heure au format 24 h (00-23) 14
%I Heure au format 12 h (01-12) 02
%j Jour de l'année (001-366) 235
%k Heure au format 24 h, les chiffres à un chiffre suivi d'un espace (0-23) 14
%l Heure au format 12 h, suivie d'un espace (0-12) 2
%m Mois, sous forme de nombre décimal (01-12) 8
%M Minute (00-59) 55
%n Caractère de nouvelle ligne ("\n")
%P Désignation am ou pm en minuscules pm
%r Heure au format 12 heures * 14:55:02
%R Heure HH:MM sur 24 heures, équivalent à %H:%M 14:55
%s Nombre de secondes depuis l'époque, 1970-01-01 00:00:00 +0000 (UTC) 1566236649
%S Seconde (00-61) 2
%t Caractère de tabulation horizontale ("\t")
%T Format d'heure ISO 8601 (HH:MM:SS), équivalent à %H:%M:%S 14:55:02
%u Jour de la semaine ISO 8601 sous forme de nombre, lundi sous la forme d'un 1 (1-7) 4
%U Numéro de la semaine dont le premier dimanche est le premier jour de la première semaine (00-53) 33
%V Numéro de semaine ISO 8601 (01-53) 34
%w Jour de la semaine sous forme de nombre décimal avec le dimanche sous la forme d'un 0 (0-6) 4
%W Numéro de semaine dont le premier lundi est le premier jour de la première semaine (00-53) 34
%x Représentation de la date * 23/08/01
%X Représentation temporelle * 14:55:02
%y Année, deux derniers chiffres (00-99) 1
%Y Année 2001
%z Décalage ISO 8601 par rapport à l'UTC dans le fuseau horaire (1 minute = 1, 1 heure = 100) Si le fuseau horaire ne peut pas être déterminé, aucun caractère 100
%Z Nom ou abréviation du fuseau horaire *Si le fuseau horaire ne peut pas être déterminé, aucun caractère CDT
%% Un signe % %