RangeListApp is a GAS library for retrieving, putting and replacing values for Spreadsheet by a range list with a1Notation using Google Apps Script (GAS).
There is Class RangeList as one of classes for Spreadsheet. There is setValue(value)
in Class RangeList as a method. setValue(value)
puts value
to the cells of range list. Recently, when I used this method, I noticed that the following situations what I want cannot be achieved.
- Put the different values to each cell of the range list.
- Retrieve values from each cell of the range list.
- Replace values of each cell of the range list using regex.
- Use various sheets to the range list.
- Put checkbox to each cell of the range list.
Although these might be able to be used by the future update, I created this library, because I wanted to achieve them soon. If this library is also useful for you, I'm glad.
1L44xvi-AsdwbYgqeb63e2i-7PpC01Mt-1fgNO2HpTTvAHPMU1HteAIsY
- Install RangeListApp library.
- Library's project key is
1L44xvi-AsdwbYgqeb63e2i-7PpC01Mt-1fgNO2HpTTvAHPMU1HteAIsY
.
- Library's project key is
- Enable Sheets API at API console
- On script editor
- Resources -> Cloud Platform project
- View API console
- At Getting started, click Enable APIs and get credentials like keys.
- At left side, click Library.
- At Search for APIs & services, input Sheets API. And click Sheets API.
- Click Enable button.
- If it has already been enabled, please don't turn off.
Installing is done! You can use RangeListApp.
At the first run of the script using library, the authorization screen is displayed. Please authorize it. By this, you can use Sheets API. This authorization is required to do for only the first run.
Methods | Return | Descriptions |
---|---|---|
getValues() | Object | Retrieve values from each cell using range list. This works like getValues() of Class Range. |
getDisplayValues() | Object | Retrieve display values from each cell using range list. This works like getDisplayValues() of Class Range. |
getFormulas() | Object | Retrieve formulas from each cell using range list. This works like getFormulas() of Class Range. |
setValues() | Object | Put values to cells of range list. This works like setValues() of Class Range. Inputted the range list is returned. |
replaceValues() | Object | Replace values of cells of range list using regex. Inputted the range list is returned. |
replaceFormulas() | Object | Replace formulas of cells of range list using regex. Inputted the range list is returned. |
setCheckBox() | Object | Put checkbox to cells of range list. Inputted the range list is returned. |
I would like to add more methods in the future.
These methods retrieve values from each cell using range list.
As the samples, it uses the following sheets.
In this sample script, the values of "A1", "B2", "C3:D4", "sheet2!A3", "sheet2!B2:B5", "sheet2!D6:E7"
are retrieved using getValues().
- When the active sheet is "Sheet1", "A1", "B2" and "C3:D4" mean "Sheet1!A1", "Sheet1!B2" and "Sheet1!C3:D4", respectively.
- When you want to retrieve the values of other sheet, you can use "sheet2!A3", "sheet2!B2:B5" and "sheet2!D6:E7".
- getFormulas() and getDisplayValues() can also be used like getValues(). The difference is the result.
- getFormulas() retrieves the formula of each cell. This works like getFormulas() of class Range.
- getDisplayValues() retrieves the display value of each cell. This works like getDisplayValues() of class Range.
var rangeList = ["A1", "B2", "C3:D4", "sheet2!A3", "sheet2!B2:B5", "sheet2!D6:E7"];
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var r = RangeListApp.getSpreadsheet(spreadsheet).getRangeList(rangeList).getValues();
// var r = RangeListApp.getSpreadsheet(spreadsheet).getRangeList(rangeList).getFormulas();
// var r = RangeListApp.getSpreadsheet(spreadsheet).getRangeList(rangeList).getDisplayValues();
These values can be retrieved by one API call. All values are 2 dimensional array.
[
{"range":"Sheet1!A1","values":[["sheet1_A1"]]},
{"range":"Sheet1!B2","values":[["sheet1_B2"]]},
{"range":"Sheet1!C3:D4","values":[["sheet1_C3","sheet1_D3"],["sheet1_C4","sheet1_D4"]]},
{"range":"sheet2!A3","values":[["sheet2_A3"]]},
{"range":"sheet2!B2:B5","values":[["sheet2_B2"],[],[],["sheet2_B5"]]},
{"range":"sheet2!D6:E7","values":[["sheet2_D6","sheet2_E6"],["sheet2_D7"]]}
]
This method put values to each cell using range list.
var rangeList = ["A1", "B2", "C3:D4", "sheet2!A3", "sheet2!B2:B5", "sheet2!D6:E7"];
var values = ["sample1", 123, "sample2", "=sum(B2:B5)", "=ROW() * 2", true];
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var r = RangeListApp.getSpreadsheet(spreadsheet).getRangeList(rangeList).setValues(values);
- Lengths of
rangeList
andvalues
are required to be the same. For example, 2nd index ofrangeList
("B2"
) is corresponding to the 2nd index ofvalues
(123
). - When the range including several cells is set to
rangeList
like"C3:D4"
,"sample2"
is put to all cells of range. - When you want to put a formula, you can use it like
"=sum(B2:B5)"
. This library checks the top letter of each element invalues
. When it is=
, the element is put as a formula. - For example, when you want to put
=ROW() * 2
as a string, you can put it by giving==ROW() * 2
.- When
==
is used for the top letter of formula, the formula is put as a string. When it is put,==
is converted to=
.
- When
- setValues() returns rangeList.
- For above sample script, when
var values = "sample";
is used, "sample" is put to all cells of "rangeList". This works like "setValue(value)" of Class RangeList.
These methods replace values of each cell using range list by regex.
var rangeList = ["A1", "B2", "C3:D4"];
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var regex = new RegExp("[a-d]");
var value = "foo";
var r = RangeListApp.getSpreadsheet(spreadsheet).getRangeList(rangeList).replaceValues(regex, value);
- In this library, it uses String.prototype.replace() for replacing values. So you can use regexp and substr for
regex
. - In these methods,
regex
andvalue
which can be used is one value, respectively. - When
replaceFormulas()
instead ofreplaceValues()
is used, it can replace formulas in each cell.
This method puts checkbox to each cell using range list.
var rangeList = ["A1", "B2", "C3:D4"];
var values = [[], [], ["foo", "bar"]];
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var r = RangeListApp.getSpreadsheet(spreadsheet).getRangeList(rangeList).setCheckBox(values);
- Basic usage is the same with
setValues()
. - In the sample script,
["foo", "bar"]
ofvalues
meanstrue
andfalse
, respectively.
If you have any questions and commissions for me, feel free to tell me.
-
v1.0.0 (July 27, 2018)
- Initial release.