jinja

[filters] Jinja - sort() 필터 ★ - 정렬 (= sort필터 = 소트필터) ※ 오름차순/내림차순

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

 

sort() 예제 - 정렬

[예제1] - 숫자 List 정렬

 

{% set nums = [3, 1, 2, 5, 4] %}

 

{{ nums|sort }} {# [1, 2, 3, 4, 5] #}

{{ nums|sort(reverse=true) }} {# [5, 4, 3, 2, 1] #}

 


[예제2] - 문자열 List 정렬

 

{% set cities = ['서울','광주','대전','부산'] %}


{% for city in cities|sort %}

    {{ city }}

{% endfor %}

 


[예제3] - 여러 정렬 기준을 순차적으로 적용 가능.

 

{% set users = [

    {'name': '영희', 'age': 10},

    {'name': '철수', 'age': 20},

    {'name': '길동', 'age': 30}

] %}


{% for user in users|sort(attribute="name")

    |sort(reverse=true, attribute="age") %}

    {{ user.name }}({{ user.age }})

{% endfor %}

 

결과값: 길동(30) 철수(20) 영희(10)


[예제4] - 정렬 방향 동일 시, 속셩명을 쉼표(,)로 나열 가능

 

{% for user in users|sort(attribute="age,name") %}

    {{ user.name }}({{ user.age }})

{% endfor %}

 

결과값: 영희(10) 철수(20) 길동(30)

 

 

sort() 정의

 

Python의 sorted() 메서드 사용해 반복 가능한 항목을 정렬하는 필터.

 


 

1. 

for 반복문에서 유용.

 

{% for city in cities|sort %}

    ...

{% endfor %}

 

2. 

정렬은 안정적이며 동일하다고 비교되는 요소의 상대적 순서를 변경하지 않음. 이를 통해 다양한 속성과 순서에 따라 정렬을 연결 가능.

 

{% for user in users|sort(attribute="name")

    |sort(reverse=true, attribute="age") %}

    ...

{% endfor %}

 

3. 

모든 속성에 대해 방향이 동일할 때 체이닝을 간소화하기 위해 쉼표로 구분된 속성 목록을 전달.

 

{% for user in users|sort(attribute="age,name") %}

    ...

{% endfor %}

 

 

4. cf.

  • reverse() 필터 - 역순 (= 순서 뒤집기)

 

5.

  • Jinja2 2.11.0 - attribute 매개변수는 쉼표로 구분된 속성 목록으로 지정 가능. 예: "age, name".
  • Jinja2 2.6 - attribute 매개변수가 추가됨.

 

6. 공식 매뉴얼

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

 

 

sort() 구문

 

jinja-filters.sort(value: 't.Iterable[V]', reverse: bool = False, case_sensitive: bool = False, attribute: str | int | NoneType = None) → 't.List[V]'

 


[매개변수]

 

value: 't.Iterable[V]'

필수. 반복가능한 값에 대해 적용.

 

reverse: bool = False

선택. 내림차순 여부 지정.

 

case_sensitive: bool = False

선택. 문자열 정렬 시, 대소문자 구분 여부 지정.

 

attribute: str | int | NoneType = None

선택. 객체(objects)나 딕셔너리(dicts) 자료형 정렬 시, 정렬 기준이 되는 속성(attribute)이나 키(key) 지정. (예) "address.city"와 같은 점 표기법 사용할 수도 있고, "age,name"과 같은 속성 목록일 수 있음.

 


[반환값]

 

지정 순서로 정렬된 리스트 반환. 

 



분류 제목
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 - 맞춤 필터
1/11
목록
 홈  PC버전 로그인 일본어
그누앞단언어
그누뒷단언어
그외코딩언어
그누보드
제작의뢰
Q&A
커뮤니티 2
웹유틸
회원센터
홈짱닷컴 PC버전 로그인