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

[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 반복자 반환.

 



분류 제목
filters Jinja - groupby() 필터 - 속성별로 객체 시퀀스를 그룹화. (= groupby필터 = 그룹바이…
filters Jinja - indent() 필터 - 문자열 들여쓰기. (= indent필터 = 인덴트필터)
filters Jinja - int() 필터 - 정수로 변환. (= int필터 = 인트필터) ※ 문자열숫자나 부동소수를 정…
filters Jinja - items() 필터 - 매핑의 (키, 값) 항목에 대한 반복자를 반환. (= items필터 =…
filters Jinja - join() 필터 - 시퀀스의 문자열을 연결한 문자열을 반환. (= join필터 = 조인필터)
filters Jinja - last() 필터 - 시퀀스의 마지막 아이템 반환. (= last필터 = 라스트필터) ※ 마지…
filters Jinja - length() / count() 필터 - 컨테이너 안 아이템 개수 반환. (= length필…
filters Jinja - list() 필터 - 리스트로 변환. (= list필터 = 리스트필터) ※ 리스트 자료형(=데…
filters Jinja - lower() 필터 - 소문자로 변환. (= lower필터 = 로우어필터) ※ 문자열 전체를 …
filters Jinja - map() 필터 - 각 아이템에 필터 적용하거나 속성 조회 (= map필터 = 맵필터)
filters Jinja - max() 필터 - 최대값 반환 (= max필터 = 맥스필터) ※ 최댓값
filters Jinja - min() 필터 - 최소값 반환 (= min필터 = 민필터) ※ 최솟값
filters Jinja - pprint() 필터 - 변수를 가독성 좋게 예쁘게 출력 (= pprint필터 = 피프린트필터…
filters Jinja - random() 필터 - 랜덤값 반환 (= random필터 = 랜덤필터) ※ 임의의 선택값 반…
filters Jinja - reject() 필터 - 지정 테스트 통과 못 한 요소만 필터링 해 구성된 반복자 반환 (= …
filters Jinja - rejectattr() 필터 - 지정 속성에 대한 테스트 통과 못 한 아이템만 필터링 (= r…
filters Jinja - replace() 필터 ★ - 문자열 대체 (= replace필터 = 리플레이스필터)
filters Jinja - reverse() 필터 ★ - 역순(= 순서 뒤집기) (= reverse필터 = 리버스필터)
filters Jinja - round() 필터 - 부동소수 반올림 (= round필터 = 라운드필터) ※ 일반반올림/천장…
filters Jinja - safe() 필터 ★★★ - 회피처리 안 함 (= 이스케이프 적용 X = safe필터 = 세이…
5/9
목록
찾아주셔서 감사합니다. Since 2012