Navigation

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

    NEWS

    • Neuer Blog: Fotos und Eindrücke aus Solingen

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

    • ioBroker goes Matter ... Matter Adapter in Stable

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

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

      @Haus:

      @Bluefox:

      @Haus:

      Как сделать выполнение скрипта через пять минут после его завершения. В этом варианте circ_flap_duration2 одна или две секунды , но есть в скрипте и 35; 140 секунд. То Есть чтобы код подождал пока выполнится setTimeout действие.

      function startt() {
              {
                      if ( circ_temp_water_real > circ_temp_water + 3 )
      	        circ_flap_duration = circ_mix_step * 2;
      	        else
      	        circ_flap_duration = circ_mix_step;
                      circ_flap_duration2 = circ_flap_duration * 1000;
      	        setState(cmuid, 0);
      	        setState(cmdid, 1);
      	        setTimeout(function () {setState(cmdid, 0);}, circ_flap_duration2);
      	        circ_flap = circ_flap - circ_flap_duration;
                      setState(cfid, circ_flap);
              }
       }
      setInterval(function() {
          startt();
      },300000);               
      
      ```` `  
      

      Код не может подождать. Надо снова вызывать setTimeout. В каком месте надо подождать?

      function startt(cb) {
              {
                      if ( circ_temp_water_real > circ_temp_water + 3 )
      	        circ_flap_duration = circ_mix_step * 2;
      	        else
      	        circ_flap_duration = circ_mix_step;
                      circ_flap_duration2 = circ_flap_duration * 1000;
      	        setState(cmuid, 0);
      	        setState(cmdid, 1);
      	        setTimeout(function () {setState(cmdid, 0); cb && cb();}, circ_flap_duration2);
      	        circ_flap = circ_flap - circ_flap_duration;
                      setState(cfid, circ_flap);
                      
              }
       }
      setInterval(function() {
          startt(function () {
              log('едем дальше');
           });
      },300000);               
      
      ```` `  
      

      setState(cmdid, 1);

      setTimeout(function () {setState(cmdid, 0); cb && cb();}, 140000);

      }

      чтобы код идущий дальше выполнялся по завершению этого действия, просто дальше по коду есть условия if (circ_flap < 10) сделай то и то …

      В PHP из которого я переделал это выглядит так

      key_sw($circ_mix_up, 0);
      key_sw($circ_mix_down, 1);
      sleep(120);
      key_sw($circ_mix_down, 0);
      
      

      и по логу видно как время смищается `
      Я же показал код. Посмотри там где написано 'едем дальше'

      А твой PHP вот так бы выглядел в JS:

      key_sw($circ_mix_up, 0);
      key_sw($circ_mix_down, 1);
      setTimeout(function () {
            key_sw($circ_mix_down, 0);
      }, 120);
      
      1 Reply Last reply Reply Quote 0
      • I
        instalator last edited by

        А по моей проблемам какие идеи?

        1 Reply Last reply Reply Quote 0
        • S
          spectrekr last edited by

          А как можно вывести все поля объекта? Когда подписываюсь на изменения объекта, например чтоб не только по полю val проверять, а например, и по времени изменения?

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

            @spectrekr:

            А как можно вывести все поля объекта? Когда подписываюсь на изменения объекта, например чтоб не только по полю val проверять, а например, и по времени изменения? `
            Вместо val напиши ts. Описание на дравйвер смотри на гите

            1 Reply Last reply Reply Quote 0
            • S
              spectrekr last edited by

              В чем ошибка?

              on({id: 'javascript.0.sms.in.time', change: 'any'}, function (obj) {
                  log(obj.oldState.ts);
                  log(getObject('javascript.0.sms.in.time').oldState.ts);
              });
              

              Вроде бы должно в обоих случаях вывести одинаковое число, а по факту первый лог выводит, а второй дает ошибку что ts не существует.

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

                @spectrekr:

                В чем ошибка?

                on({id: 'javascript.0.sms.in.time', change: 'any'}, function (obj) {
                    log(obj.oldState.ts);
                    log(getObject('javascript.0.sms.in.time').oldState.ts);
                });
                

                Вроде бы должно в обоих случаях вывести одинаковое число, а по факту первый лог выводит, а второй дает ошибку что ts не существует. `
                getState (id)

                Returns state of id in form {val: value, ack: true/false, ts: timestamp, lc: lastchanged, from: origin}

                Отсюда следует что колбек getState возвращает только текущее состояние. А вот on возвращает много чего.

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

                  Имеем массив с данными

                  data-product="{"id":2104,"price":250,"discountPrice":240,"isBottle":true,"type":"product","count":1}",

                  data-product="{"id":1204,"price":190,"discountPrice":180,"isBottle":true,"type":"product","count":1}",

                  data-product="{"id":1041,"price":170,"discountPrice":160,"isBottle":true,"type":"product","count":1}",

                  data-product="{"id":3,"price":160,"discountPrice":150,"isBottle":true,"type":"product","count":1}",

                  data-product="{"id":1203,"price":120,"discountPrice":120,"isBottle":true,"type":"product","count":1}"

                  log(JSON.parse(itm)) выдает данные как строку а не как объект, это особенность JSON.parse для массивов?

                  `m.forEach(function(itm, i, arr) {
                                      result[i] = JSON.stringify((itm.replace('data-product="', '').replace(/"/g, '"').slice(0, -1)));
                  
                                      if (i >= arr.length - 1){
                                          result.forEach(function(itm, i, arr) {
                                          log(JSON.parse(itm));    
                  
                                          });
                                      }
                                  });` [/i]
                  
                  1 Reply Last reply Reply Quote 0
                  • Bluefox
                    Bluefox last edited by

                    @instalator:

                    Имеем массив с данными

                    data-product="{"id":2104,"price":250,"discountPrice":240,"isBottle":true,"type":"product","count":1}",

                    data-product="{"id":1204,"price":190,"discountPrice":180,"isBottle":true,"type":"product","count":1}",

                    data-product="{"id":1041,"price":170,"discountPrice":160,"isBottle":true,"type":"product","count":1}",

                    data-product="{"id":3,"price":160,"discountPrice":150,"isBottle":true,"type":"product","count":1}",

                    data-product="{"id":1203,"price":120,"discountPrice":120,"isBottle":true,"type":"product","count":1}"

                    log(JSON.parse(itm)) выдает данные как строку а не как объект, это особенность JSON.parse для массивов?

                    `m.forEach(function(itm, i, arr) {
                                        result[i] = JSON.stringify((itm.replace('data-product="', '').replace(/"/g, '"').slice(0, -1)));
                                        
                                        if (i >= arr.length - 1){
                                            result.forEach(function(itm, i, arr) {
                                            log(JSON.parse(itm));    
                    
                                            });
                                        }
                                    });` 
                    Ты не даешь полной информации. Как конкретно выглядит m?[/i]
                    ``` ` 
                    1 Reply Last reply Reply Quote 0
                    • I
                      instalator last edited by

                      @Bluefox:

                      @instalator:

                      Имеем массив с данными

                      data-product="{"id":2104,"price":250,"discountPrice":240,"isBottle":true,"type":"product","count":1}",

                      data-product="{"id":1204,"price":190,"discountPrice":180,"isBottle":true,"type":"product","count":1}",

                      data-product="{"id":1041,"price":170,"discountPrice":160,"isBottle":true,"type":"product","count":1}",

                      data-product="{"id":3,"price":160,"discountPrice":150,"isBottle":true,"type":"product","count":1}",

                      data-product="{"id":1203,"price":120,"discountPrice":120,"isBottle":true,"type":"product","count":1}"

                      log(JSON.parse(itm)) выдает данные как строку а не как объект, это особенность JSON.parse для массивов?

                      `m.forEach(function(itm, i, arr) {
                                          result[i] = JSON.stringify((itm.replace('data-product="', '').replace(/"/g, '"').slice(0, -1)));
                                          
                                          if (i >= arr.length - 1){
                                              result.forEach(function(itm, i, arr) {
                                              log(JSON.parse(itm));    
                      
                                              });
                                          }
                                      });` 
                      Ты не даешь полной информации. Как конкретно выглядит m?
                      Так и выглядит. Только вместо кавычек quote лог автоматом преобразовывет
                      
                      `~~[code]~~var m = body.match(/data-product="(.*)"/g);[/code]`
                      `~~[code]~~{"id":1204,"price":190,"discountPrice":180,"isBottle":true,"type":"product","count":1}[/code]`[/i]
                      ``` `  ` 
                      1 Reply Last reply Reply Quote 0
                      • Bluefox
                        Bluefox last edited by

                        @instalator:

                        @Bluefox:

                        @instalator:

                        Имеем массив с данными

                        data-product="{"id":2104,"price":250,"discountPrice":240,"isBottle":true,"type":"product","count":1}",

                        data-product="{"id":1204,"price":190,"discountPrice":180,"isBottle":true,"type":"product","count":1}",

                        data-product="{"id":1041,"price":170,"discountPrice":160,"isBottle":true,"type":"product","count":1}",

                        data-product="{"id":3,"price":160,"discountPrice":150,"isBottle":true,"type":"product","count":1}",

                        data-product="{"id":1203,"price":120,"discountPrice":120,"isBottle":true,"type":"product","count":1}"

                        log(JSON.parse(itm)) выдает данные как строку а не как объект, это особенность JSON.parse для массивов?

                        `m.forEach(function(itm, i, arr) {
                                            result[i] = JSON.stringify((itm.replace('data-product="', '').replace(/"/g, '"').slice(0, -1)));
                                            
                                            if (i >= arr.length - 1){
                                                result.forEach(function(itm, i, arr) {
                                                log(JSON.parse(itm));    
                        
                                                });
                                            }
                                        });` 
                        Ты не даешь полной информации. Как конкретно выглядит m?
                        Так и выглядит. Только вместо кавычек quote лог автоматом преобразовывет
                        
                        `~~[code]~~var m = body.match(/data-product="(.*)"/g);[/code]`
                        `~~[code]~~{"id":1204,"price":190,"discountPrice":180,"isBottle":true,"type":"product","count":1}[/code]`
                        один stringify лишний
                        `~~[code]~~result[i] = itm.replace('data-product="', '').replace(/"/g, '"').slice(0, -1);` [/i][/code][/i]
                        ``` `  `  ` 
                        1 Reply Last reply Reply Quote 0
                        • I
                          instalator last edited by

                          @Bluefox:

                          @instalator:

                          @Bluefox:

                          Ты не даешь полной информации. Как конкретно выглядит m? `
                          Так и выглядит. Только вместо кавычек quote лог автоматом преобразовывет

                          var m = body.match(/data-product="(.*)"/g);
                          
                          {"id":1204,"price":190,"discountPrice":180,"isBottle":true,"type":"product","count":1}
                          ```` `  
                          

                          один stringify лишний

                          `result[i] = itm.replace('data-product="', '').replace(/"/g, '"').slice(0, -1);` 
                           :) Решил перестраховаться, а он оказывается может напортачить[/i]
                          ``` ` 
                          1 Reply Last reply Reply Quote 0
                          • H
                            Haus last edited by

                            Народ помогайте, маленький кусочек скрипта. Проблема, сделал пока костыль на PHP чтобы дёргать из базы средние значения температур за определённый период времени. Таких request штук 10 в скрипте все прописаны в начале скрипта, так вот в временном log('Текущая ' + body), log('Средняя ' + body) инфа актуальная но она как бы запаздывает и лог log(circ_title + ': Расчет: ' + temp_base + ', Сред: ' + temp_in + ', Тек: ' + cur_temp) отображает прошлый request из переменных temp_in и cur_temp. Что можно сделать?

                            var room  = 'Heat_control';
                            var tbid    = getIdByName(room + '.temp_base');
                            var shaid  = getIdByName(room + '.temp_in_stair_hall_avr_30min');
                            var ctid    = getIdByName(room + '.cur_temp');
                            
                            function startt() {    
                                var request       = require('request');
                                var circ_title    = 'Дом';
                                var temp_base  = getState(tbid).val;
                                var temp_in      = getState(shaid).val;
                                var cur_temp    = getState(ctid).val;
                                request('http://192.168.1.11/cur_temp.php', function (error, response, body) {
                            	if (!error && response.statusCode == 200) {
                                         setState(ctid, body);
                                         log('Текущая ' + body);
                                    }
                                });
                                // Средняя температура в помещении за 30 минут
                                request('http://192.168.1.11/avr_temp_in_stair_hall.php', function (error, response, body) {
                                    if (!error && response.statusCode == 200) {
                                         setState(shaid, body);
                                         log('Средняя ' + body);
                                    }
                                });
                                // Отладка. Выводим информацию по температурам
                                log(circ_title + ': Расчет: ' + temp_base + ', Сред: ' + temp_in + ', Тек: ' + cur_temp);
                            }
                            setInterval(function() {
                                startt();
                            },30000);
                            
                            
                            1 Reply Last reply Reply Quote 0
                            • Bluefox
                              Bluefox last edited by

                              var request = require('request');
                              var room    = 'Heat_control';
                              var tbid    = getIdByName(room + '.temp_base');
                              var shaid   = getIdByName(room + '.temp_in_stair_hall_avr_30min');
                              var ctid    = getIdByName(room + '.cur_temp');
                              
                              function printDebug() {
                                  var circ_title    = 'Дом';
                              	var temp_base     = getState(tbid).val;
                              	var temp_in       = getState(shaid).val;
                              	var cur_temp      = getState(ctid).val;
                              	log(circ_title + ': Расчет: ' + temp_base + ', Сред: ' + temp_in + ', Тек: ' + cur_temp);
                              }
                              
                              function startt() {    
                              	var count = 0;
                              
                              	count++;
                                  request('http://192.168.1.11/cur_temp.php', function (error, response, body) {
                              		if (!error && response.statusCode == 200) {
                                           setState(ctid, body);
                                           log('Текущая ' + body);
                                      }
                              		count--;
                              		if (!count) printDebug();
                                  });
                              
                                  // Средняя температура в помещении за 30 минут
                              	count++;
                                  request('http://192.168.1.11/avr_temp_in_stair_hall.php', function (error, response, body) {
                                      if (!error && response.statusCode == 200) {
                                           setState(shaid, body);
                                           log('Средняя ' + body);
                                      }
                              		count--;
                              		if (!count) printDebug();
                                  });
                              
                              }
                              setInterval(function() {
                                  startt();
                              },30000);
                              

                              А надо ли вызывать скрипт каждые 30 секунд?

                              1 Reply Last reply Reply Quote 0
                              • H
                                Haus last edited by

                                @Bluefox:

                                var request = require('request');
                                var room    = 'Heat_control';
                                var tbid    = getIdByName(room + '.temp_base');
                                var shaid   = getIdByName(room + '.temp_in_stair_hall_avr_30min');
                                var ctid    = getIdByName(room + '.cur_temp');
                                
                                function printDebug() {
                                    var circ_title    = 'Дом';
                                	var temp_base     = getState(tbid).val;
                                	var temp_in       = getState(shaid).val;
                                	var cur_temp      = getState(ctid).val;
                                	log(circ_title + ': Расчет: ' + temp_base + ', Сред: ' + temp_in + ', Тек: ' + cur_temp);
                                }
                                
                                function startt() {    
                                	var count = 0;
                                	
                                	count++;
                                    request('http://192.168.1.11/cur_temp.php', function (error, response, body) {
                                		if (!error && response.statusCode == 200) {
                                             setState(ctid, body);
                                             log('Текущая ' + body);
                                        }
                                		count--;
                                		if (!count) printDebug();
                                    });
                                	
                                    // Средняя температура в помещении за 30 минут
                                	count++;
                                    request('http://192.168.1.11/avr_temp_in_stair_hall.php', function (error, response, body) {
                                        if (!error && response.statusCode == 200) {
                                             setState(shaid, body);
                                             log('Средняя ' + body);
                                        }
                                		count--;
                                		if (!count) printDebug();
                                    });
                                    
                                }
                                setInterval(function() {
                                    startt();
                                },30000);
                                

                                А надо ли вызывать скрипт каждые 30 секунд? `

                                Не, вызывается каждые 5 минут это я для отладки 30 сек поставил

                                1 Reply Last reply Reply Quote 0
                                • H
                                  Haus last edited by

                                  @Bluefox:

                                  var request = require('request');
                                  var room    = 'Heat_control';
                                  var tbid    = getIdByName(room + '.temp_base');
                                  var shaid   = getIdByName(room + '.temp_in_stair_hall_avr_30min');
                                  var ctid    = getIdByName(room + '.cur_temp');
                                  
                                  function printDebug() {
                                      var circ_title    = 'Дом';
                                  	var temp_base     = getState(tbid).val;
                                  	var temp_in       = getState(shaid).val;
                                  	var cur_temp      = getState(ctid).val;
                                  	log(circ_title + ': Расчет: ' + temp_base + ', Сред: ' + temp_in + ', Тек: ' + cur_temp);
                                  }
                                  
                                  function startt() {    
                                  	var count = 0;
                                  	
                                  	count++;
                                      request('http://192.168.1.11/cur_temp.php', function (error, response, body) {
                                  		if (!error && response.statusCode == 200) {
                                               setState(ctid, body);
                                               log('Текущая ' + body);
                                          }
                                  		count--;
                                  		if (!count) printDebug();
                                      });
                                  	
                                      // Средняя температура в помещении за 30 минут
                                  	count++;
                                      request('http://192.168.1.11/avr_temp_in_stair_hall.php', function (error, response, body) {
                                          if (!error && response.statusCode == 200) {
                                               setState(shaid, body);
                                               log('Средняя ' + body);
                                          }
                                  		count--;
                                  		if (!count) printDebug();
                                      });
                                      
                                  }
                                  setInterval(function() {
                                      startt();
                                  },30000);
                                  

                                  А надо ли вызывать скрипт каждые 30 секунд? `
                                  Спасибо за помощь, но я так и не смог прикрутить это в свой скрипт 😢

                                  Закинул весь скрипт, может будет понятней вопрос взгляни если сможешь http://forum.iobroker.net/viewtopic.php?f=26&t=2646

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

                                    @Haus:

                                    Спасибо за помощь, но я так и не смог прикрутить это в свой скрипт 😢

                                    Закинул весь скрипт, может будет понятней вопрос взгляни если сможешь `

                                    ! ````
                                    var request = require('request');
                                    var room = 'Heat_control';
                                    var tbid = getIdByName(room + '.temp_base');
                                    var shaid = getIdByName(room + '.temp_in_stair_hall_avr_30min');
                                    var ctid = getIdByName(room + '.cur_temp');
                                    ! function printDebug() {
                                    var circ_title = 'Дом';
                                    var temp_base = getState(tbid).val;
                                    var temp_in = getState(shaid).val;
                                    var cur_temp = getState(ctid).val;
                                    log(circ_title + ': Расчет: ' + temp_base + ', Сред: ' + temp_in + ', Тек: ' + cur_temp);
                                    }
                                    ! function startt() {
                                    // var count = 0;

                                    //count++;
                                    request('http://192.168.1.11/cur_temp.php', function (error, response, body) {
                                    if (!error && response.statusCode == 200) {
                                    setState(ctid, body);
                                    log('Текущая ' + body);
                                    // Средняя температура в помещении за 30 минут
                                    // count++;
                                    request('http://192.168.1.11/avr_temp_in_stair_hall.php', function (error, response, body) {
                                    if (!error && response.statusCode == 200) {
                                    setState(shaid, body);
                                    log('Средняя ' + body);
                                    printDebug();
                                    }
                                    // count--;
                                    // if (!count) printDebug();
                                    });
                                    }
                                    // count--;
                                    // if (!count) printDebug();
                                    });

                                    }
                                    setInterval(function() {
                                    startt();
                                    },30000);

                                    1 Reply Last reply Reply Quote 0
                                    • H
                                      Haus last edited by

                                      @instalator:

                                      @Haus:

                                      Спасибо за помощь, но я так и не смог прикрутить это в свой скрипт 😢

                                      Закинул весь скрипт, может будет понятней вопрос взгляни если сможешь `

                                      ! ````
                                      var request = require('request');
                                      var room = 'Heat_control';
                                      var tbid = getIdByName(room + '.temp_base');
                                      var shaid = getIdByName(room + '.temp_in_stair_hall_avr_30min');
                                      var ctid = getIdByName(room + '.cur_temp');
                                      ! function printDebug() {
                                      var circ_title = 'Дом';
                                      var temp_base = getState(tbid).val;
                                      var temp_in = getState(shaid).val;
                                      var cur_temp = getState(ctid).val;
                                      log(circ_title + ': Расчет: ' + temp_base + ', Сред: ' + temp_in + ', Тек: ' + cur_temp);
                                      }
                                      ! function startt() {
                                      // var count = 0;

                                      //count++;
                                      request('http://192.168.1.11/cur_temp.php', function (error, response, body) {
                                      if (!error && response.statusCode == 200) {
                                      setState(ctid, body);
                                      log('Текущая ' + body);
                                      // Средняя температура в помещении за 30 минут
                                      // count++;
                                      request('http://192.168.1.11/avr_temp_in_stair_hall.php', function (error, response, body) {
                                      if (!error && response.statusCode == 200) {
                                      setState(shaid, body);
                                      log('Средняя ' + body);
                                      printDebug();
                                      }
                                      // count--;
                                      // if (!count) printDebug();
                                      });
                                      }
                                      // count--;
                                      // if (!count) printDebug();
                                      });

                                      }
                                      setInterval(function() {
                                      startt();
                                      },30000);
                                      ```` `
                                      Спасибо дружище, забыл дать ссылку http://forum.iobroker.net/viewtopic.php?f=26&t=2646 кусками чего то не выходит.

                                      1 Reply Last reply Reply Quote 0
                                      • L
                                        Lstt last edited by

                                        Возможно ли средствами JavaScript, или отдельно установленным модулем npm загружать типа такого https://github.com/matthewdfuller/fast-image-downloader

                                        Своих заний не хватает..Есть url - http://192.168.0.222:10000/Streaming/ch … 46MTIzNDU= это поток с камер..Хочется их грабить по событию и кидать картинку в Telegram. Кто-нибудь подскажет, возможно это реализовать или нет?

                                        1 Reply Last reply Reply Quote 0
                                        • S
                                          spectrekr last edited by

                                          @Lstt:

                                          Возможно ли средствами JavaScript, или отдельно установленным модулем npm загружать типа такого https://github.com/matthewdfuller/fast-image-downloader

                                          Своих заний не хватает..Есть url - http://192.168.0.222:10000/Streaming/ch … 46MTIzNDU= это поток с камер..Хочется их грабить по событию и кидать картинку в Telegram. Кто-нибудь подскажет, возможно это реализовать или нет? `
                                          А что за камеры? Может они умеют по тревоге складывать файлы на ftp или сетевой хранилище? Тогда можно скриптом мониторить каталог и при появлении новых файлов отсылать их. Если напрямую с камеры брать видео поток, тогда вопрос каким приложением собираетесь реализовывать тревогу? Если просто забирать с камеры картинку и слать, то можно через exec wget забирать картинку и потом слать в telegramm

                                          1 Reply Last reply Reply Quote 0
                                          • L
                                            Lstt last edited by

                                            Спасибо за ответ! Пока интересует статическая картинка по указанному адресу по моему запросу через Telegram. Можно ли по подробней, хотя бы, фрагмент скрипта привести при помощи exec wget?

                                            1 Reply Last reply Reply Quote 0
                                            • First post
                                              Last post

                                            Support us

                                            ioBroker
                                            Community Adapters
                                            Donate

                                            679
                                            Online

                                            31.8k
                                            Users

                                            80.0k
                                            Topics

                                            1.3m
                                            Posts

                                            29
                                            358
                                            87693
                                            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