Functions
Function은 ProtoPie에서 설정해 둔 Formula로, 데이터를 입력하면 결과값을 추출하도록 설계되어 있습니다. 다음은 Function이 하는 역할에 대한 예시입니다.
- 텍스트의 글자 수를 계산합니다.
- 텍스트에 있는 특정 단어를 추출합니다.
- 여러 숫자 가운데 가장 작은 값을 추출합니다.
Function은 다음과 같은 구조를 갖습니다.
function(argument: TYPE)
→ 결과 값: TYPEfunction(argument1: TYPE, argument2: TYPE)
→ 결과 값: TYPEfunction(argument1: TYPE, argument2: TYPE, argument3: TYPE)
→ 결과 값: TYPE
Function에는 한 개 혹은 여러 개의 데이터를 입력해야 합니다. 이 때 데이터는 텍스트, 숫자, 색상 등 특정 유형을 사용해야 합니다.
Function의 종류는 다음과 같이 구분할 수 있습니다.
Text
concat(source1: TEXT, source2: TEXT)
TEXT두 개의 다른 텍스트를 하나로 결합시킵니다.
Example:concat("hello", "world")"helloworld"
indexOf(source: TEXT, searchValue: TEXT)
NUMBER텍스트에서 특정 단어가 시작되는 위치를 찾습니다. 해당 단어가 텍스트 내 존재하지 않을 경우. 값은 -1로 추출됩니다.
Example:indexOf("hello world", "world")6
Example:indexOf("hello world", "hello")0
Example:indexOf("hello world", "goodbye")-1
- 예를 들어, 이메일 인증 프로토타입을 만들 때 indexOf를 사용할 수 있습니다. 다음 링크에서 예제를 확인하십시오.
length(source: TEXT)
NUMBER텍스트의 글자 수를 계산합니다.
Example:length("hello")5
Example:length("helloworld")10
Example:length("hello world")11
- 예를 들어, 비밀번호 인증 프로토타입을 만들 때 length를 사용할 수 있습니다. 다음 링크에서 예제를 확인하십시오.
lowerCase(source: TEXT)
TEXT텍스트를 소문자로 변경합니다.
Example:lowerCase("Hello")"hello"
upperCase(source: TEXT)
TEXT텍스트를 대문자로 변경합니다.
Example:upperCase("Hello")"HELLO"
left(source: TEXT, count: NUMBER)
TEXT텍스트 좌측에서 원하는 개수 만큼 글자를 추출합니다.
Example:left("hello", 3)"hel"
right(source: TEXT, count: NUMBER)
TEXT텍스트 우측에서 원하는 개수 만큼 글자를 추출합니다.
Example:right("hello", 2)"lo"
lpad(source: TEXT, length: NUMBER, pad: TEXT)
TEXT원하는 길이가 되도록 텍스트 좌측에 입력한 글자를 추가합니다.
Example:lpad("5", 2, "0")"05"
Example:lpad("5", 4, "0")"0005"
rpad(source: TEXT, length: NUMBER, pad: TEXT)
TEXT원하는 길이가 되도록 텍스트 우측에 입력한 글자를 추가합니다.
Example:rpad("5", 2, "1")"51"
Example:rpad("5", 6, "1")"511111"
repeat(source: TEXT, count: NUMBER)
TEXT텍스트를 입력한 숫자 만큼 반복합니다.
Example:repeat("hello", 2)"hellohello"
Example:repeat("hello", 3)"hellohellohello"
replace(source: TEXT, from: TEXT, to: TEXT)
TEXT텍스트의 특정 부분을 다른 글자로 변경합니다.
Example:replace("helloworld", "world", "protopie")"helloprotopie"
Example:replace("goodbye, John", "goodbye", "thank you")"thank you, John"
trim(source: TEXT)
TEXT텍스트 양쪽에 있는 여백을 삭제합니다.
Example:trim(" helloworld ")"helloworld"
Example:trim(" helloworld ")"helloworld"
ltrim(source: TEXT)
TEXT텍스트 좌측에 있는 여백을 삭제합니다.
Example:ltrim(" helloworld ")"helloworld "
rtrim(source: TEXT)
TEXT텍스트 우측에 있는 여백을 삭제합니다.
Example:rtrim(" helloworld ")" helloworld"
regexextract(source: TEXT, regular expression: TEXT)
TEXT제공된 정규 표현식과 일치하는 텍스트의 초기 서브스트링을 추출합니다.
Example:regexextract("Google Doc 101", "[0-9]+")"101"
Example:regexextract("The price today is $826.25", "[0-9]*\.[0-9]+[0-9]+")"826.25"
regexreplace(source: TEXT, regular expression: TEXT, replacement: TEXT)
TEXT정규 표현식을 사용하여 텍스트 스트링의 일부를 다른 텍스트로 교체합니다.
Example:regexreplace("Google Doc 101", "[0-9]+", "777")"Google Doc 777"
Example:regexreplace("The price today is $826.25", "[0-9]*\.[0-9]+[0-9]+", "315.75")"The price is $315.75"
parseJson(source: TEXT, key: TEXT)
TEXT유효한 JSON 스트링을 분석한 다음 해당 값을 반환합니다.
Example:parseJson("{\"name\":\"John\", \"age\":30, \"car\":null}", "age")"30"
Example:parseJson("{\"name\":\"John\", \"age\":30, \"car\":null}", "name")"John"
- ProtoPie Connect 내 Bridge 앱(예: 메시지: “AutomobileSignal”, 값: “json string”)을 통해 Pie로 JSON 스트링을 전송할 수 있습니다.
- Receive 트리거를 통해 Pie 변수 내 값을 저장할 수 있습니다.
- JSON 스트링 내에서 데이터 값을 활용할 수 있습니다.
parseJson(var, "key")를 예시로 살펴보겠습니다. 여기서 var는 JSON 스트링을 저장하는 텍스트 변수이며, "key"는 분석할 키에 해당합니다. 키는 중첩된 키 호출 및 유사 배열 객체와 같은 단순 레퍼런스를 지원하며, 이 경우 . (점) 표기를 사용합니다.
parseJson 함수를 통해 ProtoPie 내 복잡한 데이터 구조 작업을 크게 단순화할 수 있습니다. 또한 대부분의 API 응답은 JSON 형식으로 이루어지므로 Pies 내에서 parseJson을 활용할 수 있게 된다면 API를 훨씬 간단하게 작업할 수 있습니다.
parseJson 함수를 통해 다음과 같은 작업이 가능합니다.
이 Pie 예시를 통해 자세히 살펴보실 수 있습니다.
Math
pow(source: NUMBER, exponent: NUMBER)
NUMBER첫번째 숫자를 두번째 숫자 만큼 거듭제곱합니다.
Example:pow(2, 3)8
sqrt(source: NUMBER)
NUMBER입력된 숫자의 제곱근을 추출합니다. 입력한 숫자가 음수이면 계산되지 않습니다.
Example:sqrt(9)3
Example:sqrt(2)1.41
min(source1: NUMBER, source2: NUMBER)
NUMBER입력한 숫자 중 최소값을 추출합니다.
Example:min(0, 1)0
max(source1: NUMBER, source2: NUMBER)
NUMBER입력한 숫자 중 최대값을 추출합니다.
Example:max(0, 1)1
abs(value: NUMBER)
NUMBER입력된 숫자의 절대값을 추출합니다. 사실상 음수의 마이너스 기호를 삭제하기 위해 사용됩니다.
Example:abs(-1)1
Example:abs(5 - 25)20
sign(value: NUMBER)
NUMBER입력된 숫자가 양수인지 음수인지 판별합니다. 양수는 1, 음수는 -1로 값이 추출됩니다. 0을 입력하면 결과값도 0이 됩니다.
Example:sign(5)1
Example:sign(-10)-1
Example:sign(0)0
round(source: NUMBER)
NUMBER입력된 숫자를 반올림합니다.
Example:round(3.49)3
Example:round(1.5)2
Example:round(6.79)7
floor(source: NUMBER)
NUMBER입력된 숫자를 내림합니다.
Example:floor(1.5)1
Example:floor(2.99)2
ceil(source: NUMBER)
NUMBER입력된 숫자를 올림합니다.
Example:ceil(1.5)2
Example:ceil(4.3)5
random()
NUMBER0과 1 사이의 소수를 무작위로 추출합니다.
Example:random()0과 1 사이의 소수를 무작위로 추출
random(min: NUMBER, max: NUMBER)
NUMBER입력한 두 숫자 사이의 소수를 무작위로 추출합니다.
Example:random(1, 5)1과 5 사이의 소수를 무작위로 추출
randomInt(min: NUMBER, max: NUMBER)
NUMBER입력한 두 숫자 사이의 정수를 무작위로 추출
Example:randomInt(1, 5)1과 5 사이의 정수를 무작위로 추출
radians(degrees: NUMBER)
NUMBER각도 값을 라디안으로 추출합니다.
Example:radians(180)3.14 = π
Example:radians(90)1.57 = π / 2
degrees(radians: NUMBER)
NUMBER라디안을 각도 값으로 추출합니다.
Example:degrees($pi)180
Example:degrees($pi / 2)90
sin(radian: NUMBER)
NUMBER라디안의 사인 값을 추출합니다.
Example:sin($pi / 2)1
Example:sin($pi / 6)0.5
cos(radian: NUMBER)
NUMBER라디안의 코사인 값을 추출합니다.
Example:cos(0)1
Example:cos($pi / 2)0
tan(radian: NUMBER)
NUMBER라디안의 탄젠트 값을 추출합니다.
Example:tan($pi / 4)1
Example:tan(0)0
asin(x: NUMBER)
NUMBER라디안에서 x의 아크사인 값을 추출합니다.
Example:asin(1)1.57 = π / 2
Example:asin(0.5)0.52 = π / 6
acos(x: NUMBER)
NUMBER라디안에서 x의 아크코사인 값을 추출합니다.
Example:acos(1)0
Example:acos(0)1.57 = π / 2
atan(x: NUMBER)
NUMBER라디안에서 x의 아크탄젠트 값을 추출합니다.
Example:atan(1)0.79 = π / 4
Example:atan(0)0
atan2(y: NUMBER, x: NUMBER)
NUMBER라디안에서 x와 y의 아크탄젠트 값을 추출합니다.
Example:atan2(1, 0)1.57 = π / 2
Example:atan2(1, 1)0.79 = π / 4
Color
color(red: NUMBER, green: NUMBER, blue: NUMBER)
COLORRGB 값을 기본으로 하는 색상 코드를 추출합니다.
Example:color(255, 255, 255)#FFFFFF
Example:color(255, 102, 97)#FF6661
red(source: COLOR)
NUMBER색상 코드의 적색 RGB 파라미터를 추출합니다.
Example:red(#FF0000)255
Example:red(#008000)0
Example:red(#0000FF)0
green(source: COLOR)
NUMBER색상 코드의 녹색 RGB 파라미터를 추출합니다.
Example:green(#FF0000)0
Example:green(#008000)128
Example:green(#0000FF)0
blue(source: COLOR)
NUMBER색상 코드의 청색 RGB 파라미터를 추출합니다.
Example:blue(#FF0000)0
Example:blue(#008000)0
Example:blue(#0000FF)255
Type Conversion
number(source: TEXT)
NUMBER텍스트를 숫자로 변경합니다. 텍스트가 숫자로 이루어져야 사용할 수 있습니다.
Example:number("1234")1234
Example:number("94.27")94.27
text(source: NUMBER)
TEXT숫자를 텍스트로 변경합니다.
Example:text(1234)"1234"
Example:text(94.27)"94.27"
Example:text(1 + 3)"4"
format(source: NUMBER, format: TEXT)
TEXT숫자를 원하는 형식의 텍스트로 변경합니다. #으로 정수 자리를, 0으로 소수점 자리를 표시할 수 있습니다.
Example:format(1234.567, "#")"1235"
Example:format(1234.567, "#,###")"1,235"
Example:format(1234.567, "#.###,00")"1.234,57"
Example:format(1234.567, "#,##.00")"12,34.57"
Example:format(1234.567, "#,###.00")"1,234.57"
color(source: TEXT)
COLOR텍스트를 색상 코드로 변경합니다. 텍스트가 색상 코드에 맞는 구조로 이루어져야 사용할 수 있습니다.
Example:color("#FFFFFF")#FFFFFF
Layers
layer(source: TEXT)
LAYER특정 레이어를 참조할 수 있습니다.
- 다른 Function 및 모든 Formula에 활용 가능합니다.
layer(source: TEXT).property
TEXT or NUMBER레이어의 속성을 활용할 수 있습니다. 레이어 속성에 대한 자세한 사항은 다음 링크를 참고하십시오.
Example:layer("Rectangle 1").xRectangle 1 레이어의 X좌표
Example:layer("Oval 1").opacityOval 1 레이어의 투명도
Example:layer("Input 1").textInput 1 레이어의 텍스트
parent(layerName: LAYER)
LAYER부모 레이어(컨테이너, 컴포넌트 등)를 참조할 수 있습니다.
- 다른 Function 및 모든 Formula에 활용 가능합니다.
parent(layerName: LAYER).property
TEXT or NUMBER부모 레이어의 속성을 활용할 수 있습니다. 레이어 속성에 대한 자세한 사항은 다음 링크를 참고하십시오.
Example:parent(`Rectangle 1`).xRectangle 1 부모 레이어의 X좌표
Example:parent(`Oval 1`).opacityOval 1 부모 레이어의 투명도
initial(layerName: LAYER, layerProperty: TEXT)
TEXT or NUMBER특정 레이어 속성의 인터랙션 적용 전 초기 설정값을 추출합니다. 레이어 속성에 대한 자세한 사항은 다음 링크를 참고하십시오.
Example:initial(`Rectangle 1`, "x")Rectangle 1 레이어의 X좌표 초기 설정값
Example:initial(`Oval 1`, "opacity")Oval 1 레이어의 투명도 초기 설정값
Example:initial(`Input 1`, "text")Input 1 레이어의 텍스트 초기 설정값
Relative Coordinates
toLayerX(containerName: LAYER, x: NUMBER, y: NUMBER)
NUMBER컨테이너 혹은 컴포넌트에 대한 X 상대 좌표를 추출합니다. 컨테이너나 컴포넌트에 속한 레이어의 경우, 이에 대한 상대 좌표값을 갖습니다.
- 예를 들어, 화면 상 (100,200)의 위치를 기준으로 컨테이너 내 X 상대 좌표를 추출하려면 다음 수식을 사용할 수 있습니다.
toLayerX(`Container 1`, 100, 200)화면 상 X=100을 기준으로 한 Container 1에 대한 X 상대 좌표
toLayerY(containerName: LAYER, x: NUMBER, y: NUMBER)
NUMBER컨테이너 혹은 컴포넌트에 대한 Y좌표를 추출합니다. 컨테이너나 컴포넌트에 속한 레이어의 경우, 이에 대한 상대 좌표값을 갖습니다.
- 예를 들어, 화면 상 (100,200)의 위치를 기준으로 컨테이너 내 Y 상대 좌표를 추출하려면 다음 수식을 사용할 수 있습니다.
toLayerY(`Container 1`, 100, 200)화면 상 Y=200을 기준으로 한 Container 1에 대한 Y 상대 좌표
toScreenX(containerName: LAYER, x: NUMBER, y: NUMBER)
NUMBER화면에 대한 X 상대 좌표를 추출합니다. 컨테이너나 컴포넌트에 속한 레이어의 경우, 이에 대한 상대 좌표값을 갖습니다.
- 예를 들어, 컨테이너 혹은 컴포넌트 상 (10,20)의 위치를 기준으로 화면 내 X 상대 좌표를 추출하려면 다음 수식을 사용할 수 있습니다.
toScreenX(`Container 1`, 10, 20)Container 1 상 X=10를 기준으로 한 화면에 대한 X 상대 좌표
toScreenY(containerName: LAYER, x: NUMBER, y: NUMBER)
NUMBER화면에 대한 Y 상대 좌표를 추출합니다. 컨테이너나 컴포넌트에 속한 레이어의 경우, 이에 대한 상대 좌표값을 갖습니다.
- 예를 들어, 컨테이너 혹은 컴포넌트 상 (10,20)의 위치를 기준으로 화면 내 Y 상대 좌표를 추출하려면 다음 수식을 사용할 수 있습니다.
toScreenY(`Container 1`, 10, 20)Container 1 상 Y=20을 기준으로 한 화면에 대한 Y 상대 좌표
timeNow()
TEXTExample:timeNow()
time(hour: NUMBER, min: NUMBER, sec: NUMBER)
TEXTExample:time(14, 50, 23)
hour()
NUMBERExample:hour("17:44:30")
minute()
NUMBERExample:minute("17:44:30")
second()
NUMBERExample:second("17:44:30")
diffTime()
NUMBERExample:diffTime("17:45:30", "18:45:30", "H")
Example:diffTime("17:45:30", "18:45:30", "M")
Example:diffTime("17:45:30", "18:45:30", "S")
formatTime()
TEXTExample:formatTime("11:44:30", "HHa")
Example:formatTime("11:44:30", "HHam mm")
Example:formatTime("11:44:30", "hh:mm a")
dateNow()
TEXTExample:dateNow()
date(year: NUMBER, month: NUMBER, day: NUMBER)
TEXTExample:date(2014, 12, 8)
year()
NUMBERExample:year("2014-12-8")
month()
NUMBERExample:month("2014-12-8")
day()
NUMBERExample:day("2014-12-8")
diffDate()
NUMBERExample:diffDate("1973-02-24", "1969-05-16", "Y")
Example:diffDate("1973-02-24", "1969-05-16", "M")
Example:diffDate("1973-02-24", "1969-05-16", "D")
Example:diffDate("1969-05-16", "1973-02-24", "Y")
Example:diffDate("1969-05-16", "1973-02-24", "M")
Example:diffDate("1969-05-16", "1973-02-24", "D")
Example:diffDate("1969-05-16", "1973-02-24", "MD")
Example:diffDate("2023-01-01", "2023-02-10", "MD")
Example:diffDate("1969-05-16", "1973-02-24", "YM")
Example:diffDate("1969-05-16", "1973-02-24", "YD")
Example:diffDate("2023-01-01", "2023-02-10", "YD")
formatDate()
TEXTExample:formatDate("2023-06-01", "DD/MM/YYYY")
Example:formatDate("2023-06-01", "YYYY MMMM dddd")
Example:formatDate("2023-06-01", "MMM DD, YY")
epochtodate(timestamp: NUMBER)
TEXTExample:epochtodate(0)
Example:epochtodate(-1)
Example:epochtodate(1)
Example:epochtodate(1655908429662)
epochtodate(timestamp: NUMBER, format: TEXT)
TEXTExample:epochtodate(1695316200000)
Example:epochtodate(1695316200000, "hh:mm")
ProtoPie 내 함수 활용에 대해 자세히 알고 싶으신가요?ProtoPie 마스터클래스에 등록하여 해당 문서 내에 설명된 여러 가지 특정 함수 기능을 활용하는 법에 대한 세부적인 예시와 가이드를 확인할 수 있습니다.