我尝试在谷歌电子表格上运行一个脚本来固定一堆重复的动作。
根据{{3}},我可以使用四个数字参数getRange
重载来访问一系列数据。
我的问题是,当我运行脚本谷歌说我 getRange(数字,数字,数字,数字)找不到并停止脚本。
以下是代码:
function addMonth(){
var month = ["Janvier","Février","Mars","Avril","Mai","Juin",
"Juillet","Août","Septembre","Octobre","Novembre","Décembre"];
var days = ["po","wr","sr","cz","pl","so","nd"];
var dateString = Browser.inputBox('Enter the month with format "mm-yyyy"');
var date = new Date(dateString.split("-")[1],dateString.split("-")[0]-1,1);
var dateFin = new Date(dateString.split("-")[1],dateString.split("-")[0]-1,0);
var sheet = SpreadsheetApp.getActiveSpreadsheet();
var pos =sheet.getLastColumn();
sheet.insertColumnsAfter(pos,dateFin.getDate());
var monthRange = sheet.getRange(1,parseInt(pos+1),1,parseInt(dateFin.getDate()));
monthRange.merge();
monthRange.setValue(month[dateDebut.getMonth()]);
var daysOfMonth = [];
for(var i=1;i<=dateFin.getDate();i++){
daysOfMonth.push(days[date.getDay()+(i%7)-1]);
}
sheet.getRange(2,parseInt(pos+1),1,parseInt(dateFin.getDate())).setValues(daysOfMonth);
}
答案 0 :(得分:1)
错误信息说的是实话。您的变量sheet
属于Class Spreadsheet,没有方法getRange(row, column, numRows, numColumns)
- 这是Class Sheet的方法。
更改变量sheet
的分配以确保它是正确的类型:
var sheet = SpreadsheetApp.getActiveSheet();
在编写脚本时,请注意自动完成功能,这有助于避免此错误。有关详细信息,请参阅this previous answer。