Google Sheets API를 사용하면 셀, 범위, 범위 집합, 전체 시트에서 값을 읽을 수 있습니다. 이 페이지의 예는 spreadsheets.values
리소스를 사용하는 몇 가지 일반적인 읽기 작업을 보여줍니다. spreadsheets.get
메서드를 사용하여 셀 값을 읽을 수도 있지만 일반적으로 spreadsheets.values.get
또는 spreadsheets.values.batchGet
가 더 쉽습니다.
이 예시는 언어 중립적인 HTTP 요청의 형태로 제공됩니다. Google API 클라이언트 라이브러리를 사용하여 다양한 언어로 읽기를 구현하는 방법을 알아보려면 셀 값 읽기 및 쓰기를 참고하세요.
이 예시에서 자리표시자 SPREADSHEET_ID는 스프레드시트 URL에서 찾을 수 있는 스프레드시트 ID를 입력할 위치를 나타냅니다. 읽을 범위는 요청 URL에서 A1 표기법을 사용하여 지정됩니다. 예시 범위는 Sheet1!A1:D5입니다.
소스 데이터
다음 예에서는 읽고 있는 스프레드시트의 첫 시트 ('Sheet1')에 다음과 같은 소스 데이터가 있다고 가정합니다. 첫 번째 행의 문자열은 개별 열의 레이블입니다. 스프레드시트의 다른 시트에서 읽는 방법의 예는 A1 표기법을 참고하세요.
A | B | C | D | |
1 | 항목 | 비용 | 재고 있음 | 배송 날짜 |
2 | 휠 | $20.50 | 4 | 2016년 3월 1일 |
3 | 문 | $15 | 2 | 2016년 3월 15일 |
4 | 엔진 | $100 | 1 | 2016년 3월 20일 |
5 | 총계 | $135.5 | 7 | 2016년 3월 20일 |
단일 범위 읽기
다음 spreadsheets.values.get
코드 샘플은 Sheet1!A1:D5 범위에서 값을 읽고 응답에 반환하는 방법을 보여줍니다. 비어있는 후행 열과 행은 생략됩니다.
요청 프로토콜은 다음과 같습니다.
GET https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values/Sheet1!A1:D5
응답은 범위 값을 설명하는 ValueRange
객체로 구성됩니다. majorDimension
필드는 배열이 행별로 구성된 값 목록임을 나타냅니다.
{ "range": "Sheet1!A1:D5", "majorDimension": "ROWS", "values": [ ["Item", "Cost", "Stocked", "Ship Date"], ["Wheel", "$20.50", "4", "3/1/2016"], ["Door", "$15", "2", "3/15/2016"], ["Engine", "$100", "1", "30/20/2016"], ["Totals", "$135.5", "7", "3/20/2016"] ], }
열별로 그룹화된 단일 범위 읽기
다음 spreadsheets.values.get
코드 샘플은 Sheet1!A1:D3 범위에서 값을 읽고 응답에 반환하지만 열별로 그룹화하는 방법을 보여줍니다. 비어있는 후행 열과 행은 생략됩니다.
요청 프로토콜은 다음과 같습니다.
GET https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values/Sheet1!A1:D3?majorDimension=COLUMNS
응답은 범위 값을 설명하는 ValueRange
객체로 구성됩니다. majorDimension
필드는 배열이 열로 구성된 값 목록임을 나타냅니다.
{ "range": "Sheet1!A1:D3", "majorDimension": "COLUMNS", "values": [ ["Item", "Wheel", "Door"], ["Cost", "$20.50", "$15"], ["Stocked", "4", "2"], ["Ship Date", "3/1/2016", "3/15/2016"] ], }
렌더링 옵션으로 단일 범위 읽기
다음 spreadsheets.values.get
코드 샘플은 Sheet1!A1:D5 범위에서 값을 읽고 응답에 반환하지만 렌더링 옵션을 사용하여 정보 반환 방식을 관리하는 방법을 보여줍니다. FORMULA
의 ValueRenderOption
설정은 계산된 값 대신 수식이 반환되어야 함을 나타내며, SERIAL_NUMBER
의 DateTimeRenderOption
설정은 날짜가 숫자로 반환되어야 함을 나타냅니다.
다른 설정들도 가능합니다. 비어있는 후행 열과 행은 생략됩니다.
요청 프로토콜은 다음과 같습니다.
GET https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values/Sheet1!A1:D5? valueRenderOption=FORMULA&dateTimeRenderOption=SERIAL_NUMBER
응답은 범위 값을 설명하는 ValueRange
객체로 구성됩니다. majorDimension
필드는 배열이 행별로 구성된 값 목록임을 나타냅니다.
{ "range": "Sheet1!A1:D5", "majorDimension": "ROWS", "values": [ ["Item", "Cost", "Stocked", "Ship Date"], ["Wheel", "$20.50", "4", "42430"], ["Door", "$15", "2", "42444"], ["Engine", "$100", "1", "42449"], ["Totals", "=SUM(B2:B4)", "=SUM(C2:C4)", "=MAX(D2:D4)"] ], }
여러 범위 읽기
다음 spreadsheets.values.batchGet
코드 샘플은 Sheet1!B:B 및 Sheet1!D:D 범위에서 값을 읽고 응답으로 반환하는 방법을 보여줍니다. UNFORMATTED_VALUE
의 ValueRenderOption
설정은 값이 계산되지만 응답에 서식이 지정되지 않음을 나타냅니다. 비어있는 후행 열과 행은 생략됩니다.
요청 프로토콜은 다음과 같습니다.
GET https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values:batchGet? ranges=Sheet1!B:B&ranges=Sheet1!D:D&valueRenderOption=UNFORMATTED_VALUE&majorDimension=COLUMNS
이 메서드 호출에 대한 응답은 스프레드시트 ID가 있는 객체와 요청된 각 범위에 해당하는 ValueRange
객체 배열로 구성되며, 요청된 순서대로 나열됩니다. majorDimension
필드는 배열이 열로 구성된 값 목록임을 나타냅니다. 예를 들면 다음과 같습니다.
{ "spreadsheetId": SPREADSHEET_ID, "valueRanges": [ { "range": "Sheet1!B1:B1000", "majorDimension": "COLUMNS", "values": [ ["Cost",20.5,15,100,135.5] ] }, { "range": "Sheet1!D1:D1000", "majorDimension": "COLUMNS", "values": [ ["Ship Date",42430,42444,42449,42449] ]s } ] }
여러 시트에서 여러 범위 읽기
다음 spreadsheets.values.batchGet
코드 샘플은 Sheet1!A1:D5, Products!D1:D100, Sales!E4:F6 시트의 범위에서 값을 읽고 응답에 반환하는 방법을 보여줍니다. UNFORMATTED_VALUE
의 ValueRenderOption
설정은 값이 계산되지만 응답에 서식이 지정되지 않음을 나타냅니다. 비어있는 후행 열과 행은 생략됩니다.
요청 프로토콜은 다음과 같습니다.
GET https://sheets.googleapis.com/v4/spreadsheets/SPREADSHEET_ID/values:batchGet? ranges=Sheet1!A1:D5&ranges=Products!D1:D100&ranges=Sales!E4:F6&valueRenderOption=UNFORMATTED_VALUE&majorDimension=COLUMNS
이 메서드 호출에 대한 응답은 스프레드시트 ID가 있는 객체와 요청된 각 범위에 해당하는 ValueRange
객체 배열로 구성되며, 요청된 순서대로 나열됩니다. majorDimension
필드는 배열이 열로 구성된 값 목록임을 나타냅니다. 예를 들면 다음과 같습니다.
{ "spreadsheetId": SPREADSHEET_ID, "valueRanges": [ { "range": "Sheet1!A1:D5", "majorDimension": "COLUMNS", "values": [ [...], [...] ] }, { "range": "Products!D1:D100", "majorDimension": "COLUMNS", "values": [ [...] ] }, { "range": "Sales!E4:F6", "majorDimension": "COLUMNS", "values": [ [...], [...] ] } ] }