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

[filters] Jinja - sum() 필터 - (합계/합산/총합/총계) 구하기 (= sum필터 = 섬필터)

목차
  1. sum() 예제
  2. sum() 정의
  3. sum() 구문

 

sum() 예제 - 합계 구하기

[예제1] - 숫자 합산

 

{% set nums = [10, 20, 30] %}

{{ nums|sum }} {# 60 #}



[예제2] - 특정 속성 합산

 

{% set items = [

    {'name': '수박', 'price': 10},

    {'name': '참외', 'price': 20},

    {'name': '딸기', 'price': 30}

] %}


{{ items|sum(attribute='price') }} {# 60 #}

 


[예제3] - 초기값 주어진 경우 합산

 

{% set nums = [1, 2, 3] %}

{{ nums|sum(start=10) }} {# 16 #}

 


[예제4] - 초기값만 있는 경우 합산

 

{{ nums|sum(start=10) }} {# 10 #}

 

 

sum() 정의

 

「일련의 숫자와 매개변수 'start' 값(기본값: 0)의 합계를 반환. 시퀀스가 비어 있으면 start를 반환.」하는 필터.

 


 

1. 특정 속성만 합산하는 것도 가능. (예: price 속성만 합산.)

합계: {{ items|sum(attribute='price') }}

 

2.

Jinja2 2.6 - ① attribute 매개변수 추가해 속성별 합산 가능. ② strat 매개변수가 오른쪽으로 이동됨.

 

3. 공식 매뉴얼

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

 

 

sum() 구문

 

jinja-filters.sum(iterable: 't.Iterable[V]', attribute: str | int | NoneType = None, start: V = 0) → V

 


[매개변수]

iterable: 't.Iterable[V]'
반복 가능한 타입의 값에 대해 적용.

 

attribute: str | int | NoneType = None

합산할 속성 지정.

 

start: V = 0

합산할 때 기본적으로 더할 초기값.

 


[반환값]

 

  • 반복가능값 있으면, 반복가능값의 합계와 start 값의 합산을 반환.
  • 반복가능값 없으면, start 값 반환.

 


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

분류 제목
intro Jinja - 소개 - 설치
api Jinja - API - 기초
api Jinja - API - 고급 API
api Jinja - API - 자동 이스케이프
api Jinja - API - 식별자에 관한 참고 사항
api Jinja - API - 정의되지 않은 유형
api Jinja - API - 문맥
api Jinja - API - 로더
api Jinja - API - 바이트코드 캐시
api Jinja - API - 비동기 지원
api Jinja - API - 정책
api Jinja - API - 유용
api Jinja - API - 예외
api Jinja - API - 맞춤 필터
api Jinja - API - 맞춤형 테스트
api Jinja - API - 평가 컨텍스트
api Jinja - API - 글로벌 네임스페이스
api Jinja - API - 저수준 API
api Jinja - API - 메타 API
1/9
목록
찾아주셔서 감사합니다. Since 2012