Таблица Получение категорий
function getKat() {
var sheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Вход');
var outSheet = SpreadsheetApp.getActiveSpreadsheet().getSheetByName('Выход');
var range = sheet.getDataRange();
var values = range.getValues();
values.shift(1);
var kat = values.map(e => e.pop());
var links = curry((j, o, e) => {
var temp = kat[j]
o[e] = o.hasOwnProperty(e) ? [...new Set([...o[e], temp])] : [temp]
return o
})
var z = {}
values.forEach((r, j) => {
//console.log(r)
r.filter(q => q).forEach((cell) => {
var katLinks = links(j);
z = katLinks(z, cell)
})
})
const flatArrAddKey = Object.keys(z).map(e => [e, ...z[e]])
outSheet.getRange(1,1,w.length,w[0].length).setValues(normaliseArr(w))
}Следующая статья цикла:
"Банк знаний по ботам и не только... "
🛠🤖
В этой статье....
1.Telegram
Полезные боты для разработки ,
Группы и каналы
Примеры
Telegram Bot и Google Form
Telegram и GMail-боты
Обычное подменю клавиатуры в Telegram Bot
Как ограничить доступ к Telegram-ботам
Получить идентификатор чата и название группы Telegram
Яндекс.Алиса и бот Telegram на PHP с единым функционалом
Создаём Telegram-бота с нуля на Python
13. TinyURL
"Сокращатель" ссылок
15.Яндекс-Алиса
Простая и пошаговая интеграция Яндекс-Алисы и 1С
...to be continued
Пишите в комментариях найденное Вами... Добавим ‼️
"Банк знаний по ботам и не только... "
🛠🤖
В этой статье....
1.Telegram
Полезные боты для разработки ,
Группы и каналы
Примеры
Telegram Bot и Google Form
Telegram и GMail-боты
Обычное подменю клавиатуры в Telegram Bot
Как ограничить доступ к Telegram-ботам
Получить идентификатор чата и название группы Telegram
Яндекс.Алиса и бот Telegram на PHP с единым функционалом
Создаём Telegram-бота с нуля на Python
13. TinyURL
"Сокращатель" ссылок
15.Яндекс-Алиса
Простая и пошаговая интеграция Яндекс-Алисы и 1С
...to be continued
Пишите в комментариях найденное Вами... Добавим ‼️
Telegraph
Банк знаний по ботам и не только... 2
Company @Google Таблицы and @VolondApps presents...
Volond Apps pinned «Следующая статья цикла: "Банк знаний по ботам и не только... " 🛠🤖 В этой статье.... 1.Telegram Полезные боты для разработки , Группы и каналы Примеры Telegram Bot и Google Form Telegram и GMail-боты Обычное подменю клавиатуры в Telegram Bot Как ограничить…»
Forwarded from Рестарт
Miro - это платформа интерактивных досок
для совместной работы
Бесконечно масштабируемый холст и веб-доска Miro позволяют вам работать так, как вы хотите. Дайте волю своему творчеству, планируйте проекты со всех сторон и создавайте централизованные центры информации, чтобы держать всех в курсе. Вы сможете увидеть общую картину и детали.
Будьте креативным. Будьте продуктивны. Откуда угодно.
В бесплатном тарифе только пять досок и отсутствие приятных плюшек вроде видеочата, секундомера и т.д.
GIT
для совместной работы
Бесконечно масштабируемый холст и веб-доска Miro позволяют вам работать так, как вы хотите. Дайте волю своему творчеству, планируйте проекты со всех сторон и создавайте централизованные центры информации, чтобы держать всех в курсе. Вы сможете увидеть общую картину и детали.
Будьте креативным. Будьте продуктивны. Откуда угодно.
В бесплатном тарифе только пять досок и отсутствие приятных плюшек вроде видеочата, секундомера и т.д.
GIT
Класс для управления Properties
#snippet #GAS
#snippet #GAS
/**
* Класс для управления Properties
* DocumentProperties or ScriptProperties or UserProperties
*
* Creates an instance of Props.
* @param {string} prop
* @memberof Props
* @constructor
* https://developers.google.com/apps-script/reference/properties
* @example
* const testProps=()=>{
* const scrProp=new Props("ScriptProperties");
* scrProp.set("v","1")
* concole.log(scrProp.get("v"))
* }
* @return {} Class Properties
*/
class Props {
constructor(prop) {
this[prop] = PropertiesService['get' + prop]();
this.type = prop
return this;
}
get(name) {
return this[this.type].getProperty(name);
}
getProperties(name) {
return this[this.type].getProperties();
}
type(prop) {
return this.type;
}
set(name, value) {
return this[this.type].setProperty(name, value);
}
forget(name) {
return this[this.type].deleteProperty(name);
}
forgets(names)Таймер в Боте на скриптах
function finalCountdown() {
var token = '<token>';;
var chatID = 'chatID';
var url = 'https://api.telegram.org/bot' + token +
'/sendMessage?chat_id=' + chatID + '&text=It\'s the final countdown!';
var response = UrlFetchApp.fetch(url);
response = JSON.parse(response.getContentText());
var msgID = response.result.message_id;
Utilities.sleep(1000);
var baseUrl = 'https://api.telegram.org/bot' + token +
'/editMessageText?chat_id=' + chatID + '&message_id=' + msgID + '&text=';
var w = { '0': "0️⃣", '1': "1️⃣", '2': "2️⃣", '3': "3️⃣", '4': "4️⃣", '5': "5️⃣", '6': "6️⃣", '7': "7️⃣", '8': "8️⃣", '9': "9️⃣", ":": "▪️" }
var url;
for (var i = 0; i < 15; ++i) {
var date = new Date();
var timestamp = date.getTime();
var timezone = Session.getScriptTimeZone()
var times = Utilities.formatDate(date, timezone, "HH:mm:ss");
url = baseUrl + [...times.toString()].map(e => w[e]).join();
UrlFetchApp.fetch(url);
Utilities.sleep(1000);
}
url = baseUrl + '💣Boom!';
UrlFetchApp.fetch(url);
}RegEx не так сложны, как вам кажется.
Перевод статьи «Regular Expressions Demystified: RegEx isn’t as hard as it looks».
Сборка
Перевод статьи «Regular Expressions Demystified: RegEx isn’t as hard as it looks».
Сборка
freeCodeCamp.org
Regular Expressions Demystified: RegEx isn’t as hard as it looks
By Vijayabharathi Balasubramanian Are you one of those people who stays away from regular expressions because it looks like a foreign language? I was one. Not anymore. Think of all those sounds, traffic signs and smells that you can recognize. Regula...
Forwarded from volond
Используя функцию из этого поста
https://t.me/google_sheets/530
И добавив бонус
https://t.me/google_sheets/530
И добавив бонус
/** Декартово произведение двух диапазонов
* https://t.me/google_sheets – наш канал про Таблицы Google и скрипты :)
* @param Первый диапазон
* @param Второй диапазон
* @return
* @customfunction
*/
function RENE(range1, range2){
return [].concat(...range1.map(y => [].concat(...[range2.map(h => [y[0], h[0]])]))).filter(t => t[0]);
}
function alphabet(){
return [...Array(26)].map((_, y) => String.fromCharCode(y + 65)).join('')
}
function alphabetArr(){ return [...alphabet()]}
function alphabetRENEJOIN(range){ return range.map(e=>e.join(''))}
Комбинируя в формуле={alphabetArr();alphabetRENEJOIN(RENE(alphabetArr();alphabetArr()));alphabetRENEJOIN(RENE(alphabetRENEJOIN(RENE(alphabetArr();alphabetArr()));alphabetArr()))}
Получаем все сочетания от A до ZZZ/*
Использование функций генератора JavaScript для диапазонов
Создание генератора диапазонов,подобного диапазонам Python или Ruby
*/
Использование функций генератора JavaScript для диапазонов
Создание генератора диапазонов,подобного диапазонам Python или Ruby
*/
const range = (end, start = 0, step = 1) => {
function* generateRange() {
let x = start - step;
while(x < end - step) yield x += step;
}
return {
[Symbol.iterator]: generateRange
};
}
console.log([...range(7)]); // [0, 1, 2, 3, 4, 5, 6]
for (let i of range(8, 2, 2)) console.log(i); // Logs: 2, 4, 6
#JS #function #arrayИзучаю замену условным конструкциям в JavaScript
В этой статье рассказывается о том как писать условные конструкции лучше,
чем вы к этому скорее всего привыкли и наглядно, на примерах показывается,
как это делать в сравнении с обычными методами.
читать ...
В этой статье рассказывается о том как писать условные конструкции лучше,
чем вы к этому скорее всего привыкли и наглядно, на примерах показывается,
как это делать в сравнении с обычными методами.
читать ...
Telegraph
Изучаю замену условным конструкциям в JavaScript
Перевод статьи 5 Tips to Write Better Conditionals in JavaScript // условие function test(fruit) { if (fruit == 'apple' || fruit == 'strawberry') { console.log('red'); } } На первый взгляд пример выше выглядит вполне хорошо. Однако, что если у нас будет больше…
