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

[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


방문 감사합니다. (즐겨찾기 등록: Ctrl + D)

분류 제목
filters Jinja - title() 필터 - 각 단어의 첫글자를 대문자로 나머지는 소문자로 변환. (= title필…
filters Jinja - tojson() 필터 - JSON 문자열로 직렬화 (= tojson필터 = 투제이슨필터)
filters Jinja - truncate() 필터 - 문자열을 지정 길이로 자르기 (= truncate필터 = 트런케이…
filters Jinja - unique() 필터 - 고유 아이템으로 구성된 반복자 반환 (= unique필터 = 유니크필…
filters Jinja - upper() 필터 - 대문자로 변환 (= upper필터 = 어퍼필터) ※ 문자열 전체를 대문…
filters Jinja - urlencode() 필터 - URL 주소나 또는 쿼리에 적합한 문자열로 변환 (= urlen…
filters Jinja - urlize() 필터 ★ - 텍스트 URL을 클릭 가능한 링크로 변환 적용 (= urlize필…
filters Jinja - wordcount() 필터 - 문자열의 단어 개수 세기 (= wordcount필터 = 워드카운…
filters Jinja - wordwrap() 필터 - 문자열을 지정 길이 단위로 쪼개기 (= wordwrap필터 = 워…
filters Jinja - xmlattr() 필터 - dict의 아이템 기반으로 SGML/XML 속성 문자열 생성 (= …
filters Jinja - trim() 필터 - 문자열 앞뒤 공백(또는, 지정문자) 제거 (= trim필터 = 트림필터)
3/3
목록
찾아주셔서 감사합니다. Since 2012