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

[filters] Jinja - select() 필터 - 지정 테스트 통과한 요소만 필터링 (= select필터 = 실렉트필터) ※ 테스트 통과 성공한 아이템 얻기

목차
  1. select() 예제 - 테스트 통과한 요소만 필터링
  2. select() 정의
  3. select() 구문

 

select() 예제 - 테스트 통과한 요소만 필터링

[예제1] - 홀수만 출력

 

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


{% for n in numbers|select("odd") %}

  {{ n }}

{% endfor %}

 

결과값: 1 3 5


[예제2] - 짝수만 출력

 

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


{% for n in numbers|select("even") %}

  {{ n }}

{% endfor %}

 

결과값: 2 4


[예제3] - 3으로 정확히 나눠지는 수만 출력

 

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


{% for n in numbers|select("divisibleby", 3) %}

  {{ n }}

{% endfor %}

 

결과값: 3


[예제4] - 지정 숫자보다 작은 수만 출력

 

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


{% for n in numbers|select("lessthan", 3) %}

  {{ n }}

{% endfor %}

 

결과값: 1 2


[예제5] - 정확히 일치하는 문자열만 출력

 

{% set strings = ["홈짱닷컴","Homzzang.com", "홈짱"] %}


{% for n in strings|select("equalto", "홈짱") %}

  {{ n }}

{% endfor %} 

 

결과값: 홈짱


[예제6] - 매개변수가 전혀 없는 경우, boolean으로 평가

 

{% set A = [false,true,123,"홈짱"] %}


{% for n in A|select %}

  {{ n }}

{% endfor %}

 

결과값: True 123 홈짱 

 

select() 정의

 

반복 가능한 객체에 테스트(test) 적용 후 해당 테스트에 성공(= 필터링 통과)한 요소로 구성된 반복 가능한 객체를 반환하는 필터.

 


 

1.

테스트 미지정 시, 각 요소는 boolean() 으로 평가됨. 즉, true이거나 true로 평가되는 요소들로 구성된 객체가 반환됨.

  • {{ numbers|select }}
  • {{ numbers|select("odd") }}
  • {{ numbers|select("even") }}
  • {{ numbers|select("divisibleby", 3) }}
  • {{ numbers|select("lessthan", 42) }}
  • {{ strings|select("equalto", "mystring") }}

 

2. 다음과 같은 generator와 유사하다고 보면 됨.

  • (n for n in numbers if test_odd(n))
  • (n for n in numbers if test_divisibleby(n, 3))

 

3. cf.

  • reject() 필터 - 지정 테스트 통과 못 한 요소만 필터링 후 반복자 반환.

 

4.

Jinja2 2.7 +

 

5. 공식 매뉴얼

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

 

 

select() 구문

 

jinja-filters.select(value: 't.Iterable[V]', *args: Any, **kwargs: Any) → 't.Iterator[V]'

 


[매개변수]

 

value: 't.Iterable[V]'

필수. select 필터를 적용할 반복가능한 값

 

*args: Any

튜플(tuple) 형태로 여러 독립변수 전달 가능.

 

**kwargs: Any

딕트(dict) 형태로 여러 독립변수 전달 가능.

 


[반환값]

 

테스트에 성공한 요소로 구성된 반복 가능한 객체 반환.

 



분류 제목
tests Jinja - sameas() 테스트 - 두 객체의 메모리 주소 동일성 체크 (= sameas테스트 = 세임…
tests Jinja - sequence() 테스트 - 시퀀스인지 여부 체크 (= sequence테스트 = 시퀀스테스트…
tests Jinja - string() 테스트 - 문자열인지 체크 (= string테스트 = 스트링테스트)
tests Jinja - test() 테스트 - 테스트 존재 여부 체크 (= test테스트 = 테스트테스트)
tests Jinja - true() 테스트 - 참인지 체크 (= true테스트 = 트루테스트)
tests Jinja - undefined() 테스트 - 변수가 정의 안 되었는지 체크 (= undefined테스트 =…
tests Jinja - upper() 테스트 - 대문자인지 체크 (= upper테스트 = 어퍼테스트)
functions Jinja - range() 함수 ★ - 지정 범위 안 지정 간격의 정수 리스트 반환 (= range함수 =…
functions Jinja - lipsum() 함수 - 로렘입섬(= 의미없는 채우기용 문자열) (=lipsum함수 = 립섬함…
functions Jinja - dict() 함수 ★ - 딕트 리터럴 반환 (= 딕셔너리 반환 = dict함수 = 딕트함수)
functions Jinja - cycler() 함수 ★ - 교대순환 반환 (=cycler함수 = 사이클러함수) ※ cycle…
functions Jinja - joiner() 함수 ★ - 결합구분자 지정 (= 결합문자 지정 = joiner함수 = 조이너…
functions Jinja - namespace() 함수 - 속성 할당 가능한 변수 생성 (= namespace함수 = 네임…
structures Jinja - for 반복문 (= for반복문 = 포반복문/포문)
structures Jinja - if 조건문 (= if조건문 = 이프조건문/이프문)
structures Jinja - macro (매크로)
structures Jinja - call (콜블럭) ※ caller함수 = 콜러함수
structures Jinja - filter (필터섹션)
structures Jinja - Assignments (할당) ※ set태그 = 셋태그 ※ namespace (네임스페이스) …
structures Jinja - Block Assignments (블럭 할당)
8/9
목록
찾아주셔서 감사합니다. Since 2012