Архив: java script google sheets. найти ошибку в скрипте
Бюджет
3$
/ 200
руб
в месяц
Создан: 7 лет назад
Закрыт
- Описание
- история скрипта: //Название: "Автоматич. емаил напоминание по параметру". пример: сканируем колонку O, если O=1 или O=0,
то сканируем столбец B,
если В=Влад, то отправить емаил на щ@w с содержанием данной строки от А до L
если В=Сергей, то отправить емаил на x@s с содержанием данной строки от А до L
и т.д сотрудников 5-6.
(тригер скрипта раз в день)"
Позже, я поменял колонки имен c B на A : и скрипт перестал работать. теперь не знаю где исправить скрипт
можете подписать где что менять, если в следующий раз поменяю столбцы?:
var EMAILS = [
{name:"Влад" , emails:"х" },
{name:" Сергей" , emails:"ч" },
{name:"Анастасия", emails:"в" },
var defaultEmail = "щ"; // если имя в списке не найдено будет использоваться этот е-майл.
//var subject ="Напоминание " //Заголовок письма
var NAME_FROM_for_notification="Напоминание" //От кого
function checkReminder() {
// get the spreadsheet object
var spreadsheet = SpreadsheetApp.getActiveSpreadsheet();
var ss=spreadsheet;
// fetch this sheet
var sheet = spreadsheet.getSheetByName(SHEET_NAME_of_notificat ion_sheet);
// figure out what the last row is
var lastRow = sheet.getLastRow();
var lastColumn = sheet.getLastColumn();
// the rows are indexed starting at 1, and the first row
// is the headers, so start with row 2
var startRow = 1;
// grab column 5 (the 'days left' column)
var range = sheet.getRange(startRow,1,lastRow,lastColumn );
var numRows = range.getNumRows();
var values = range.getDisplayValues();
var headers = values.shift(); //получение заголовков из первой строки
var userEmail ="";
var recipients="";
var error = "";
for (var j=0;j<values.length; j++){
columnO=String(values[j][14]).trim(); // получение значения из O столбца.
if (columnO==="0" || columnO==="1" ) // каждая строка столбец O (буква)(нумерация с нуля)
{
//Нахождение соответствующего имени и е-мейл адреса из списка словарей EMAILS:
var name = String(values[j][1]).trim().toLowerCase();
userEmail = defaultEmail; //default Email
for (var k=0;k<EMAILS.length; k++){
if (EMAILS[k].name==""){continue} //переход к следующей итерации если имя — пустая строка
if (EMAILS[k].name.trim().toLowerCase() === name){
if (EMAILS[k].emails==""){continue} //переход к следующей итерации если emails — пустая строка
var templist =EMAILS[k].emails.split(",") //временная переменная чтобы убрать первый е-мейл адрес
userEmail = templist[0].trim(); //
recipients = templist.splice(1).join(",") //дополнительные адреса
break; //при нахождении прекращение итерации.
}
}
//Создание текста для письма:
var data_columnsAL=values[j]; //просто копирование в другую переменную чтоб не тащить за собой [i]
var numberofcolumns=12; //A-L = 0-12, конечный индекс столбца в массиве 12
//ХТМЛ версия письма
var dataAL = "";
for (var i=0; i<=numberofcolumns;i++){
if (headers[i]===undefined) {headers[i]=""}; //пропуск записи если ячейка пустая, чтобы не было "undefined" в результате
if (data_columnsAL[i]===undefined) {data_columnsAL[i]=""}; //пропуск записи если ячейка пустая, чтобы не было "undefined" в результате
if (i>=7 && i <=numberofcolumns) { //если номер столбца H:L
if (headers[i]==""){var headers_with_semicolon=headers[i]}else {headers_with_semicolon=headers[i]+": "}; //Убираем двоеточие из заголовка
dataAL = dataAL + "<br/><b>" +headers_with_semicolon+"</b>"+dat a_columnsAL[i]+"<br/>" //сборка текста письма
} else {
dataAL = dataAL +data_columnsAL[i]+" "; //сборка текста письма
}
var html = dataAL+"<br/> "+ ss.getName() + " <br/><br/> перейти в БлокнотКонтрагенты " + ss.getUrl() + " внести изменения.";
- Категория
Похожие проекты
0
3
Необходимо разработать систему, которая: Подключается к API Diagnocat и iDent (через токены доступа). Получает данные о пациенте, результатах диагностики, снимках и назначениях. Автоматически формирует структурированный отчет по шаблону (включая врачей, этапы лечения, стоимость и описание процедур).......
2 месяца назад
0
0
Необходимо связать БД 1C:ERP с БД Outlook, MS Access, Битрикс24. Например при вводе нового сотрудника в 1С:ERP он должен автоматически появляться в вышеперечисленных БД....
3 месяца назад
0
1
Требуется реализация отчёта на кастомизированной 1С:УПП 1. 2, ТЗ и контрольный пример во вложении, 80% кода должно быть покрыто модульными тестами....
3 месяца назад
$7
0
2
Мне нужно копировать мой текст и вставлять в одну группу ВК с открытой стеной для публикации рекламы. Задача скрипта/сервиса/программы - примерно каждые 10 секунд брать мой текст и вставлять в эту группу. Я пробовал через одну программу, которая записывает действия мышки и потом повторяет, но она как-то......
5 месяцев назад
0
0
Написать прошивку для A94B114, используя 2 подобные рабочие прошивки. Все файлы есть....
6 месяцев назад
$21
0
2
Нужно разархивировать файл архив. ujems, есть распаковщик, но выдает ошибку. Прислать пруфы(скрины)....
7 месяцев назад
0
1
Входные: Имеется скрипт по обработке email писем и добавление их в систему Redmine Проблема: Система обработки этих писем написана некорректная и негибкая Задача: Переписать логику обработки входящих писем, чтобы исключить их потерю при незначительных отклонениях от ожидаемой структуры....
7 месяцев назад
$37
0
1
- В обязанности сотрудника входит поддержание мобильного приложения системы автоматизации бизнеса. - Работа сдельная: задачи выдаются на оценку, далее после согласования передаются на реализацию. - Заключаем договор и NDA (соглашение о неразглашении)....
7 месяцев назад
$71
0
0
Информация о проекте: Проект включает в себя React Native приложение с Expo внутри которого находится webview с сайтом На устройствах с ОС IOS проблема с воспроизведением видео....
8 месяцев назад
0
0
Разрабатываю десктопные программы на языке Java, а так же Java + SQL....
8 месяцев назад
0
0
0
6
1. Чтобы можно было писать описание события (без заголовка) - превью в списке берется N количества букв с начала. (в списке писать дату события и сколько осталось до него) . Выставление даты и времени напоминания и ИНТЕРВАЛА ПОВТОРА ОТ 1 МИНУТЫ! Выставлять количество повторов, далее напоминания прекращаются.......
9 месяцев назад
0
4
Сайт arg2028t. beget. tech/. Нужно сделать вот такой калькулятор. airprint. by/outdoor/wide-format. и еще некоторые доработки....
9 месяцев назад
$214
0
1
0
7
Краткое описание: Мы ищем исполнителя для тестирования функционала мобильного приложения на платформе Android. Задача включает проверку основных функций приложения, таких как работа комнаты, передача видео, звука и чата, а также создание подробной отчетности о найденных ошибках. Требования к исполнителю:......
10 месяцев назад
0
12
$143
0
0
Oпpocы (1008pyб/чaс) Заходитe на сaйт: gonsù....
11 месяцев назад
0
4
Требуется создать скрипт для premiere pro. Данная суть скрипта: в выделеном бине нужно что бы автоматически проставлялся in out ровно по серидине файла так что бы выделенная область была длиной 3 секунды. И требуется кнопка что бы работало через окно expressions. Проблема текущего в том что он не работает......
11 месяцев назад
0
2
Нужно создать приложения под гемблинг/беттинг, на котлин. Приложение должно работать Firebase. Детали вышлю при обсуждение....
11 месяцев назад
$21
0
4
Нужно разархивировать файл archive. ujems, есть распаковщик, но выдает ошибку. Прислать пруфы ....
1 год назад
0
3
Разработать впн сервис ( Приложения на ios и android + сайт для оплаты подписки). Настройка Серверов. Оплата по договоренности. Работаем черед безопасную сделку....
1 год назад
Похожая удалённая работа
- Удаленная работа для веб-программиста
- Удаленная работа для разработчика баз данных
- Удаленная работа для прикладного программиста
- Удаленная работа для системного программиста
- Удаленная работа для разработчика игр
- Удаленная работа для разработчика мобильных приложений
- Удаленная работа для тестировщика ПО
- Удаленная работа для 1С программиста
- Удаленная работа для разработчика встраиваемых систем
- Удаленная работа для разработчика CRM и ERP