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

[filters] Jinja - groupby() 필터 - 속성별로 객체 시퀀스를 그룹화. (= groupby필터 = 그룹바이필터)

목차
  1. groupby() 예제 - 속성별로 그룹화
  2. groupby() 정의
  3. groupby() 구문
  4. groupby() 예제 - 그룹별로 List 자료형 문자열로 출력
  5. groupby() 예제 - 그룹화 할 속성 없을 시 기본값 추가

 

groupby() 예제 - 속성별로 그룹화

[예제1] - type별로 그룹화

 

{% set items = [

    { "name": "모모", "type": "green"},

    { "name": "사나", "type": "blue" }, 

    { "name": "다현", "type": "blue" },

    { "name": "쯔위", "type": "green"}

] %}


{% for type, items in items | groupby('type') %}

{{ type }}:

{% for item in items %}{{ item.name }} {% endfor %}

{% endfor %}

 

결과값: blue: 사나 다현 green: 모모 쯔위


[예제2] - 도시별로 그룹화해서 멤버 출력

 

{% set users = [

    {'name': '서울1', 'city': '서울'},

    {'name': '대전1', 'city': '대전'},

    {'name': '광주1', 'city': '광주'},

    {'name': '서울2', 'city': '서울'},

    {'name': '광주2', 'city': '광주'}

] %}


<ul>{% for city, items in users|groupby("city") %}

  <li>{{ city }}

    <ul>{% for user in items %}

      <li>{{ user.name }}

    {% endfor %}</ul>

  </li>

{% endfor %}</ul>

 

결과값:

광주

  광주1

  광주2

대전

  대전1

서울

  서울1

  서울2

 

groupby() 정의

 

Python의 itertools.groupby() 사용해 속성별로 객체 시퀀스를 그룹화하는 필터.

 


 

1.

  • 속성은 "address.city"와 같이 중첩된 액세스에 점(.) 표기법을 사용 가능. 
  • Python의 groupby와 달리, 값이 먼저 정렬되므로 각 고유 값에 대해 하나의 그룹만 반환됨.

 

2.

  • sort() 필터와 마찬가지로, 정렬 및 그룹화는 기본적으로 대소문자 구분 X
  • 각 그룹의 키는 해당 값 그룹의 첫 번째 항목의 대/소문자 갖음. (예) 사용자 목록에 도시 ["CA", "NY", "ca"]가 있는 경우 "CA" 그룹에는 2개 값이 존재. (※ case_sensitive=True 전달해 대소문자 구분으로 변경 가능.)

 

3.

  • Jinja2 3.1 - case_sensitive 매개변수 추가. (※ 정렬 및 그룹화는 기본적으로 대소문자를 구분하지 않으며 비교를 수행하는 다른 필터와 일치함. )
  • Jinja2 3.0 - default 매개변수 추가. 
  • Jinja2 2.6 - 속성은 중첩 액세스에 대한 점 표기법을 지원.

 

 

groupby() 구문

 

jinja-filters.groupby(value: 't.Iterable[V]', attribute: str | int, default: Any | None = None, case_sensitive: bool = False) → 't.List[_GroupTuple]'

 

 

groupby() 예제 - 그룹별로 List 자료형 문자열로 출력

  • groupby는 위 예처럼 풀어헤쳐진 튜플 대신 사용 가능한 (grouper, list) 튜플을 생성함. (※ grouper는 속성 값이고 list는 해당 값을 가진 아이템임.)


{% set users = [

    {'name': '서울1', 'city': '서울'},

    {'name': '대전1', 'city': '대전'},

    {'name': '광주1', 'city': '광주'},

    {'name': '서울2', 'city': '서울'},

    {'name': '광주2', 'city': '광주'}

] %}


<ul>{% for group in users|groupby("city") %}

  <li>{{ group.grouper }}: {{ group.list|join(", ") }}</li>

{% endfor %}</ul>

 

결과값

광주: {'name': '광주1', 'city': '광주'}, {'name': '광주2', 'city': '광주'}

대전: {'name': '대전1', 'city': '대전'}

서울: {'name': '서울1', 'city': '서울'}, {'name': '서울2', 'city': '서울'}

 

groupby() 예제 - 그룹화 할 속성 없을 시 기본값 추가

 

{% set users = [

    {'name': '미상1'},

    {'name': '서울1', 'city': '서울'},

    {'name': '대전1', 'city': '대전'},

    {'name': '광주1', 'city': '광주'},

    {'name': '서울2', 'city': '서울'},

    {'name': '광주2', 'city': '광주'},

    {'name': '미상2'}

] %}


<ul>{% for city, items in users|groupby("city", default="지구") %}

  <li>{{ city }} - {{ items|map(attribute="name")|join(", ") }}</li>

{% endfor %}</ul>

 

결과값:

광주 - 광주1, 광주2

대전 - 대전1

서울 - 서울1, 서울2

지구 - 미상1, 미상2



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