다음을 통해 공유


JSON 함수

적용 대상: Canvas 앱 모델 기반 앱 Power Pages

테이블, 레코드 또는 값에 대한 JSON 텍스트 문자열을 생성합니다.

설명

JSON 함수는 데이터 구조의 JSON(JavaScript Object Notation) 표현을 텍스트로 반환하여 네트워크에 저장하거나 전송하는 데 적합합니다. [ECMA-404](https://www.ecma-international.org/publications/files/ECMA-ST/ECMA-404.pdfIETF RFC 8259는 JavaScript 및 기타 프로그래밍 언어에서 광범위하게 쓰이는 형식을 설명합니다.

캔버스 앱은 데이터 유형을 지원하며 이 표에 텍스트 표현에 대한 세부 사항이 나열되어 있습니다.

데이터 형식 설명 결과 예
부울 또는 거짓. true
색상 색상에 대한 8자리 16진수 표현이 포함된 문자열입니다. 이 표현은 #rrggbbaa 형식이며, rr이 빨간색 구성 요소이고 gg는 초록색, bb 파란색, aa 알파 채널입니다. 알파 채널의 경우 00은 완전히 투명하고 ff는 완전히 불투명합니다. 문자열을 ColorValue 함수에 전달할 수 있습니다. "#102030ff"
통화 사용자 언어에 적절한 소수점 구분 기호를 사용하는 숫자입니다. 필요한 경우 과학적 표기법이 사용됩니다. 1.345
날짜 ISO 8601 yyyy-mm-dd 형식의 날짜를 포함하는 문자열입니다. "2019-03-31"
날짜시간 ISO 8601 날짜/시간을 포함하는 문자열입니다. 마지막 "Z"에 나오듯 날짜/시간 값은 UTC입니다. "2019-03-31T22:32:06.822Z"
가이드 GUID 값을 포함하는 문자열입니다. 문자는 소문자입니다. "751b58ac-380e-4a04-a925-9f375995cc40"
이미지, 미디어 JSONFormat.IncludeBinaryData가 지정되었다면 미디어 파일은 문자열로 인코딩됩니다. Http: 또는 https: URL 체계를 사용하는 웹 참조는 수정되지 않습니다. 메모리 내 이진 데이터에 대한 참조는 "data:mimetype;base64,..." 형식입니다. 인 메모리 데이터에는 사용자가 Camera 컨트롤과 ppres: 및 blob: URL의 다른 기타 참조를 사용하여 사용자가 캡처하는 이미지를 포함합니다. "..."
숫자 사용자 언어에 적절한 소수점 구분 기호를 사용하는 숫자입니다. 필요한 경우 과학적 표기법이 사용됩니다. 1.345
옵션 집합 표시에 사용되는 레이블이 아닌 선택 항목의 숫자 값입니다. 언어에 종속되지 않음으로 숫자 값이 사용됩니다. 1001
시간 ISO 8601 hh:mm:ss.fff 형식을 포함하는 문자열. "23:12:49.000"
기록 { and } 및 필드와 값 사이의 쉼표로 구분된 목록. 이 표기법은 캔버스 앱의 레코드와 유사하지만 이름은 항상 큰 따옴표로 묶습니다. 이 형식은 다 대 일 관계를 기반으로 하는 레코드를 지원하지 않습니다. { "First Name": "Fred", "Age": 21 }
테이블 [ and ] 및 레코드 사이의 쉼표로 구분된 목록. 이 형식은 일 대 다 관계를 기반으로 하는 테이블을 지원하지 않습니다. JSONFormat.FlattenValueTables 옵션을 사용하여 Value라는 열이 있는 단일 열 테이블의 레코드를 제거합니다. [ { "First Name": "Fred", "Age": 21 }, { "First Name": "Jean", "Age": 20 } ]
두 가지 옵션 두 옵션의 부울 값 true 또는 false는 표시에 사용되는 레이블이 아닙니다. 언어에 종속되지 않음으로 부울 값이 사용됩니다. false
하이퍼링크, 텍스트 큰 따옴표 사이의 문자열입니다. 이 함수는 포함된 큰 따옴표를 백 슬래시로 이스케이프하고 새행을 "\n" 및 기타 표준 JavaScript로 대체합니다. "This is a string."

선택 사항으로 형식 인수를 지정하여 결과의 가독성과 지원되지 않는 이진 데이터 유형을 취급하는지 결정합니다. 기본적으로 출력은 불필요한 공백이나 줄 바꿈없이 최대한 간결하게 하며 지원되지 않는 데이터 형식과 이진 데이터는 허용되지 않습니다. & 연산자를 지정하면 여러 형식을 혼합할 수 있습니다.

JSONFormat 열거형 Description
JSON포맷.컴팩트 기본값. 공백이나 줄 바꿈을 추가하지 않고도 출력이 최대한 간결합니다.
JSONFormat.FlattenValueTables Value 테이블로 표기하면 [1,2,3] 표기법이 각 레코드에 단일 Value 열이 있는 레코드가 포함된 테이블이 됩니다. JSON에서는 동일한 표기법이 세 개의 숫자 배열을 나타냅니다. 둘 사이의 상호 운용성을 더 쉽게 만들기 위해 이 옵션은 Power Fx 값 테이블을 레코드 배열 대신 JSON 친화적인 배열로 평면화합니다.
JSONFormat.IndentFour 가독성을 높이기 위해 출력에는 각 열과 중첩 수준에 대한 줄 바꿈이 포함되며 각 들여 쓰기 수준에 대해 4개의 공백이 사용됩니다.
JSONFormat.IncludeBinaryData 결과에는 이미지, 비디오 및 오디오 클립 열이 포함됩니다. 이 형식은 결과 크기를 크게 늘리고 앱 성능을 저하시킬 수 있습니다.
JSONFormat.IgnoreBinaryData 결과에는 이미지, 비디오 및 오디오 클립 열이 포함되지 않습니다. JSONFormat.IncludeBinaryDataJSONFormat.IgnoreBinaryData 둘다 지정하지 않으면 이진 데이터가 있을 때 함수에서 오류가 발생합니다.
JSONFormat.IgnoreUnsupportedTypes 지원되지 않는 데이터 유형은 허용되지만 결과에는 포함되지 않습니다. 기본적으로 지원되지 않는 데이터 유형은 오류를 생성합니다.

ShowColumnsDropColumns 함수를 사용해 결과에 포함되는 데이터나 지원되지 않는 데이터 유형을 삭제할지를 결정합니다.

JSON은 메모리와 컴퓨팅 집약적이기 때문에 동작 함수에서만 이 함수를 사용할 수 있습니다. JSON에서 데이터 흐름에서 사용할 수 있는 변수로 결과를 캡처할 수 있습니다.

열에 표시 이름와 논리 이름이 모두 있으면 결과에 논리 이름이 포함됩니다. 표시 이름은 앱 사용자의 언어를 반영하므로 공통 서비스로 데이터를 전송하는 데 적합하지 않습니다.

구문

JSON( 데이터 구조 [, 형식 ] )

  • DataStructure – 필수. JSON으로 변환할 데이터 구조입니다. 테이블, 레코드 및 기본 값이 임의로 중첩되어 지원됩니다.
  • 형식 - 선택 사항. JSONFormat 열거형 값. 기본값은 줄 바꿈이나 공백을 추가하지 않고 이진 데이터와 지원되지 않는 열을 차단하는 JSONFormat.Compact입니다.

예제

계층적 데이터

  1. Button 컨트롤을 삽입하고 OnSelect 속성을 다음 수식으로 설정합니다.

    ClearCollect( CityPopulations,
        { City: "London",    Country: "United Kingdom", Population: 8615000 },
        { City: "Berlin",    Country: "Germany",        Population: 3562000 },
        { City: "Madrid",    Country: "Spain",          Population: 3165000 },
        { City: "Hamburg",   Country: "Germany",        Population: 1760000 },
        { City: "Barcelona", Country: "Spain",          Population: 1602000 },
        { City: "Munich",    Country: "Germany",        Population: 1494000 }
    );
    ClearCollect( CitiesByCountry, GroupBy( CityPopulations, "Country", "Cities" ) )
    
  2. Alt 키를 누른 상태에서 단추를 선택합니다.

    CitiesByCountry 컬렉션은 이 데이터 구조로 생성되며 파일 메뉴의 컬렉션을 선택하고 컬섹션 이름을 선택하여 표시할 수 있습니다.

    CitiesByCountry 컬렉션.

    설정>예정된 기능>수식 입력줄 결과 보기 사용을 선택하고 수식 입력줄에서 컬렉션 이름을 선택한 다음 수식 입력줄 아래 컬렉션 이름 옆에 있는 아래쪽 화살표를 선택하여 이 컬렉션을 표시할 수도 있습니다.

    수식 입력줄의 결과 보기에 있는 컬렉션.

  3. 다른 단추를 삽입하고, OnSelect 속성을 이 수식으로 설정합니다.

    Set( CitiesByCountryJSON, JSON( CitiesByCountry ) )
    

    이 수식은 전역 변수 CitiesByCountryJSONCitiesByCountry에 대한 JSON 표현으로 설정합니다.

  4. Alt 키를 누른 상태에서 단추를 선택합니다.

  5. Label 컨트롤을 삽입하고, Text 속성을 다음 변수로 설정합니다.

    CitiesByCountryJSON
    

    레이블은 공백없이 단일 줄에 이 결과를 표시하며 네트워크를 통한 전송에 적합합니다.

    [
      {
        "Cities": [{ "City": "London", "Population": 8615000 }],
        "Country": "United Kingdom"
      },
      {
        "Cities": [
          { "City": "Berlin", "Population": 3562000 },
          { "City": "Hamburg", "Population": 1760000 },
          { "City": "Munich", "Population": 1494000 }
        ],
        "Country": "Germany"
      },
      {
        "Cities": [
          { "City": "Madrid", "Population": 3165000 },
          { "City": "Barcelona", "Population": 1602000 }
        ],
        "Country": "Spain"
      }
    ]
    
  6. 두 번째 단추의 수식을 변경하여 출력을 보다 읽기 쉽게 만듭니다.

    Set( CitiesByCountryJSON, JSON(CitiesByCountry, JSONFormat.IndentFour ))
    
  7. Alt 키를 누른 상태에서 두 번째 단추를 선택합니다.

    레이블은 더 읽기 쉬운 결과를 보여줍니다.

    [
      {
        "Cities": [
          {
            "City": "London",
            "Population": 8615000
          }
        ],
        "Country": "United Kingdom"
      },
      {
        "Cities": [
          {
            "City": "Berlin",
            "Population": 3562000
          },
          {
            "City": "Hamburg",
            "Population": 1760000
          },
          {
            "City": "Munich",
            "Population": 1494000
          }
        ],
        "Country": "Germany"
      },
      {
        "Cities": [
          {
            "City": "Madrid",
            "Population": 3165000
          },
          {
            "City": "Barcelona",
            "Population": 1602000
          }
        ],
        "Country": "Spain"
      }
    ]
    

base64의 이미지 및 미디어

  1. Image를 추가합니다.

    이 컨트롤은 SampleImage를 가져옵니다.

  2. Button 컨트롤을 추가하고 OnSelect 속성을 다음 수식으로 설정합니다.

    Set( ImageJSON, JSON( SampleImage, JSONFormat.IncludeBinaryData ) )
    
  3. Alt 키를 누른 상태에서 단추를 선택합니다.

  4. 레이블을 추가하고 Text 속성을 다음 변수로 설정합니다.

    ImageJSON
    
  5. 대부분의 결과를 표시하려면 컨트롤의 크기를 조정하고 글꼴 크기를 줄입니다.

    레이블은 JSON 함수가 캡처한 문자열을 보여줍니다.

    ""
    

Value 테이블

이 수식:

JSON( [1,2,3] )

텍스트 문자열 [{"Value":1},{"Value":2},{"Value":3}]을 생산합니다.

JSONFormat.FlattenValueTables 옵션을 사용한 동일한 수식:

JSON( [1,2,3], JSONFormat.FlattenValueTables )

텍스트 문자열 [1,2,3]을 생산합니다.

FlatableValueTables 옵션은 값 테이블이 아니므로 CityPopulations 또는 CitiesByCountry 집합과 함께 JSON을 사용할 때 영향을 미치지 않습니다. 값 테이블에는 단일 열이 있으며 이름은 "Value"로 지정되어야 합니다.