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

[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"과 같은 속성 목록일 수 있음.

 


[반환값]

 

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

 



분류 제목
tests Jinja - divisibleby() 테스트 - 해당값을 지정숫자로 나머지 없이 정확히 나눌 수 있는지 여…
tests Jinja - eq() / equalto() 테스트 - 동일한지(=같은지) 여부 체크 (= eq테스트 = 이…
tests Jinja - escaped() 테스트 - 회피처리된 값인지 체크 (= escaped테스트 = 이스케이프드테…
tests Jinja - even() 테스트 - 짝수인지 여부 체크 (= even테스트 = 이븐테스트)
tests Jinja - false() 테스트 - 거짓인지 체크 (= false테스트 = 폴스테스트)
tests Jinja - filter() 테스트 - 필터 존재 여부 체크 (= filter테스트 = 필터테스트)
tests Jinja - float() 테스트 - 부동소수(실수) 여부 체크 (= float테스트 = 플로우트테스트)
tests Jinja - ge() 테스트 - 더 크거나 같은지 체크 (= ge테스트 = 지이테스트/제테스트/게테스트)
tests Jinja - gt() / greaterthan() 테스트 - 더 큰지 체크 (= gt테스트 = 지티테스트 …
tests Jinja - in() 테스트 - 지정값이 시퀀스에 있는지 체크 (= in테스트 = 인테스트)
tests Jinja - integer() 테스트 - 정수인지 여부 체크 (= integer테스트 = 인티저테스트/인트…
tests Jinja - iterable() 테스트 - 반복 가능한 객체인지 체크 (= iterable테스트 = 이터러…
tests Jinja - le() 테스트 - 더 작거나 같은지 체크 (= le테스트 = 엘이데스트/레테스트)
tests Jinja - lower() 테스트 - 소문자인지 여부 체크 (= lower테스트 = 로우어테스트)
tests Jinja - lt() / lessthan() 테스트 - 보다 더 작은지 체크 (= lt테스트 = 엘티테스트…
tests Jinja - mapping() 테스트 - 매핑인지 여부 체크 (= mapping테스트 = 매핑테스트)
tests Jinja - ne() 테스트 - 다른지 여부 체크 (= ne테스트 = 네테스트/낫이퀄테스트)
tests Jinja - none() 테스트 - none인지 여부 체크 (= none테스트 = 넌테스트)
tests Jinja - number() 테스트 - 숫자인지 체크 (= number테스트 = 넘버테스트)
tests Jinja - odd() 테스트 - 홀수인지 여부 체크 (= odd테스트 = 아드테스트)
7/9
목록
찾아주셔서 감사합니다. Since 2012