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

[filters] Jinja - slice() 필터 - 집합을 지정 개수로 쪼개기 (= slice필터 = 슬라이스필터) ※ 지정 개수의 컬럼으로 나누기

목차
  1. slice() 예제 - 집합 쪼개기
  2. slice() 정의
  3. slice() 구문

 

slice() 예제 - 집합 쪼개기

[예제] - List를 3등분 해서, 3개의 UL 만들기

 

{% set items = ['가','나','다','라','마'] %}


<div class="columnwrapper">

  {%- for column in items|slice(3) %}

    <ul class="column-{{ loop.index }}">

    {%- for item in column %}

      <li>{{ item }}</li>

    {%- endfor %}

    </ul>

  {%- endfor %}

</div>

 

결과값:

<div class="columnwrapper">

    <ul class="column-1">

      <li>가</li>

      <li>나</li>

    </ul>

    <ul class="column-2">

      <li>다</li>

      <li>라</li>

    </ul>

    <ul class="column-3">

      <li>마</li>

    </ul>

</div>


[예제2] - 누락된 부분에 채울 값 지정

 

{% set items = ['가','나','다','라','마'] %}


<div class="columnwrapper">

  {%- for column in items|slice(3,fill_with="홈짱") %}

    <ul class="column-{{ loop.index }}">

    {%- for item in column %}

      <li>{{ item }}</li>

    {%- endfor %}

    </ul>

  {%- endfor %}

</div>

 

결과값:

<div class="columnwrapper">

    <ul class="column-1">

      <li>가</li>

      <li>나</li>

    </ul>

    <ul class="column-2">

      <li>다</li>

      <li>라</li>

    </ul>

    <ul class="column-3">

      <li>마</li>

      <li>홈짱</li>

    </ul>

</div>


PS. '{%' 기호 바로 뒤에 '-' 문자 있는 이유

  • Jinja 템플릿에서 {%와 %} 사이에 있는 -는 공백 제어 기호임. 이를 사용하여 템플릿 엔진이 생성하는 결과물에서 불필요한 공백을 제거할 수 있음. (예) {%와 %} 사이에 -를 사용하면 개행 문자를 제거하여 생성되는 HTML 코드를 좀 더 읽기 쉽게 만들 수 있음.
  • 위의 예제 코드에서 -는 {%-와 -%}를 사용하여 제거될 수 있는 공백을 나타냄. 이를 통해 템플릿 코드와 생성된 HTML 사이의 공백이 제거되어 렌더링된 결과물이 더 깔끔하게 보일 수 있음.

 

 

slice() 정의

 

반복자(iterator)를 분할하고 해당 항목이 포함된 Lists 목록을 반환하는 필터

 



1.

  • 집합을 쪼개서 여러 그룹으로 표현할 때 유용.
  • 두 번째 인수를 전달하면 마지막 반복에서 누락된 값을 채우는 데 사용됨.


3. 공식 매뉴얼

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

 

 

slice() 구문

 

jinja-filters.slice(value: 't.Collection[V]', slices: int, fill_with: 't.Optional[V]' = None) → 't.Iterator[t.List[V]]

 


[매개변수]

 

value: 't.Collection[V]'

필수. 슬라이스 필터 적용할 집합

 

slices: int

필수. 몇 개의 그룹으로 쪼갤지 지정.

 

fill_with: 't.Optional[V]' = None

선택. 마지막 빈 자리에 채울 값.

 


[반환값]

 

지정 개수의 List 반복자 반환.

 



분류 제목
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