Skip to content
  • Home
  • Recent
  • Tags
  • 0 Unread 0
  • Categories
  • Unreplied
  • Popular
  • GitHub
  • Docu
  • Hilfe
Skins
  • Light
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dark
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Default (No Skin)
  • No Skin
Collapse
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Русский
  3. ioBroker
  4. Скрипты
  5. ioBroker скрипты
  6. Трех-кратное выполнение кода скрипта

NEWS

  • Monatsrückblick Januar/Februar 2026 ist online!
    BluefoxB
    Bluefox
    18
    1
    688

  • Jahresrückblick 2025 – unser neuer Blogbeitrag ist online! ✨
    BluefoxB
    Bluefox
    18
    1
    5.8k

  • Neuer Blogbeitrag: Monatsrückblick - Dezember 2025 🎄
    BluefoxB
    Bluefox
    13
    1
    1.5k

Трех-кратное выполнение кода скрипта

Scheduled Pinned Locked Moved ioBroker скрипты
8 Posts 3 Posters 2.6k Views
  • Oldest to Newest
  • Newest to Oldest
  • Most Votes
Reply
  • Reply as topic
Log in to reply
This topic has been deleted. Only users with topic management privileges can see it.
  • E Offline
    E Offline
    evgeny_nd
    wrote on last edited by
    #1

    Добрый день.

    Есть код:

    ! ````
    on({id: "megad.3.p9_G0_Boiler_Control2"/G0_Boiler_Control2 - Размыкатель ТТ котла/, change: 'any'}, function (obj) {
    if (getState("megad.3.p9_G0_Boiler_Control2").val === false) { // если котел запущен
    setState("den.0.Отопление.ТТ_Котел.Время_до_запуска",0);
    time_start_stamp = new Date(getState("megad.3.p9_G0_Boiler_Control2").ts);
    var time_start = ('0' + time_start_stamp.getHours()).slice(-2) + ':' + ('0' + time_start_stamp.getMinutes()).slice(-2);
    setState("den.0.Отопление.ТТ_Котел.Время_последнего_запуска",time_start);
    log ('ТТ Котел запущен в ' + getState("den.0.Отопление.ТТ_Котел.Время_последнего_запуска").val);
    sendTo("telegram.0", "send", {
    text: 'ТТ Котел запущен в '+ time_start
    })
    }
    else { // иначе если котел остановлен
    setState("den.0.Отопление.ТТ_Котел.Время_до_останова",0);
    time_stop_stamp = new Date(getState("megad.3.p9_G0_Boiler_Control2").ts);
    var time_stop = ('0' + time_stop_stamp.getHours()).slice(-2) + ':' + ('0' + time_stop_stamp.getMinutes()).slice(-2);
    setState("den.0.Отопление.ТТ_Котел.Время_последнего_останова",time_stop);
    log ('ТТ Котел остановлен в ' + getState("den.0.Отопление.ТТ_Котел.Время_последнего_останова").val);
    sendTo("telegram.0", "send", {
    text: 'ТТ Котел остановлен в '+ time_stop
    })
    }
    });

    
    Он рабочий, НО не понимаю почему драйвер Telegram присылает по три сообщения о включении или выключении котла.
    
    В остальных скриптах, сообщения приходят по одному, без повторения. А здесь…
    
    При этом не важно изменяется статус переменной megad.3.p9_G0_Boiler_Control2 (вручную нажатием кнопки в VIS или из скрипта по условию).
    
    Подскажите в какую сторону посмотреть?
    1 Reply Last reply
    0
    • BluefoxB Offline
      BluefoxB Offline
      Bluefox
      wrote on last edited by
      #2

      А так? Два срабатывания я могу объяснить. А вот три

      on({id: "megad.3.p9_G0_Boiler_Control2"/*G0_Boiler_Control2 - Размыкатель ТТ котла*/, change: 'any', ack: false}, function (obj) {    
          if (obj.state.val === false) { // если котел запущен
              setState("den.0.Отопление.ТТ_Котел.Время_до_запуска",0);
              time_start_stamp = new Date(getState("megad.3.p9_G0_Boiler_Control2").ts);
              var time_start = ('0' + time_start_stamp.getHours()).slice(-2) + ':' + ('0' + time_start_stamp.getMinutes()).slice(-2);
              setState("den.0.Отопление.ТТ_Котел.Время_последнего_запуска",time_start);
              log ('ТТ Котел запущен в ' + getState("den.0.Отопление.ТТ_Котел.Время_последнего_запуска").val);
              sendTo("telegram.0", "send", {
                  text: 'ТТ Котел запущен в  '+ time_start
              })
          }
          else {                                                          // иначе если котел остановлен
              setState("den.0.Отопление.ТТ_Котел.Время_до_останова",0);
              time_stop_stamp = new Date(getState("megad.3.p9_G0_Boiler_Control2").ts);
              var time_stop = ('0' + time_stop_stamp.getHours()).slice(-2) + ':' + ('0' + time_stop_stamp.getMinutes()).slice(-2);
              setState("den.0.Отопление.ТТ_Котел.Время_последнего_останова",time_stop);
              log ('ТТ Котел остановлен в ' + getState("den.0.Отопление.ТТ_Котел.Время_последнего_останова").val);
              sendTo("telegram.0", "send", {
                  text: 'ТТ Котел остановлен в  '+ time_stop
              }) 
          }
      });
      
      
      1 Reply Last reply
      0
      • I Offline
        I Offline
        instalator
        wrote on last edited by
        #3

        @evgeny_nd:

        Добрый день.

        Есть код:

        ! ````
        on({id: "megad.3.p9_G0_Boiler_Control2"/G0_Boiler_Control2 - Размыкатель ТТ котла/, change: 'any'}, function (obj) {
        if (getState("megad.3.p9_G0_Boiler_Control2").val === false) { // если котел запущен
        setState("den.0.Отопление.ТТ_Котел.Время_до_запуска",0);
        time_start_stamp = new Date(getState("megad.3.p9_G0_Boiler_Control2").ts);
        var time_start = ('0' + time_start_stamp.getHours()).slice(-2) + ':' + ('0' + time_start_stamp.getMinutes()).slice(-2);
        setState("den.0.Отопление.ТТ_Котел.Время_последнего_запуска",time_start);
        log ('ТТ Котел запущен в ' + getState("den.0.Отопление.ТТ_Котел.Время_последнего_запуска").val);
        sendTo("telegram.0", "send", {
        text: 'ТТ Котел запущен в '+ time_start
        })
        }
        else { // иначе если котел остановлен
        setState("den.0.Отопление.ТТ_Котел.Время_до_останова",0);
        time_stop_stamp = new Date(getState("megad.3.p9_G0_Boiler_Control2").ts);
        var time_stop = ('0' + time_stop_stamp.getHours()).slice(-2) + ':' + ('0' + time_stop_stamp.getMinutes()).slice(-2);
        setState("den.0.Отопление.ТТ_Котел.Время_последнего_останова",time_stop);
        log ('ТТ Котел остановлен в ' + getState("den.0.Отопление.ТТ_Котел.Время_последнего_останова").val);
        sendTo("telegram.0", "send", {
        text: 'ТТ Котел остановлен в '+ time_stop
        })
        }
        });

        
        Он рабочий, НО не понимаю почему драйвер Telegram присылает по три сообщения о включении или выключении котла.
        
        В остальных скриптах, сообщения приходят по одному, без повторения. А здесь…
        
        При этом не важно изменяется статус переменной megad.3.p9_G0_Boiler_Control2 (вручную нажатием кнопки в VIS или из скрипта по условию).
        
        Подскажите в какую сторону посмотреть? `  
        

        На будущее оформляйте код на форуме в тег CODE и под спойлер.

        Вот так что выдает в логе?

        ! ````
        on({id: "megad.3.p9_G0_Boiler_Control2"/G0_Boiler_Control2 - Размыкатель ТТ котла/, change: 'any'}, function (obj) {
        log ('megad.3.p9_G0_Boiler_Control2 = ' + obj.state.val);
        if (obj.state.val === false) { // если котел запущен
        setState("den.0.Отопление.ТТ_Котел.Время_до_запуска", 0);
        var time_start_stamp = new Date(obj.state.ts);
        var time_start = ('0' + time_start_stamp.getHours()).slice(-2) + ':' + ('0' + time_start_stamp.getMinutes()).slice(-2);
        setState("den.0.Отопление.ТТ_Котел.Время_последнего_запуска",time_start);
        log ('ТТ Котел запущен в ' + getState("den.0.Отопление.ТТ_Котел.Время_последнего_запуска").val);
        sendTo("telegram.0", "send", {
        text: 'ТТ Котел запущен в '+ time_start
        });
        }
        else { // иначе если котел остановлен
        setState("den.0.Отопление.ТТ_Котел.Время_до_останова",0);
        var time_stop_stamp = new Date(obj.state.ts);
        var time_stop = ('0' + time_stop_stamp.getHours()).slice(-2) + ':' + ('0' + time_stop_stamp.getMinutes()).slice(-2);
        setState("den.0.Отопление.ТТ_Котел.Время_последнего_останова", time_stop);
        log ('ТТ Котел остановлен в ' + getState("den.0.Отопление.ТТ_Котел.Время_последнего_останова").val);
        sendTo("telegram.0", "send", {
        text: 'ТТ Котел остановлен в '+ time_stop
        });
        }
        });

        Высокий уровень Децибел вреден для здоровья!

        http://blog.instalator.ru/

        1 Reply Last reply
        0
        • E Offline
          E Offline
          evgeny_nd
          wrote on last edited by
          #4

          @Bluefox:

          А так? Два срабатывания я могу объяснить. А вот три

          on({id: "megad.3.p9_G0_Boiler_Control2"/*G0_Boiler_Control2 - Размыкатель ТТ котла*/, change: 'any', ack: false}, function (obj) {    
          
          ```` `  
          

          Bluefox, спасибо, добавление ", ack: false" помогло. Сообщение приходят по одному. А можете объяснить назначение этого флага, либо дать ссылку где вообще подробнее почитать описание используемого языка. Потому что сейчас весь процесс обучения происходит по аналогии с увиденным, а хотелось бы так чтобы понимать основы и все возможности :).

          To Instalator, в части написания сообщений с кодом, учту.

          1 Reply Last reply
          0
          • I Offline
            I Offline
            instalator
            wrote on last edited by
            #5

            @evgeny_nd:

            Bluefox, спасибо, добавление ", ack: false" помогло. Сообщение приходят по одному. А можете объяснить назначение этого флага, либо дать ссылку где вообще подробнее почитать описание используемого языка. Потому что сейчас весь процесс обучения происходит по аналогии с увиденным, а хотелось бы так чтобы понимать основы и все возможности :).

            To Instalator, в части написания сообщений с кодом, учту. ` аск это подтверждение. Если проверишь и проанализируешь оба предложенных варианта то скорее всего поймёшь в чём проблема

            Высокий уровень Децибел вреден для здоровья!

            http://blog.instalator.ru/

            1 Reply Last reply
            0
            • E Offline
              E Offline
              evgeny_nd
              wrote on last edited by
              #6

              @instalator:

              @evgeny_nd:

              Bluefox, спасибо, добавление ", ack: false" помогло. Сообщение приходят по одному. А можете объяснить назначение этого флага, либо дать ссылку где вообще подробнее почитать описание используемого языка. Потому что сейчас весь процесс обучения происходит по аналогии с увиденным, а хотелось бы так чтобы понимать основы и все возможности :).

              To Instalator, в части написания сообщений с кодом, учту. аск это подтверждение. Если проверишь и проанализируешь оба предложенных варианта то скорее всего поймёшь в чём проблема

              Подтверждение в смысле дополнительное условие, т.е. подтверждение того что подписка срабатывает только тогда когда ее изменение переходят в значение которое указано после "ack"?

              А второй вопрос, как правильнее должен быть устроен код? Мой или ваш, в котором проверяется не сама переменная внутри подписки, а статус ответа, который отдает подписка?

              1 Reply Last reply
              0
              • I Offline
                I Offline
                instalator
                wrote on last edited by
                #7

                @evgeny_nd:

                @instalator:

                @evgeny_nd:

                Bluefox, спасибо, добавление ", ack: false" помогло. Сообщение приходят по одному. А можете объяснить назначение этого флага, либо дать ссылку где вообще подробнее почитать описание используемого языка. Потому что сейчас весь процесс обучения происходит по аналогии с увиденным, а хотелось бы так чтобы понимать основы и все возможности :).

                To Instalator, в части написания сообщений с кодом, учту. аск это подтверждение. Если проверишь и проанализируешь оба предложенных варианта то скорее всего поймёшь в чём проблема

                Подтверждение в смысле дополнительное условие, т.е. подтверждение того что подписка срабатывает только тогда когда ее изменение переходят в значение которое указано после "ack"?

                А второй вопрос, как правильнее должен быть устроен код? Мой или ваш, в котором проверяется не сама переменная внутри подписки, а статус ответа, который отдает подписка? ` когда ты меняешь объект руками то аск будет фолс, а если в этот объект прилетит статус из драйвера то аск будет тру.

                Мой. По подписке ты уже получаешь все данные в объекте obj. И не нужно получать их другими функциями например getState

                Высокий уровень Децибел вреден для здоровья!

                http://blog.instalator.ru/

                1 Reply Last reply
                0
                • E Offline
                  E Offline
                  evgeny_nd
                  wrote on last edited by
                  #8

                  @instalator:

                  @evgeny_nd:

                  @instalator:

                  аск это подтверждение. Если проверишь и проанализируешь оба предложенных варианта то скорее всего поймёшь в чём проблема `

                  Подтверждение в смысле дополнительное условие, т.е. подтверждение того что подписка срабатывает только тогда когда ее изменение переходят в значение которое указано после "ack"?

                  А второй вопрос, как правильнее должен быть устроен код? Мой или ваш, в котором проверяется не сама переменная внутри подписки, а статус ответа, который отдает подписка? ` когда ты меняешь объект руками то аск будет фолс, а если в этот объект прилетит статус из драйвера то аск будет тру.

                  Мой. По подписке ты уже получаешь все данные в объекте obj. И не нужно получать их другими функциями например getState `

                  Теперь все понял. Спасибо.

                  Кстати сейчас с вариантом Bluefox, сообщение приходят по одному разу. И в случае ручного включения, и в случае изменения по условию из другого скрипта.

                  1 Reply Last reply
                  0

                  Hello! It looks like you're interested in this conversation, but you don't have an account yet.

                  Getting fed up of having to scroll through the same posts each visit? When you register for an account, you'll always come back to exactly where you were before, and choose to be notified of new replies (either via email, or push notification). You'll also be able to save bookmarks and upvote posts to show your appreciation to other community members.

                  With your input, this post could be even better 💗

                  Register Login
                  Reply
                  • Reply as topic
                  Log in to reply
                  • Oldest to Newest
                  • Newest to Oldest
                  • Most Votes


                  Support us

                  ioBroker
                  Community Adapters
                  Donate

                  488

                  Online

                  32.7k

                  Users

                  82.6k

                  Topics

                  1.3m

                  Posts
                  Community
                  Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                  ioBroker Community 2014-2025
                  logo
                  • Login

                  • Don't have an account? Register

                  • Login or register to search.
                  • First post
                    Last post
                  0
                  • Home
                  • Recent
                  • Tags
                  • Unread 0
                  • Categories
                  • Unreplied
                  • Popular
                  • GitHub
                  • Docu
                  • Hilfe