목차
sort() 예제 - 정렬
sort() 정의
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.
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"과 같은 속성 목록일 수 있음.
[반환값]
지정 순서로 정렬된 리스트 반환.
주소 복사
랜덤 이동