• 회원가입
  • 로그인
  • 구글아이디로 로그인

[filters] Jinja - dictsort() 필터 - 딕셔너리 키 또는 값으로 정렬. (=dictsort필터 = 딕트소트필터)

목차
  1. dictsort() 예제 - dict 정렬
  2. dictsort() 정의
  3. dictsort() 구문

 

dictsort() 예제 - dict 정렬

[예제] - (대소문자 구분 O / value 기준 / 역순) 정렬 경우

{% set mydict = {'apple': 5, 'Banana': 2, 'orange': 8, 'Kiwi': 3} %}


{% for key, value in mydict|dictsort(true, 'value', true) %}

    {{ key }}/{{ value }} 

{% endfor %}

 

결과값: orange/8 apple/5 Kiwi/3 Banana/2

 

dictsort() 정의

 

dict 및 Yield (키, 값) 쌍을 정렬하는 필터.

 



1.
Python dict는 표시하려는 순서가 아닐 수 있으므로 먼저 정렬.

 


2. 여러가지 정렬 기준 조합

  • {% for key, value in mydict|dictsort %} - (대소문자 구분X / key 기준 / 기본) 정렬
  • {% for key, value in mydict|dictsort(reverse=true) %} - (대소문자 구분 X / key 기준 / 역순) 정렬
  • {% for key, value in mydict|dictsort(true) %} - (대소문자 구분 O / key 기준 / 기본) 정렬
  • {% for key, value in mydict|dictsort(false, 'value') %} - (대소문자 구분 X / value 기준 / 기본) 정렬

 

3. 공식 매뉴얼

https://jinja.palletsprojects.com/en/3.1.x/templates/#jinja-filters.dictsort

 

 

dictsort() 구문

 

jinja-filters.dictsort(value: Mapping[K, V], case_sensitive: bool = False, by: 'te.Literal["key", "value"]' = 'key', reverse: bool = False) → List[Tuple[K, V]]

 


[매개변수]

 

value: Mapping[K, V]

필수. 이 필터를 적용할 key:value 쌍으로 구성된 값. (예: dict)

 

case_sensitive: bool = False

선택. 대소문자 구분 여부.

 

by: 'te.Literal["key", "value"]' = 'key'

선택. 정렬 기준 지정.

 

reverse: bool = False

선택. 역순 여부 지정.

 


[반환값]

 

지정 순서로 정렬된 key:value 쌍으로 구성된 값 반환. (List, Tuple 형태)

 



분류 제목
intro Jinja - 소개 - 설치
api Jinja - API - 기초
api Jinja - API - 고급 API
api Jinja - API - 자동 이스케이프
api Jinja - API - 식별자에 관한 참고 사항
api Jinja - API - 정의되지 않은 유형
api Jinja - API - 문맥
api Jinja - API - 로더
api Jinja - API - 바이트코드 캐시
api Jinja - API - 비동기 지원
api Jinja - API - 정책
api Jinja - API - 유용
api Jinja - API - 예외
api Jinja - API - 맞춤 필터
api Jinja - API - 맞춤형 테스트
api Jinja - API - 평가 컨텍스트
api Jinja - API - 글로벌 네임스페이스
api Jinja - API - 저수준 API
api Jinja - API - 메타 API
1/9
목록
찾아주셔서 감사합니다. Since 2012