Excel DAX-함수

대부분 DAX functionsExcel 함수와 이름과 기능이 동일합니다. 그러나 DAX 함수는 DAX 데이터 형식을 사용하고 테이블 및 열을 사용하도록 수정되었습니다.

DAX에는 Excel에서 찾을 수없는 몇 가지 추가 기능이 있습니다. 이러한 DAX 함수는 데이터 모델의 관계형 데이터베이스 측면과 관련된 관계를 기반으로 한 조회, 테이블을 반복하여 재귀 계산을 수행하고, 동적 집계를 수행하고, 시간 인텔리전스를 활용하는 계산과 같은 특정 목적을 위해 제공됩니다.

이 장에서는 DAX 언어에서 지원되는 기능에 대해 알아 봅니다. 이러한 DAX 함수 사용에 대한 자세한 내용은이 자습서 라이브러리의 자습서 – DAX 함수를 참조하십시오.

DAX 기능이란?

DAX 함수는 데이터 모델의 테이블에있는 데이터에 대해 다양한 작업을 수행 할 수 있도록 DAX 언어로 제공되는 내장 함수입니다. 앞서 논의한 바와 같이 DAX는 데이터에서 인사이트를 추출, 동화 및 도출하기위한 지원이 필요한 데이터 분석 및 비즈니스 인텔리전스 목적으로 사용됩니다. 데이터 모델을 기반으로하는 DAX 함수는 DAX 언어 및 DAX 함수 사용을 이해하면 작업을 더 간단하게 만드는 이러한 유틸리티를 제공합니다.

Excel 함수와 DAX 함수

알고있는 Excel 함수와 DAX 함수 간에는 특정 유사점이 있습니다. 그러나 특정 차이점도 있습니다. DAX 함수를 사용하고 DAX 함수를 포함하는 DAX 수식을 작성할 때 실수를 방지 할 수 있도록 이에 대한 명확성을 확보해야합니다.

Excel 함수와 DAX 함수의 유사점

  • 많은 DAX 함수는 Excel 함수와 동일한 이름과 일반적인 동작을 갖습니다.

  • DAX에는 Excel의 배열 및 벡터 조회 함수와 유사한 조회 함수가 있습니다.

Excel 함수와 DAX 함수의 차이점

  • DAX 함수는 다른 유형의 입력을 받도록 수정되었으며 일부 DAX 함수는 다른 데이터 유형을 반환 할 수 있습니다. 따라서 이름이 같더라도 이러한 함수의 사용법을 개별적으로 이해해야합니다. 이 자습서에서는 Excel 함수와의 혼동을 피하기 위해 DAX 접두사가 붙은 모든 DAX 함수를 찾을 수 있습니다.

  • 필요한 수정없이 Excel 수식에서 DAX 함수를 사용하거나 DAX에서 Excel 수식 / 함수를 사용할 수 없습니다.

  • Excel 함수는 셀 참조 또는 셀 범위를 참조로 사용합니다. DAX 함수는 셀 참조 또는 셀 범위를 참조로 사용하지 않고 대신 열 또는 테이블을 참조로 사용합니다.

  • Excel 날짜 및 시간 함수는 날짜를 일련 번호로 나타내는 정수를 반환합니다. DAX 날짜 및 시간 함수는 DAX에는 있지만 Excel에는없는 datetime 데이터 형식을 반환합니다.

  • Excel에는 표를 반환하는 함수가 없지만 일부 함수는 배열과 함께 작동 할 수 있습니다. 많은 DAX 함수는 전체 테이블과 열을 쉽게 참조하여 계산을 수행하고 테이블 또는 값 열을 반환 할 수 있습니다. 이 DAX 기능은 DAX가 사용되는 Power Pivot, Power View 및 Power BI에 힘을 추가합니다.

  • DAX 조회 기능을 사용하려면 테이블간에 관계가 설정되어야합니다.

  • Excel은 데이터 열에서 변형 데이터 유형을 지원합니다. 즉, 열에 서로 다른 데이터 유형의 데이터를 가질 수 있습니다. 반면 DAX는 테이블 열의 데이터가 항상 동일한 데이터 유형일 것으로 예상합니다. 데이터가 동일한 데이터 형식이 아닌 경우 DAX는 전체 열을 열의 모든 값을 가장 잘 수용하는 데이터 형식으로 변경합니다. 그러나 데이터를 가져 와서이 문제가 발생하면 DAX에서 오류를 표시 할 수 있습니다.

DAX 데이터 유형 및 데이터 유형 캐스팅에 대한 자세한 내용은 DAX 구문 참조 장을 참조하십시오.

DAX 함수 유형

DAX는 다음 유형의 기능을 지원합니다.

  • DAX 테이블 값 함수
    • DAX 필터 기능
    • DAX 집계 함수
    • DAX 시간 인텔리전스 함수
  • DAX 날짜 및 시간 함수
  • DAX 정보 기능
  • DAX 논리 함수
  • DAX 수학 및 삼각 함수
  • DAX 기타 기능
  • DAX 부모 및 자식 함수
  • DAX 통계 함수
  • DAX 텍스트 함수

이 섹션에서는 함수 범주 수준에서 DAX 함수에 대해 알아 봅니다. DAX 함수 구문 및 DAX 함수가 반환하고 수행하는 작업에 대한 자세한 내용은이 자습서 라이브러리의 DAX 함수 자습서를 참조하십시오.

DAX 시간 인텔리전스 기능과 DAX 필터 기능은 강력하며 특별한 언급이 필요합니다. 자세한 내용은 DAX 시간 인텔리전스 및 DAX 필터 기능 이해 장을 참조하십시오.

DAX 테이블 값 함수

많은 DAX 함수는 테이블을 입력 또는 출력 테이블로 사용하거나 둘 다 수행합니다. 이러한 DAX 함수를 DAX 테이블 값 함수라고합니다. 테이블에 단일 열이있을 수 있으므로 DAX 테이블 값 함수도 단일 열을 입력으로 사용합니다. 다음과 같은 유형의 DAX 테이블 값 함수가 있습니다.

  • DAX 집계 함수
  • DAX 필터 기능
  • DAX 시간 인텔리전스 기능

DAX 테이블 값 함수를 이해하면 DAX 수식을 효과적으로 작성하는 데 도움이됩니다.

DAX 집계 함수

DAX 집계 함수는 테이블 행에 대한 모든 식을 집계하며 계산에 유용합니다.

다음은 일부 DAX 집계 함수입니다.

  • ADDCOLUMNS (<테이블>, <이름>, <식>, [<이름>, <식>]…)

  • AVERAGE (<열>)

  • AVERAGEA (<열>)

  • AVERAGEX (<테이블>, <표현식>)

  • COUNT (<열>)

  • COUNTA (<열>)

  • COUNTAX (<테이블>, <표현식>)

  • COUNTBLANK (<열>)

  • COUNTROWS (<테이블>)

  • COUNTX (<테이블>, <표현식>)

  • CROSSJOIN (<table1>, <table2>, [<table3>]…)

  • DISTINCTCOUNT (<열>)

  • GENERATE (<table1>, <table2>)

  • GENERATEALL (<table1>, <table2>)

  • MAX (<열>)

  • MAXA (<열>)

  • MAXX (<테이블>, <표현식>)

  • MIN (<열>)

  • MINA (<열>)

  • MINX (<테이블>, <식>)

  • PRODUCT (<열>)

  • PRODUCTX (<테이블>, <표현식>)

  • ROW (<이름>, <식>, [<이름>, <식>]…)

  • SELECTCOLUMNS (<테이블>, <이름>, <스칼라 _ 식>,

  • [<이름>, <스칼라 _ 식>]…)

  • SUM (<열>)

  • SUMMARIZE (<테이블>, <groupBy_columnName>, [<groupBy_columnName>]…, [<name>, <expression>]…)

  • SUMX (<테이블>, <표현식>)

  • TOPN (<n_value>, <table>, <orderBy_expression>, [<order>], [<orderBy_expression>, [<order>]]…)

DAX 필터 기능

DAX 필터 함수는 현재 행과 관련된 열, 테이블 또는 값을 반환합니다. DAX 필터 함수를 사용하여 특정 데이터 유형을 반환하고, 관련 테이블에서 값을 조회하고, 관련 값을 기준으로 필터링 할 수 있습니다. DAX 조회 함수는 테이블과 테이블 간의 관계를 사용하여 작동합니다. DAX 필터 함수를 사용하면 데이터 컨텍스트를 조작하여 동적 계산을 생성 할 수 있습니다.

다음은 일부 DAX 필터 기능입니다.

  • ADDMISSINGITEMS (<showAllColumn>, [<showAllColumn>]…, <table>, <groupingColumn>, [<groupingColumn>]… [filterTable]…)

  • ALL ({<table> | <column>, [<column>], [<column>]…})

  • ALLEXCEPT (<테이블>, <열>, [<열>]…)

  • ALLNOBLANKROW(<table>|<column>)

  • ALLSELECTED ([<테이블 이름> | <열 이름>])

  • CALCULATE (<식>, <필터 1>, <필터 2>…)

  • CALCULATETABLE (<식>, <필터 1>, <필터 2>…)

  • CROSSFILTER (<columnName1>, <columnName2>, <direction>)

  • DISTINCT (<열>)

  • EARLIER (<열>, <숫자>)

  • EARLIEST(<column>)

  • FILTER(<table>,<filter>)

  • FILTERS(<columnName>)

  • HASONEFILTER(<columnName>)

  • HASONEVALUE(<columnName>)

  • ISCROSSFILTERED (<columnName>)

  • ISFILTERED (<columnName>)

  • KEEPFILTERS (<표현식>)

  • RELATED(<column>)

  • RELATEDTABLE(<tableName>)

  • SUBSTITUTEWITHINDEX (<table>, <indexColumnName>, <indexColumnsTable>, <orderBy_expression>, [<order>], [<orderBy_expression>, [<order>]]…])

  • USERELATIONSHIP(<columnName1>,<columnName2>)

  • VALUES(<TableNameOrColumnName>)

DAX 시간 인텔리전스 함수

DAX Time Intelligence 함수는 날짜 표를 반환하거나 날짜 표를 사용하여 집계를 계산합니다. 이러한 DAX 함수를 사용하면 일, 월, 분기 및 연도를 포함한 기간을 사용하여 데이터를 조작 할 수 있으므로 비즈니스 인텔리전스 분석의 요구 사항을 지원하는 계산을 만들 수 있습니다.

다음은 일부 DAX 시간 인텔리전스 기능입니다.

  • CLOSINGBALANCEMONTH (<표현식>, <날짜> [, <필터>])

  • CLOSINGBALANCEQUARTER (<표현식>, <날짜>, [<필터>])

  • CLOSINGBALANCEYEAR (<표현식>, <날짜>, [<필터>], [<연말 _ 날짜>])

  • DATEADD (<날짜>, <간격 _ 횟수>, <간격>)

  • DATESBETWEEN (<날짜>, <시작일>, <종료일>)

  • DATESINPERIOD (<날짜>, <시작일>, <간격 _ 횟수>, <간격>)

  • DATESMTD (<날짜>)

  • DATESQTD (<날짜>)

  • DATESYTD (<날짜>, [<연말 _ 날짜>])

  • ENDOFMONTH (<날짜>)

  • ENDOFQUARTER (<날짜>)

  • ENDOFYEAR (<dates>, [<year_end_date>])

  • FIRSTDATE (<날짜>)

  • FIRSTNONBLANK (<열>, <식>)

  • LASTDATE (<날짜>)

  • LASTNONBLANK (<열>, <식>)

  • NEXTDAY (<날짜>)

  • NEXTMONTH (<날짜>)

  • NEXTQUARTER (<날짜>)

  • NEXTYEAR (<dates>, [<year_end_date>])

  • OPENINGBALANCEMONTH (<표현식>, <날짜>, [<필터>])

  • OPENINGBALANCEQUARTER (<표현식>, <날짜>, [<필터>])

  • OPENINGBALANCEYEAR (<expression>, <dates>, [<filter>], [<year_end_date>])

  • PARALLELPERIOD (<날짜>, <간격 _ 횟수>, <간격>)

  • PREVIOUSDAY(<dates>)

  • PREVIOUSMONTH(<dates>)

  • PREVIOUSQUARTER(<dates>)

  • PREVIOUSYEAR (<dates>, [<year_end_date>])

  • SAMEPERIODLASTYEAR(<dates>)

  • STARTOFMONTH(<dates>)

  • STARTOFQUARTER(<dates>)

  • STARTOFYEAR(<dates>)

  • TOTALMTD (<식>, <날짜>, [<필터>])

  • TOTALQTD (<표현식>, <날짜>, [<필터>])

  • TOTALYTD (<expression>, <dates>, [<filter>], [<year_end_date>])

DAX 날짜 및 시간 함수

DAX 날짜 및 시간 함수는 Excel 날짜 및 시간 함수와 유사합니다. 그러나 DAX 날짜 및 시간 함수는 DAX의 datetime 데이터 유형을 기반으로합니다.

다음은 DAX 날짜 및 시간 기능입니다-

  • DATE (<연도>, <월>, <일>)
  • DATEVALUE(date_text)
  • DAY(<date>)
  • EDATE (<시작일>, <월>)
  • EOMONTH (<시작일>, <월>)
  • HOUR(<datetime>)
  • MINUTE(<datetime>)
  • MONTH(<datetime>)
  • NOW()
  • SECOND(<time>)
  • TIME (시, 분, 초)
  • TIMEVALUE(time_text)
  • TODAY()
  • WEEKDAY (<날짜>, <반품 _ 유형>)
  • WEEKNUM (<날짜>, <반품 _ 유형>)
  • YEAR(<date>)
  • YEARFRAC (<시작일>, <종료일>, <기준>)

DAX 정보 기능

DAX 정보 함수는 인수로 제공된 셀 또는 행을보고 값이 예상 유형과 일치하는지 여부를 알려줍니다.

다음은 일부 DAX 정보 기능입니다.

  • CONTAINS (<table>, <columnName>, <value>, [<columnName>, <value>]…)

  • CUSTOMDATA()

  • ISBLANK(<value>)

  • ISERROR(<value>)

  • ISEVEN(number)

  • ISLOGICAL(<value>)

  • ISNONTEXT(<value>)

  • ISNUMBER(<value>)

  • ISONORAFTER (<스칼라 _ 식>, <스칼라 _ 식>, [정렬 _ 순서], [<스칼라 _ 식>, <스칼라 _ 식>, [정렬 _ 순서]]…)

  • ISTEXT(<value>)

  • LOOKUPVALUE (<result_columnName>, <search_columnName>, <search_value>, [<search_columnName>, <search_value>]…)

  • USERNAME()

DAX 논리 함수

DAX 논리 함수는 식의 값에 대한 정보를 반환합니다. 예를 들어 DAX TRUE 함수를 사용하면 평가중인식이 TRUE 값을 반환하는지 여부를 알 수 있습니다.

다음은 DAX 논리 함수입니다-

  • AND(<logical1>,<logical2>)
  • FALSE()
  • IF (논리 _ 테스트>, <값 _if_true>, 값 _if_false)
  • IFERROR (값, value_if_error)
  • NOT(<logical>)
  • OR(<logical1>,<logical2>)
  • SWITCH (<표현식>, <값>, <결과>, [<값>, <결과>]…, [<else>])
  • TRUE()

DAX 수학 및 삼각 함수

DAX 수학 및 삼각 함수는 Excel 수학 및 삼각 함수와 매우 유사합니다.

다음은 일부 DAX 수학 및 삼각 함수입니다.

  • ABS(<number>)
  • ACOS(number)
  • ACOSH(number)
  • ASIN(number)
  • ASINH(number)
  • ATAN(number)
  • ATANH(number)
  • CEILING (<숫자>, <유의>)
  • COMBIN (숫자, 숫자 _ 선택)
  • COMBINA (숫자, 숫자 _ 선택)
  • COS(number)
  • COSH(number)
  • CURRENCY(<value>)
  • DEGREES(angle)
  • DIVIDE (<분자>, <분모>, [<대체 결과>])
  • EVEN(number)
  • EXP(<number>)
  • FACT(<number>)
  • FLOOR (<숫자>, <유의>)
  • GCD (숫자 1, [숫자 2], ...)
  • INT(<number>)
  • ISO.CEILING (<숫자>, [<유의>])
  • LCM (숫자 1, [숫자 2], ...)
  • LN(<number>)
  • LOG(<number>,<base>)
  • LOG10(<number>)
  • INT(<number>)
  • MROUND (<숫자>, <다중>)
  • ODD(number)
  • PI()
  • POWER (<숫자>, <힘>)
  • PRODUCT(<column>)
  • PRODUCTX (<테이블>, <표현식>)
  • QUOTIENT (<분자>, <분모>)
  • RADIANS(angle)
  • RAND()
  • RANDBETWEEN(<bottom>,<top>)
  • ROUND (<숫자>, <숫자>)
  • ROUNDDOWN (<숫자>, <숫자>)
  • ROUNDUP (<숫자>, <숫자>)
  • SIN(number)
  • SINH(number)
  • SIGN(<number>)
  • SQRT(<number>)
  • SUM(<column>)
  • SUMX (<테이블>, <표현식>)
  • TAN(number)
  • TANH(number)
  • TRUNC(<number>,<num_digits>)

DAX 기타 기능

이러한 DAX 함수는 대부분의 다른 함수가 속한 범주로 정의 할 수없는 고유 한 작업을 수행합니다.

다음은 일부 DAX 기타 기능입니다-

  • EXCEPT (<표식 1>, <표식 2>

  • GROUPBY (<테이블>, [<groupBy_columnName1>], [<이름>, <식>]…)

  • INTERSECT (<테이블 _ 표현식 1>, <표 _ 표현식 2>)

  • ISEMPTY(<table_expression>)

  • NATURALINNERJOIN (<leftJoinTable>, <rightJoinTable>)

  • NATURALLEFTOUTERJOIN (<leftJoinTable>, <rightJoinTable>)

  • SUMMARIZECOLUMNS (<groupBy_columnName>, [<groupBy_columnName>]…, [<filterTable>]…, [<name>, <expression>]…)

  • UNION (<테이블 _ 식 1>, <테이블 _ 식 2>, [<테이블 _ 식>]…)

  • VAR <이름> = <표현식>

DAX 부모 및 자식 함수

DAX 부모 및 자식 함수는 데이터 모델에서 부모 / 자식 계층으로 표시되는 데이터를 관리하는 데 유용합니다.

다음은 일부 DAX 부모 및 자식 함수입니다.

  • PATH (<ID_ 열 이름>, <상위 _ 열 이름>)
  • PATHCONTAINS (<경로>, <항목>)
  • PATHITEM (<경로>, <위치>, [<유형>])
  • PATHITEMREVERSE (<경로>, <위치>, [<유형>])
  • PATHLENGTH(<path>)

DAX 통계 함수

DAX 통계 함수는 Excel 통계 함수와 매우 유사합니다.

다음은 일부 DAX 통계 기능입니다.

  • BETA.DIST (x, 알파, 베타, 누적, [A], [B])

  • BETA.INV (확률, 알파, 베타, [A], [B])

  • CHISQ.INV (확률, 자유도)

  • CHISQ.INV.RT (확률, 자유도)

  • CONFIDENCE.NORM (알파, 표준 _ 개발, 크기)

  • CONFIDENCE.T (알파, 표준 _ 개발, 크기)

  • DATATABLE (ColumnName1, DataType1, ColumnName2, DataType2 ..., {{Value1, Value2 ...}, {ValueN, ValueN + 1 ...} ...})

  • EXPON.DIST (x, 람다, 누적)

  • GEOMEAN(<column>)

  • GEOMEANX (<테이블>, <표현식>)

  • MEDIAN(<column>)

  • MEDIANX (<테이블>, <표현식>)

  • PERCENTILE.EXC (<열>, <k>)

  • PERCENTILE.INC (<열>, <k>)

  • PERCENTILEX.EXC (<테이블>, <식>, k)

  • PERCENTILEX.EXC (<테이블>, <식>, k)

  • POISSON.DIST (x, 평균, 누적)

  • RANK.EQ (<값>, <열 이름> [, <순서>])

  • RANKX (<테이블>, <표현식> [, <값> [, <순서> [, <관계>]]])

  • SAMPLE (<n_value>, <table>, <orderBy_expression>, [<order>], [<orderBy_expression>, [<order>]]…)

  • STDEV.P(<ColumnName>)

  • STDEV.S(<ColumnName>)

  • STDEVX.P (<테이블>, <표현식>)

  • STDEVX.S (<테이블>, <표현식>)

  • SQRTPI(number)

  • VAR.P(<columnName>)

  • VAR.S(<columnName>)

  • VARX.P (<테이블>, <표현식>)

  • VARX.S (<테이블>, <표현식>)

  • XIRR (<테이블>, <값>, <날짜>, [추측])

  • XNPV (<테이블>, <값>, <날짜>, <요율>)

DAX 텍스트 함수

DAX 텍스트 함수는 테이블 및 열에서 작동합니다. DAX 텍스트 함수를 사용하면 문자열의 일부를 반환하거나 문자열 내에서 텍스트를 검색하거나 문자열 값을 연결할 수 있습니다. 날짜, 시간 및 숫자의 형식을 제어 할 수도 있습니다.

다음은 일부 DAX 텍스트 기능입니다.

  • BLANK()
  • CODE(text)
  • CONCATENATE (<텍스트 1>, <텍스트 2>)
  • CONCATENATEX (<테이블>, <표현식>, [구분자])
  • EXACT(<text1>,<text2>)
  • FIND (<find_text>, <within_text>, [<start_num>], [<NotFoundValue>])
  • FIXED (<숫자>, <소수>, <쉼표 없음>)
  • FORMAT (<값>, <형식 _ 문자열>)
  • LEFT (<텍스트>, <문자 _ 수>)
  • LEN(<text>)
  • LOWER(<text>)
  • MID (<텍스트>, <시작 _ 번호>, <문자 _ 숫자>)
  • REPLACE (<이전 _ 텍스트>, <시작 _ 번호>, <문자 _ 숫자>, <새 _ 텍스트>)
  • REPT (<텍스트>, <횟수>)
  • RIGHT (<텍스트>, <문자 _ 숫자>)
  • SEARCH (<find_text>, <within_text>, [<start_num>], [<NotFoundValue>])
  • SUBSTITUTE (<텍스트>, <이전 _ 텍스트>, <새 _ 텍스트>, <인스턴스 _ 번호>)
  • TRIM(<text>)
  • UPPER (<텍스트>)
  • VALUE(<text>)