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

[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 - 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