반응형
Apps Script로 Google Sheets의 데이터들을 가져올 때 getRange()를 사용한다.
a1Notation을 그냥 사용해도 되지만,
a1Notation을 입력 받고, 이를 getRange(row, column, numRows, numColumns) 으로 변경해야 할 경우가 있을 수도 있기 때문에 변환하는기능을 구현해본다.
function getSheetValues() {
const sheet = SpreadsheetApp.getActive().getSheetByName("상품리스트_지사용");
const range = convertA1NotationToRange("A2:C4");
console.log('영역변환 "A2:C4');
console.log(range);
console.log(`${range.row}, ${range.column}, ${range.numRows}, ${range.numColumns}`);
// A1Notaion으로 조회
const A1Values = sheet.getRange("A2:C4").getValues();
console.log(`sheet.getRange("A2:C4").getValues()`);
console.log(A1Values);
// 영역을 수동으로 지정하여 조회
const ManualValues = sheet.getRange(2, 1, 3, 3).getValues();
console.log(`sheet.getRange(2, 1, 3, 3).getValues();`);
console.log(ManualValues);
// A1Notaion을 영역으로 변환하여 조회
const values = sheet.getRange(range.row, range.column, range.numRows, range.numColumns).getValues();
console.log(`sheet.getRange(range.row, range.column, range.numRows, range.numColumns).getValues();`);
console.log(values);
}
/**
* ### Description
* 입력받은 A1Notaion을 getRange의 범위로 변경
* @param {String} a1NotationString.
* @return {Object} Range Info.
*/
function convertA1NotationToRange(a1NotationString) {
var sheet = SpreadsheetApp.getActiveSpreadsheet().getActiveSheet();
var range = sheet.getRange(a1NotationString);
var row = range.getRow();
var column = range.getColumn();
var numRows = range.getNumRows();
var numColumns = range.getNumColumns();
// 선택영역 반환
return {
row: row,
column: column,
numRows: numRows,
numColumns: numColumns
};
}
반응형
'GCP > Apps Script' 카테고리의 다른 글
Apps Script로 Google Sheets 셀 병합하기 (1) | 2023.08.24 |
---|---|
Apps Script로 Google Sheets에서 전화번호 양식 변환하기 (0) | 2023.08.21 |
Google Sites에서 Apps Script로 배포한 webapp 으로 파라미터 넘기기 (0) | 2023.06.15 |
Apps Script로 장 종료 후 특정 주식의 종가 정보 카카오톡으로 전송하기 (0) | 2023.06.12 |
Apps Script로 Google Forms의 Dropdown 항목을 Google Sheets에서 가져온 데이터로 생성하기 (0) | 2023.06.09 |