Forwarded from volond
This media is not supported in your browser
VIEW IN TELEGRAM
Понадобилось мне синхронизировать заголовки столбцов на разных листах, но хотелось какой-нибудь функционал, чтобы не приходилось бегать и производить настройку с одного места.
Добавил названия листов и указал в какой строке находятся заголовки в этом листе
Формулой подтянул заголовки, но как известно попытка внести данные в ячейки, которые затрагивают эту формулу ломают эту формулу ,поэтому была был придуман какой функционал
Он позволяет изменить заголовок в соответствующем столбце или добавить его в конец строки заголовков соответствующего листа
Код
Добавил названия листов и указал в какой строке находятся заголовки в этом листе
Формулой подтянул заголовки, но как известно попытка внести данные в ячейки, которые затрагивают эту формулу ломают эту формулу ,поэтому была был придуман какой функционал
Он позволяет изменить заголовок в соответствующем столбце или добавить его в конец строки заголовков соответствующего листа
Код
Отфильтруем Массив объектов по переданному массиву ключей
/**#snippet #JS
* Отфильтруем Массив объектов по переданному массиву ключей
* Значения этих в объектах должны соответствовать истине
* @param {Array} filter
* @param {Array[Object]} obj
* @returns {Array}
* var filter=['a','b']
* var obj=[{a:false,b:1,c:3},{a:true,b:1,c:0}]
* return [{a:true,b:1,c:0}]
*/
function filterObject(filter,obj){
var some=(x)=>!x
return obj.filter(row=>!filter.map(key=>row[key]).some(some))
}
Список проектов приложений Google скрипт - CodeRoad
https://coderoad.ru/52087906/%D0%A1%D0%BF%D0%B8%D1%81%D0%BE%D0%BA-%D0%BF%D1%80%D0%BE%D0%B5%D0%BA%D1%82%D0%BE%D0%B2-%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D0%B9-Google-%D1%81%D0%BA%D1%80%D0%B8%D0%BF%D1%82
https://coderoad.ru/52087906/%D0%A1%D0%BF%D0%B8%D1%81%D0%BE%D0%BA-%D0%BF%D1%80%D0%BE%D0%B5%D0%BA%D1%82%D0%BE%D0%B2-%D0%BF%D1%80%D0%B8%D0%BB%D0%BE%D0%B6%D0%B5%D0%BD%D0%B8%D0%B9-Google-%D1%81%D0%BA%D1%80%D0%B8%D0%BF%D1%82
coderoad.ru
Список проектов приложений Google скрипт
- CodeRoad
- CodeRoad
О получении списка файлов проектов типа сценария с привязкой к контейнеру и экспорте каждого сценария из проекта, пожалуйста, проверьте следующий ответ. Получить список файлов проектов типа сценария...
СyrillicPattern
#regexp
#regexp
function cyrillicPattern(){
const cyrillicPattern = /[\u0400-\u04FF]/;
const cyrillicPattern1 = /(?<I>[\u0400-\u04FF]+)\s{1,}(?<F>[\u0400-\u04FF]+)\s{1,}(?<O>[\u0400-\u04FF]+)/;
console.log('Привіт:', cyrillicPattern.test('Привіт'));
console.log('Hello:', cyrillicPattern.test('Hello'));
console.log('Привіт Вася Пупкин', 'Привіт Вася Пупкин'.match(cyrillicPattern1));
var {I,F,O}='Привіт Вася Пупкин'.match(cyrillicPattern1).groups
console.log([I,F,O])//[ 'Привіт', 'Вася', 'Пупкин' ]
}Свяжите проект облачной платформы с проектом GAS.
Презентация
Источник:Linking Cloud Platform Project to Google Apps Script Project
Требуеться для ProjectApp2
Презентация
Источник:Linking Cloud Platform Project to Google Apps Script Project
Требуеться для ProjectApp2
Google Docs
Свяжите проект облачной платформы с проектом GAS.
В таблице Инструменты Редактор сценариев
Получение 1-й пустой ячейки определенного столбца путем поиска в TOP листа
// Pattern 3: getNextDataCell
const patternA3_ = (columnNumber) => {
const range = SpreadsheetApp.openById(ssId)
.getSheets()[0]
.getRange(1, columnNumber);
return range.getDisplayValue()
? range.getNextDataCell(SpreadsheetApp.Direction.DOWN).getRow() + 1
: 1;
};Получение 1-й непустой ячейки определенного столбца путем поиска снизу листа.
// Pattern 4: TextFinder
const patternB4_ = (columnNumber) => {
const sheet = SpreadsheetApp.openById(ssId).getSheets()[0];
const search = sheet
.getRange(1, columnNumber, sheet.getMaxRows())
.createTextFinder(".")
.useRegularExpression(true)
.findPrevious();
return search ? search.getRow() : 1;
};Forwarded from DidacticСardsBot
Скрипт Google Apps: сохранение уникального ключа пользователя от пользователя, получающего доступ к вашему веб-приложению
Источник:
Почему это важно? Что ж, вы можете ограничить количество раз, когда пользователь отправляет форму в вашем WebApp. Если вы можете получить уникальный ключ доступа пользователя, вы можете сохранить количество попыток пользователя и проверить его перед отправкой данных.
••••••••••
Обсудить:
Источник:
Почему это важно? Что ж, вы можете ограничить количество раз, когда пользователь отправляет форму в вашем WebApp. Если вы можете получить уникальный ключ доступа пользователя, вы можете сохранить количество попыток пользователя и проверить его перед отправкой данных.
••••••••••
Обсудить:
Yagisanatode
Google Apps Script: Store a Unique User Key from a User Accessing your WebApp [updated Dec 2021] - Yagisanatode
Google Apps Script: WebApp [updated Dec 2021 – With thanks to Greg S] In this tutorial, we will cover how you can get a unique temporary access key from a user accessing your WebApp that lasts for 30 days. Temporary access keys allow you to track users as…
Уникальные без удаления строк
#snippet #JS #GAS
#snippet #JS #GAS
function g(range){
//var range=[['v'],["v"],["b"]]
var r=range.flat()
var u=[...new Set(r)]
var d=r.reduce((acc, el) => {
acc[el] = (acc[el] || 0) + 1;
return acc;
}, {})
var a=Object.entries(d)
return a.map((e)=>[e[0],...Array(e[1]-1)
.fill('')])
.flat()
.map((h,i)=>[range[i][0],h])
}Путь к пониманию шаблонных литералов в JavaScript
Источник:
Шаблонные литералы дают нам новый механизм создания строковых значений. Этот механизм отличается множеством мощных возможностей, среди которых — упрощение создания многострочных конструкций и использование местозаполнителей для внедрения в строки результатов вычисления выражений. Кроме того, тут имеется и ещё одна возможность — теговые шаблоны (tagged template literals). Это — расширенная форма шаблонных литералов. Теговые шаблоны позволяют создавать строки с использованием выражений, находящихся внутри строк, и с применением особых функций. Всё это расширяет возможности программистов по работе со строками, позволяя, например, создавать динамические строки, которые могут представлять собой URL, или писать функции для тонкой настройки HTML-элементов.
••••••••••
#JS #book
Обсудить:
Источник:
Шаблонные литералы дают нам новый механизм создания строковых значений. Этот механизм отличается множеством мощных возможностей, среди которых — упрощение создания многострочных конструкций и использование местозаполнителей для внедрения в строки результатов вычисления выражений. Кроме того, тут имеется и ещё одна возможность — теговые шаблоны (tagged template literals). Это — расширенная форма шаблонных литералов. Теговые шаблоны позволяют создавать строки с использованием выражений, находящихся внутри строк, и с применением особых функций. Всё это расширяет возможности программистов по работе со строками, позволяя, например, создавать динамические строки, которые могут представлять собой URL, или писать функции для тонкой настройки HTML-элементов.
••••••••••
#JS #book
Обсудить:
Хабр
Путь к пониманию шаблонных литералов в JavaScript
Спецификация ECMAScript, вышедшая в 2015 году (ES6), добавила в JavaScript новую возможность — шаблонные литералы (template literals). Шаблонные литералы дают на...