Navigation

    Logo
    • Register
    • Login
    • Search
    • Recent
    • Tags
    • Unread
    • Categories
    • Unreplied
    • Popular
    • GitHub
    • Docu
    • Hilfe
    1. Home
    2. Русский
    3. ioBroker
    4. Скрипты
    5. ioBroker скрипты
    6. Вопросы по написанию скриптов

    NEWS

    • ioBroker@Smart Living Forum Solingen, 14.06. - Agenda added

    • ioBroker goes Matter ... Matter Adapter in Stable

    • Monatsrückblick - April 2025

    Вопросы по написанию скриптов

    This topic has been deleted. Only users with topic management privileges can see it.
    • S
      spectrekr last edited by

      Тогда надо было писать что у них все единицы измерения не верно воспроизводятся 🙂 У меня скорость ветра в km/h он тоже не верно воспроизводит.

      Вопрос, а как в лог записать сообщение с пометкой warn?

      1 Reply Last reply Reply Quote 0
      • Bluefox
        Bluefox last edited by

        @spectrekr:

        Вопрос, а как в лог записать сообщение с пометкой warn? `

        log('This is warning', 'warn');
        
        1 Reply Last reply Reply Quote 0
        • aurodionov
          aurodionov last edited by

          Извиняюсь, может н в ту ветку.

          По логированию, какие ещё есть варианты,(info,warning,error) знаю

          1 Reply Last reply Reply Quote 0
          • Bluefox
            Bluefox last edited by

            > По логированию, какие ещё есть варианты,(info,warning,error) знаю
            debug

            1 Reply Last reply Reply Quote 0
            • aurodionov
              aurodionov last edited by

              А возможно например создать свой уровень

               function(code){ 
              if (code !== 0) { 
              log('что-то там: ' + code); 
              } else {
              log('OK');
              }
              

              и его логировать отдельно,а ещё лучше засунуть его в переменную или типа того.

              Тогда появится возможность вести что-то вроде лога событий которые происходят (например работают из скриптов)

              1 Reply Last reply Reply Quote 0
              • Bluefox
                Bluefox last edited by

                @aurodionov:

                А возможно например создать свой уровень

                 function(code){ 
                if (code !== 0) { 
                log('что-то там: ' + code); 
                } else {
                log('OK');
                }
                

                и его логировать отдельно,а ещё лучше засунуть его в переменную или типа того.

                Тогда появится возможность вести что-то вроде лога событий которые происходят (например работают из скриптов) `
                Нет нельзя. И я пока не понял зачем ещё. Если хочешь, то можешь сам писать в переменную список событий.

                1 Reply Last reply Reply Quote 0
                • V
                  vtec last edited by

                  Bluefox, можно привести пару пример для чего можно использовать enums?

                  1 Reply Last reply Reply Quote 0
                  • Bluefox
                    Bluefox last edited by

                    Например состояния плеера:

                    'stop;play;paused'

                    Тогда значения состояния 0,1 и 2 автоматически будут показыватся в admin, как stop, play…

                    Вот в принципе и всё.

                    1 Reply Last reply Reply Quote 0
                    • V
                      vtec last edited by

                      А в виде кода можно как нибудь изобразить?

                      1 Reply Last reply Reply Quote 0
                      • V
                        vtec last edited by

                        Как правильно сделать несколько таймаутов? Нужно мегой помигать через 2 сек.

                        Вот так срабатывает первый setTimeout

                        var url = 'http://192.168.0.14/sec/?cmd=7:2';

                        request(url);

                        setTimeout(function(){ request(url); }, 2000);

                        setTimeout(function(){ request(url); }, 2000);

                        setTimeout(function(){ request(url); }, 2000);

                        Если делаю вложенные, то работает, но так ведь и запутаться можно.

                        setTimeout(function(){

                        request(url);

                        setTimeout(function(){ request(url); }, 2000);

                        }, 2000);

                        Есть ли более красивый/правильный пример?

                        1 Reply Last reply Reply Quote 0
                        • I
                          instalator last edited by

                          @vtec:

                          Как правильно сделать несколько таймаутов? Нужно мегой помигать через 2 сек.

                          Вот так срабатывает первый setTimeout

                          var url = 'http://192.168.0.14/sec/?cmd=7:2';

                          request(url);

                          setTimeout(function(){ request(url); }, 2000);

                          setTimeout(function(){ request(url); }, 2000);

                          setTimeout(function(){ request(url); }, 2000);

                          Если делаю вложенные, то работает, но так ведь и запутаться можно.

                          setTimeout(function(){

                          request(url);

                          setTimeout(function(){ request(url); }, 2000);

                          }, 2000);

                          Есть ли более красивый/правильный пример? `
                          setTimeout

                          var url = 'http://192.168.0.14/sec/?cmd=7:2';

                          request(url);

                          setTimeout(function(){ request(url); }, 2000);

                          setTimeout(function(){ request(url); }, 4000);

                          setTimeout(function(){ request(url); }, 6000);

                          1 Reply Last reply Reply Quote 0
                          • V
                            vtec last edited by

                            Спасибо, работает 🙂

                            1 Reply Last reply Reply Quote 0
                            • Bluefox
                              Bluefox last edited by

                              @instalator:

                              @vtec:

                              Как правильно сделать несколько таймаутов? Нужно мегой помигать через 2 сек.

                              Вот так срабатывает первый setTimeout

                              var url = 'http://192.168.0.14/sec/?cmd=7:2';

                              request(url);

                              setTimeout(function(){ request(url); }, 2000);

                              setTimeout(function(){ request(url); }, 2000);

                              setTimeout(function(){ request(url); }, 2000);

                              Если делаю вложенные, то работает, но так ведь и запутаться можно.

                              setTimeout(function(){

                              request(url);

                              setTimeout(function(){ request(url); }, 2000);

                              }, 2000);

                              Есть ли более красивый/правильный пример? `
                              setTimeout

                              var url = 'http://192.168.0.14/sec/?cmd=7:2';

                              request(url);

                              setTimeout(function(){ request(url); }, 2000);

                              setTimeout(function(){ request(url); }, 4000);

                              setTimeout(function(){ request(url); }, 6000); `

                              Правильнее будет сделать так:

                              var url = 'http://192.168.0.14/sec/?cmd=7:2';
                              
                              function blink(count) {
                                 if (count === undefined) count = 0;
                                 if (count > 3) return;
                                 request(url);
                                 setTimeout(blink, 2000, count + 1);
                              }
                              
                              blink();
                              
                              
                              1 Reply Last reply Reply Quote 0
                              • V
                                vtec last edited by

                                `var idSayIt = "sayit.0.tts.text";
                                var message = [];
                                message.push('Доброе утро.');
                                message.push('За окном 7 градусов.');
                                message.push('Прогноз погоды на завтра');
                                
                                for(var i=0; i<message.length; i++){/setstate/(idsayit,/message[i]);/log(message[i]);/}<e=""></message.length;>`
                                
                                Почему данный код работает не корректно, то есть может второе сообщение проговорить два раза, а последнее не произнести?[/i][/i]
                                
                                1 Reply Last reply Reply Quote 0
                                • I
                                  instalator last edited by

                                  @vtec:

                                  `var idSayIt = "sayit.0.tts.text";
                                  var message = [];
                                  message.push('Доброе утро.');
                                  message.push('За окном 7 градусов.');
                                  message.push('Прогноз погоды на завтра');
                                  
                                  for(var i=0; i<message.length; i++){/setstate/(idsayit,/message[i]);/log(message[i]);/}<e=""></message.length;>`
                                  
                                  Почему данный код работает не корректно, то есть может второе сообщение проговорить два раза, а последнее не произнести?
                                  А в лог норм выводит?[/i][/i]
                                  ``` ` 
                                  1 Reply Last reply Reply Quote 0
                                  • V
                                    vtec last edited by

                                    В лог да, нормально

                                    1 Reply Last reply Reply Quote 0
                                    • I
                                      instalator last edited by

                                      @vtec:

                                      В лог да, нормально `
                                      Данные пишутся без задержки, я думаю в этом причина, может сделать опрос закончилось ли прогаваривание текущего потом подавать на вывод следующие данные

                                      1 Reply Last reply Reply Quote 0
                                      • Bluefox
                                        Bluefox last edited by

                                        Попробуй так:

                                         `var idSayIt = "sayit.0.tts.text";
                                        var message = [];
                                        message.push({text: 'Доброе утро.', interval: 3000});
                                        message.push({text: 'За окном 7 градусов.', interval: 4000});
                                        message.push({text: 'Прогноз погоды на завтра', interval: 5000});
                                        
                                        var interval = 0;
                                        for(var i=0; i<message.length; i++){/settimeout(function/(text)/{/setstate/(idsayit,/text);/log(text);/},/interval,/message[i].text);/interval/+="message[i].interval;" }<e=""></message.length;>`
                                          [2678_error.png](/assets/uploads/files/2678_error.png)  [/i][/i]
                                        
                                        1 Reply Last reply Reply Quote 0
                                        • V
                                          vtec last edited by

                                          Можно ли как то отследить изменение объекта, если в этот объект происходит запись одного и того же значения (например: up), но с интервалом например в 2-3 секунды?

                                          Я пока только так придумал:

                                          on('javascript.0.kodi.ExecuteAction',function (obj) {
                                              if(obj.newState.val !== false){
                                                  sendCommand(obj.newState.val);
                                                  setState('javascript.0.kodi.ExecuteAction', false)
                                           }
                                          });
                                          

                                          Может лучше есть решение?

                                          1 Reply Last reply Reply Quote 0
                                          • Bluefox
                                            Bluefox last edited by

                                            on({id: 'javascript.0.kodi.ExecuteAction', change: 'any'}, function (obj) {
                                                    sendCommand(obj.newState.val);
                                            });
                                            
                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            600
                                            Online

                                            31.7k
                                            Users

                                            79.7k
                                            Topics

                                            1.3m
                                            Posts

                                            29
                                            358
                                            86315
                                            Loading More Posts
                                            • Oldest to Newest
                                            • Newest to Oldest
                                            • Most Votes
                                            Reply
                                            • Reply as topic
                                            Log in to reply
                                            Community
                                            Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen
                                            The ioBroker Community 2014-2023
                                            logo