function onOpen() {
SpreadsheetApp.getUi().createMenu("Extra")
.addItem("Обновить данные", "updatePoints")
.addToUi();
}
function updatePoints() {
var sh = SpreadsheetApp.getActiveSheet();
var datesColumn = sh.getRange( "A1:A" ).getValues();
var lastRow = datesColumn.filter( String ).length;
var oldDate = datesColumn[ lastRow - 1 ][ 0 ];
var oldPoints = parseFloat( sh.getRange( "B" + lastRow ).getValues() );
//обновляем валютки на сегодня
sh.getRange( 'e2' ).setValue( '=ROUND(IMPORTXML("http://www.cbr.ru/scripts/XML_daily.asp"; "//ValCurs/Valute[CharCode=""USD""]/Value");2)' );
//сохраняем текущую дату-время
var currentDate = Utilities.formatDate( new Date(), "GMT+3", "dd.MM HH:mm" );
sh.getRange( 'e1' ).setValue( currentDate );
//забираем текущие цифры
var currentPoints = parseFloat( sh.getRange( 'e2' ).getValues() );
if ( currentPoints !== oldPoints ) {
//сохраняем новые поинты и дату-время обновления
lastRow++;
sh.getRange( "B" + lastRow ).setValue( currentPoints );
sh.getRange( "A" + lastRow ).setValue( currentDate );
Logger.log( currentPoints + " <> " + oldPoints )
//MailApp.sendEmail("kiy@gmail.com", "[Alert] ["+currentDate+"] points raised to " + currentPoints, "Old points " + oldPoints
//+"\nNew points "+currentPoints+"\n\nUpdated:"+currentDate,{noReply:true});
} else {
Logger.log( currentPoints + " = " + oldPoints )
}
}