x = R*cos(phi) + x0
y = R*sin(phi) + y0
phi = (0,1,2...N-1)*(2*pi/N)
=СУММ(SPLIT(A1;"+"))
/**
* Копирует значения и форматирование из fromRange в toRange
*
* @param {"A1:B10"} fromRange Исходный массив
* @param {"D1:E10"} toRange Конечный массив
* @return 0 если выполнилось без ошибок, или описание ошибки
* @customfunction
*/
function copyRange(fromRange, toRange){
var ss = SpreadsheetApp.getActiveSpreadsheet();
try{
var source = ss.getRange(fromRange);
var dest = ss.getRange(toRange);
dest.setValues(source.getValues());
dest.setBackgrounds(source.getBackgrounds());
// и т.д. Есть много чего из форматирования, получается по get... ставится по set...
return 0;//Завершение без ошибок
}catch(err){
Logger.log(Utilities.formatString((arguments.callee.toString().match(/function ([^(]*)\(/)[1]) + "(%s) - %s", Array.from(arguments).join(", "), err.message)); //Ошибку в лог
return err.message;//Завершение с ошибкой
};
};
function syncRanges(){
copyRange("b7:b11", "c7:c11"); // b7:b11 >> c7:c11
copyRange("f1:f20", "g1:g20"); // f1:f20 >> g1:g20
//и т.п. можно вызывать несколько раз для разных диапазонов
};
var ss = SpreadsheetApp.getActiveSpreadsheet(); //Текущая таблица
var ss = SpreadsheetApp.openById(id); //открытие сторонней таблицы по id
//или
var ss = SpreadsheetApp.openByUrl(url);//открытие сторонней таблицы по url
=arrayFormula(
еслиошибка(
если(a:a<>""; a:a+b:b; "")
)
)
function onEdit(event) {
//Возникает при изменении ячейки
var ss = event.source.getActiveSheet();//Текущий лист
var address = event.range.getA1Notation().toUpperCase();//Адрес ячейки
var row = event.range.getRow(); //Номер строки
var col = event.range.getColumn(); //Номер столбца
var newValue = event.value; //Новое значение
var oldValue = event.oldValue; //Старое значение
if (["Лист1","Лист2"].indexOf(ss.getName())==-1) return; //Указываем на каких листах должен работать скрипт
//Что-то делаем...
};
/**
* Аналог функции split. Разбивает по наличию жирности у текста
* [ ProgrammerForever (c) 2020 ]
* @param {"A1"} rangeName Имя ячейки
* @return Возвращает массив строк с чередующейся жирностью
* @customfunction
*/
function splitByBold(rangeName) {
if (!rangeName) {
throw "Параметр rangeName не задан. Должен быть адресом ячейки"
};
var rtv = SpreadsheetApp.getActiveSheet().getRange(rangeName).getRichTextValue();
if (rtv) {
rtv=rtv.getRuns()
}else{
return SpreadsheetApp.getActiveRange().getValue();
};
var outData = [rtv[0].getText()];
var isBold = rtv[0].getTextStyle().isBold();
var k=0;
for (var i = 1; i < rtv.length; i++){
if (rtv[i].getTextStyle().isBold() === isBold){
outData[k]+= rtv[i].getText();
}else{
k+=1;
outData[k]= rtv[i].getText();
isBold = rtv[i].getTextStyle().isBold();
};
};
return outData;
}
A:A
B:B
ArrayFormula(ЕСЛИ(B:B="Заключен";A:A;""))
=ТРАНСП(ArrayFormula(ЕСЛИ(B:B="Заключен";A:A;"")))
function onEdit(event) {
//Возникает при изменении ячейки
var ss = event.source.getActiveSheet();//Текущий лист
var address = event.range.getA1Notation().toUpperCase();//Адрес ячейки
var row = event.range.getRow(); //Номер строки
var col = event.range.getColumn(); //Номер столбца
var newValue = event.value; //Новое значение
var oldValue = event.oldValue; //Старое значение
if (["Лист1","Лист2"].indexOf(ss.getName())==-1) return; //Указываем на каких листах должен работать скрипт
//Можно при желании ещё фильтровать по строке/столбцу (row/col), или по старому/новому значению (oldValue/newValue)
var archive = SpreadsheetApp.getActiveSpreadsheet().getSheetByName("Архив");
archive.getRange(archive.getLastRow()+1, 1).setValue(
formatDateTime(new Date())+" " + "[" + ss.getName() + "!" + address + "] '" + (oldValue==undefined?"":oldValue) + "' >> '" + (newValue==undefined?"":newValue) +"'"
);
};
function formatDateTime(date) {
var dd = date.getDate();
if (dd < 10) dd = '0' + dd;
var mm = date.getMonth() + 1;
if (mm < 10) mm = '0' + mm;
var yy = date.getFullYear() % 100;
if (yy < 10) yy = '0' + yy;
var hh = date.getHours();
if (hh < 10) hh = '0' + hh;
var MM = date.getMinutes();
if (MM < 10) MM = '0' + MM;
var ss = date.getSeconds();
if (ss < 10) ss = '0' + ss;
return dd + '.' + mm + '.' + yy + ' ' + hh + ':'+ MM + ':'+ ss;
}
.getRange(2, 1, FromData.length, FromData[0].length)
={1;2;3}