Weiter zum Inhalt
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • GitHub
  • Docu
  • Hilfe
Skins
  • Hell
  • Brite
  • Cerulean
  • Cosmo
  • Flatly
  • Journal
  • Litera
  • Lumen
  • Lux
  • Materia
  • Minty
  • Morph
  • Pulse
  • Sandstone
  • Simplex
  • Sketchy
  • Spacelab
  • United
  • Yeti
  • Zephyr
  • Dunkel
  • Cyborg
  • Darkly
  • Quartz
  • Slate
  • Solar
  • Superhero
  • Vapor

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
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
    17
    1
    640

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

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

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

Geplant Angeheftet Gesperrt Verschoben ioBroker скрипты
358 Beiträge 29 Kommentatoren 116.1k Aufrufe
  • Älteste zuerst
  • Neuste zuerst
  • Meiste Stimmen
Antworten
  • In einem neuen Thema antworten
Anmelden zum Antworten
Dieses Thema wurde gelöscht. Nur Nutzer mit entsprechenden Rechten können es sehen.
  • S Offline
    S Offline
    spectrekr
    schrieb am zuletzt editiert von
    #133

    И в приведенном выше примере послеconsole.log('done');вставляем````
    sendTo('telegram', 'c:/cameras/camera1.jpg')

    1 Antwort Letzte Antwort
    0
    • L Offline
      L Offline
      Lstt
      schrieb am zuletzt editiert von
      #134

      Да, спасибо большое, заработало! :)

      1 Antwort Letzte Antwort
      0
      • H Offline
        H Offline
        Haus
        schrieb am zuletzt editiert von
        #135

        Почему эта строчка отрабатывает

        else if ( temp_in < temp_base - circ_hyst && cur_temp < temp_base - circ_hyst )
        

        temp_base - circ_hyst получается 19.85

        а эта нет ?

        else if ( temp_in > temp_base + circ_hyst && cur_temp > temp_base + circ_hyst )
        

        temp_base + circ_hyst получается 20.000.15

        js-controller: 1.5.7 / node.js: v8.15.1/ npm: 6.4.1

        admin: 3.6.0

        javascript: 4.1.10

        web: 2.4.1 vis: 1.1.10

        cloud: 2.6.2

        Server: DELL FX170 / linux: Debian 9.5 Stretch

        Adapter: MegaD-2561, Mega-ES…

        1 Antwort Letzte Antwort
        0
        • S Offline
          S Offline
          spectrekr
          schrieb am zuletzt editiert von
          #136

          Потому что их обрабатывает как текстовые, делайте через````
          parseFloat(temp_base) + ParseFloat(circle_hyst)

          1 Antwort Letzte Antwort
          0
          • H Offline
            H Offline
            Haus
            schrieb am zuletzt editiert von
            #137

            @spectrekr:

            Потому что их обрабатывает как текстовые, делайте через````
            parseFloat(temp_base) + ParseFloat(circle_hyst)

            ```` `
            Спасибо spectrekr, с parseFloat конечно работает но это костыль. Проблема заключается в том что я экспериментируя с скриптом заметил странную особенность что иногда всё работает как надо а иногда неправильно. Так как эти переменные часто меняю для всевозможных экспериментов с скриптом по старой привычке менял значение в вкладке "состояние" и всё было хорошо. Когда появилась возможность менять значение переменной в вкладке объекты тут и началось. Bluefox наверно так не должно быть ?

            js-controller: 1.5.7 / node.js: v8.15.1/ npm: 6.4.1

            admin: 3.6.0

            javascript: 4.1.10

            web: 2.4.1 vis: 1.1.10

            cloud: 2.6.2

            Server: DELL FX170 / linux: Debian 9.5 Stretch

            Adapter: MegaD-2561, Mega-ES…

            1 Antwort Letzte Antwort
            0
            • L Offline
              L Offline
              Lstt
              schrieb am zuletzt editiert von
              #138

              @Haus:

              @spectrekr:

              Потому что их обрабатывает как текстовые, делайте через````
              parseFloat(temp_base) + ParseFloat(circle_hyst)

              ```` Спасибо spectrekr, с parseFloat конечно работает но это костыль. Проблема заключается в том что я экспериментируя с скриптом заметил странную особенность что иногда всё работает как надо а иногда неправильно. Так как эти переменные часто меняю для всевозможных экспериментов с скриптом по старой привычке менял значение в вкладке "состояние" и всё было хорошо. Когда появилась возможность менять значение переменной в вкладке объекты тут и началось. Bluefox наверно так не должно быть ?
              Такая же история. Когда меняю значение переменной через Telegram через Text2Command, по логу Text2Command отрабатывает чётко, а вот в скрипте, в котором подписка на изменение переменной - он то сразу сработает, то ровно через 5 мин, то вообще не работает…

              function download (uri, filename, callback){
                request.head(uri, function(err, res, body){
                     request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);
                });
              }
              var fs = require('fs');
              var request = require('request');
              
              on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) {
                  if (!fs.existsSync('C:/cameras/')) {
                 console.error('Directory for cameras does not exist');
              } else {
                download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
                  console.log('Camera 1 copying done!');
                  sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');
                });
                download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){
                  console.log('Camera 2 copying done!');
                  sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg');
                });
               download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){
                  console.log('Camera 3 copying done!');
                  sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg');
                }); 
                download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){
                  console.log('Camera 4 copying done!');
                  sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg');
                });
              }
              
               });
              
              

              Хотя есть код -

               on({id: "mqtt.0.flat129.PIR1", "change": "any"}, function (obj) {
                    pir1 = getState("mqtt.0.flat129.PIR1").val;
                       log('Информацию с дачтка 1 увидели...');
                       var date = new Date();
                       log('OK');
                       sendTo("telegram.0", "Датчик 1!");
              		 log('Датчик 1 отправили!');
                });		
              
              

              отрабатывает чётко и всегда!

              В этих случаях вижу лишь одну разницу (в первом скрипте переменная не подтверждена (false), a во втором подтверждена всегда (true).

              Может в этом причина?

              Может как-то зависит от версии Node.JS?

              1 Antwort Letzte Antwort
              0
              • S Offline
                S Offline
                spectrekr
                schrieb am zuletzt editiert von
                #139

                Я с проблемой текст в цифры столкнулся при подключении счётчика через mqtt клиент, счётчик числа передавал, а скрипт их как слова складывал, вот и пришлось искать решение как явно указать что там числа. По поводу подписки на переменную, тоже имею проблему. Явно меняю переменную, процедура отрабатывает, переменная меняется скриптом - процедура в тишине.

                Отправлено с моего C6603 через Tapatalk

                1 Antwort Letzte Antwort
                0
                • I Offline
                  I Offline
                  instalator
                  schrieb am zuletzt editiert von
                  #140

                  @Lstt:

                  Такая же история. Когда меняю значение переменной через Telegram через Text2Command, по логу Text2Command отрабатывает чётко, а вот в скрипте, в котором подписка на изменение переменной - он то сразу сработает, то ровно через 5 мин, то вообще не работает…

                  function download (uri, filename, callback){
                    request.head(uri, function(err, res, body){
                         request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);
                    });
                  }
                  var fs = require('fs');
                  var request = require('request');
                  
                  on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) {
                      if (!fs.existsSync('C:/cameras/')) {
                     console.error('Directory for cameras does not exist');
                  } else {
                    download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
                      console.log('Camera 1 copying done!');
                      sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');
                    });
                    download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){
                      console.log('Camera 2 copying done!');
                      sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg');
                    });
                   download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){
                      console.log('Camera 3 copying done!');
                      sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg');
                    }); 
                    download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){
                      console.log('Camera 4 copying done!');
                      sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg');
                    });
                  }
                  
                   });
                  
                  ```` `  
                  

                  А что ты пытаешся этим скриптом сделать? сколько времени у тебя отрабатывает функция download ?

                  А если так?

                  ! ````
                  function download (uri, filename, callback){
                  request.head(uri, function(err, res, body){
                  request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);
                  });
                  }
                  var fs = require('fs');
                  var request = require('request');
                  ! on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) {
                  if (!fs.existsSync('C:/cameras/')) {
                  console.error('Directory for cameras does not exist');
                  } else {
                  download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
                  console.log('Camera 1 copying done!');
                  sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');
                  download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){
                  console.log('Camera 2 copying done!');
                  sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg');
                  download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){
                  console.log('Camera 3 copying done!');
                  sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg');
                  download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){
                  console.log('Camera 4 copying done!');
                  sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg');
                  });
                  });
                  });
                  });
                  ! }
                  });

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

                  http://blog.instalator.ru/

                  1 Antwort Letzte Antwort
                  0
                  • I Offline
                    I Offline
                    instalator
                    schrieb am zuletzt editiert von
                    #141

                    @Haus:

                    @spectrekr:

                    Потому что их обрабатывает как текстовые, делайте через````
                    parseFloat(temp_base) + ParseFloat(circle_hyst)

                    ```` Спасибо spectrekr, с parseFloat конечно работает но это костыль. Проблема заключается в том что я экспериментируя с скриптом заметил странную особенность что иногда всё работает как надо а иногда неправильно. Так как эти переменные часто меняю для всевозможных экспериментов с скриптом по старой привычке менял значение в вкладке "состояние" и всё было хорошо. Когда появилась возможность менять значение переменной в вкладке объекты тут и началось. Bluefox наверно так не должно быть ?
                    Это не костыль, это JS

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

                    http://blog.instalator.ru/

                    1 Antwort Letzte Antwort
                    0
                    • L Offline
                      L Offline
                      Lstt
                      schrieb am zuletzt editiert von
                      #142

                      @instalator:

                      А что ты пытаешся этим скриптом сделать? сколько времени у тебя отрабатывает функция download ?

                      А если так?

                      ! function download (uri, filename, callback){ request.head(uri, function(err, res, body){ request(uri).pipe(fs.createWriteStream(filename)).on('close', callback); }); } var fs = require('fs'); var request = require('request'); ! on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) { if (!fs.existsSync('C:/cameras/')) { console.error('Directory for cameras does not exist'); } else { download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){ console.log('Camera 1 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg'); download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){ console.log('Camera 2 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg'); download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){ console.log('Camera 3 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg'); download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){ console.log('Camera 4 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg'); }); }); }); }); ! } }); `
                      Этот скрипт загружает статические картинки с видеокамер, каждая размером 110-250 кб (сек 20-30 всего).

                      Потом кидаю в Telegram.

                      Твой скрипт работает стабильнее ), но всё равно через 2-3 раза…

                      ! javascript-0 2016-04-21 19:27:24 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera1.jpg"
                      ! javascript-0 2016-04-21 19:27:24 info script.js.cameras: Camera 1 copying done!
                      ! javascript-0 2016-04-21 19:27:23 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera2.jpg"
                      ! javascript-0 2016-04-21 19:27:23 info script.js.cameras: Camera 2 copying done!
                      ! javascript-0 2016-04-21 19:27:17 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera3.jpg"
                      ! javascript-0 2016-04-21 19:27:17 info script.js.cameras: Camera 3 copying done!
                      ! javascript-0 2016-04-21 19:27:10 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera4.jpg"
                      ! javascript-0 2016-04-21 19:27:10 info script.js.cameras: Camera 4 copying done!
                      ! mqtt-0 2016-04-21 19:27:02 info send2Server admin.1.send_cameras[admin/1/send_cameras]
                      ! text2command-0 2016-04-21 19:27:02 info sendTo "send" to system.adapter.telegram.0 from system.adapter.text2command.0: {"text":"стройка","id":60629447,"user":"ссс","response":""}
                      ! text2command-0 2016-04-21 19:27:02 info Say ID admin.1.send_cameras: true
                      ! text2command-0 2016-04-21 19:27:02 info processText: "камеры"
                      C одной камерой такая же ерунда..

                      ! ````
                      function download (uri, filename, callback){
                      request.head(uri, function(err, res, body){
                      request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);
                      });
                      }
                      var fs = require('fs');
                      var request = require('request');
                      ! on({id:"admin.1.send_cameras", change: 'any'}, function (obj) {
                      if (!fs.existsSync('C:/cameras/')) {
                      console.error('Directory for cameras does not exist');
                      } else {
                      download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
                      console.log('Camera 1 copying done!');
                      sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');

                      });
                      

                      ! }
                      });

                      1 Antwort Letzte Antwort
                      0
                      • H Offline
                        H Offline
                        Haus
                        schrieb am zuletzt editiert von
                        #143

                        @instalator:

                        @Haus:

                        @spectrekr:

                        Потому что их обрабатывает как текстовые, делайте через````
                        parseFloat(temp_base) + ParseFloat(circle_hyst)

                        ```` Спасибо spectrekr, с parseFloat конечно работает но это костыль. Проблема заключается в том что я экспериментируя с скриптом заметил странную особенность что иногда всё работает как надо а иногда неправильно. Так как эти переменные часто меняю для всевозможных экспериментов с скриптом по старой привычке менял значение в вкладке "состояние" и всё было хорошо. Когда появилась возможность менять значение переменной в вкладке объекты тут и началось. Bluefox наверно так не должно быть ?
                        Это не костыль, это JS `
                        Костыль :) я имел виду в else if ( temp_in > (parseFloat(temp_base) + parseFloat(circ_hyst)) && cur_temp > (parseFloat(temp_base) + parseFloat(circ_hyst)) ) , проблема оказалось в возможности менять значение переменной в вкладке объекты. Тут скорей всего недоработка какая та. :?:

                        PS. Вот и немцы пишут

                        paul53 писал (а):
                        Как вы проверить? Надеюсь , не изменять значения в закладке "Объекты", потому что он работает (пока) не должным образом.
                        

                        js-controller: 1.5.7 / node.js: v8.15.1/ npm: 6.4.1

                        admin: 3.6.0

                        javascript: 4.1.10

                        web: 2.4.1 vis: 1.1.10

                        cloud: 2.6.2

                        Server: DELL FX170 / linux: Debian 9.5 Stretch

                        Adapter: MegaD-2561, Mega-ES…

                        1 Antwort Letzte Antwort
                        0
                        • I Offline
                          I Offline
                          instalator
                          schrieb am zuletzt editiert von
                          #144

                          @Lstt:

                          @instalator:

                          А что ты пытаешся этим скриптом сделать? сколько времени у тебя отрабатывает функция download ?

                          А если так?

                          ! function download (uri, filename, callback){ request.head(uri, function(err, res, body){ request(uri).pipe(fs.createWriteStream(filename)).on('close', callback); }); } var fs = require('fs'); var request = require('request'); ! on({id:'javascript.0.send_cameras', change: 'any'}, function (obj) { if (!fs.existsSync('C:/cameras/')) { console.error('Directory for cameras does not exist'); } else { download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){ console.log('Camera 1 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg'); download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){ console.log('Camera 2 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg'); download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){ console.log('Camera 3 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg'); download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){ console.log('Camera 4 copying done!'); sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg'); }); }); }); }); ! } }); `
                          Этот скрипт загружает статические картинки с видеокамер, каждая размером 110-250 кб (сек 20-30 всего).

                          Потом кидаю в Telegram.

                          Твой скрипт работает стабильнее ), но всё равно через 2-3 раза…

                          ! javascript-0 2016-04-21 19:27:24 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera1.jpg"
                          ! javascript-0 2016-04-21 19:27:24 info script.js.cameras: Camera 1 copying done!
                          ! javascript-0 2016-04-21 19:27:23 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera2.jpg"
                          ! javascript-0 2016-04-21 19:27:23 info script.js.cameras: Camera 2 copying done!
                          ! javascript-0 2016-04-21 19:27:17 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera3.jpg"
                          ! javascript-0 2016-04-21 19:27:17 info script.js.cameras: Camera 3 copying done!
                          ! javascript-0 2016-04-21 19:27:10 info sendTo "send" to system.adapter.telegram.0 from system.adapter.javascript.0: "C:/Users/User/Pictures/camera4.jpg"
                          ! javascript-0 2016-04-21 19:27:10 info script.js.cameras: Camera 4 copying done!
                          ! mqtt-0 2016-04-21 19:27:02 info send2Server admin.1.send_cameras[admin/1/send_cameras]
                          ! text2command-0 2016-04-21 19:27:02 info sendTo "send" to system.adapter.telegram.0 from system.adapter.text2command.0: {"text":"стройка","id":60629447,"user":"ссс","response":""}
                          ! text2command-0 2016-04-21 19:27:02 info Say ID admin.1.send_cameras: true
                          ! text2command-0 2016-04-21 19:27:02 info processText: "камеры"
                          C одной камерой такая же ерунда..

                          ! ````
                          function download (uri, filename, callback){
                          request.head(uri, function(err, res, body){
                          request(uri).pipe(fs.createWriteStream(filename)).on('close', callback);
                          });
                          }
                          var fs = require('fs');
                          var request = require('request');
                          ! on({id:"admin.1.send_cameras", change: 'any'}, function (obj) {
                          if (!fs.existsSync('C:/cameras/')) {
                          console.error('Directory for cameras does not exist');
                          } else {
                          download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
                          console.log('Camera 1 copying done!');
                          sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');

                          });
                          

                          ! }
                          });
                          ```` ` что значит через два три раза? Может у тебя ошибкой завершается копирование? Ты не ловиш в скрипте ошибки а отрабатываешь код дальше

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

                          http://blog.instalator.ru/

                          1 Antwort Letzte Antwort
                          0
                          • L Offline
                            L Offline
                            Lstt
                            schrieb am zuletzt editiert von
                            #145

                            Дело в скрипте, это работает чётко:

                            var fs = require('fs'),
                            request = require('request');
                            
                            var download = function(uri, filename, callback){
                            
                              var r = request({
                                url: uri,
                                headers: {
                                  'accept': 'image/*',
                                  'user-agent': 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_10_2) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/41.0.2272.118 Safari/537.36',
                                }
                              }).pipe(fs.createWriteStream(filename));
                              r.on('error', function(err) {console.log(err)})
                              r.on('close', callback);
                            };
                            
                            on({id:"admin.1.send_cameras", change: 'any'}, function (obj) {
                            download('http://192.168.0.222:10000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera1.jpg', function(){
                              console.log('Сamera 1 copying done');
                              sendTo("telegram.0", 'C:/Users/User/Pictures/camera1.jpg');
                              });
                            
                             download('http://192.168.0.222:11000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera2.jpg', function(){
                                console.log('Camera 2 copying done!');
                                sendTo("telegram.0", 'C:/Users/User/Pictures/camera2.jpg');
                              });
                             download('http://192.168.0.222:13000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera3.jpg', function(){
                                console.log('Camera 3 copying done!');
                                sendTo("telegram.0", 'C:/Users/User/Pictures/camera3.jpg');
                              }); 
                              download('http://192.168.0.222:14000/Streaming/channels/1/picture?snapShotImageType=JPEG?auth=YWRtaW46MTIzNDU=', 'C:/Users/User/Pictures/camera4.jpg', function(){
                                console.log('Camera 4 copying done!');
                                sendTo("telegram.0", 'C:/Users/User/Pictures/camera4.jpg');
                            });
                            });
                            
                            
                            1 Antwort Letzte Antwort
                            0
                            • H Offline
                              H Offline
                              Haus
                              schrieb am zuletzt editiert von
                              #146

                              Записываю в log_heat.txt "log_heat", может как то по другому надо ? ( log_heat может быть много, в зависимости от условий по скрипту)

                              function getTimeAsString(d) {
                                  var date = d || new Date();
                                  return ('0' + (date.getMonth() + 1)).slice(-2) + '/' + ('0' + date.getDate()).slice(-2) + ' '+ ('0' + date.getHours()).slice(-2) + ':' + ('0' + date.getMinutes()).slice(-2) + ':' +  ('0' + date.getSeconds()).slice(-2);
                              }
                              
                              function script (addTimestamp) {
                                  var fs = require('fs');
                                  var log_heat;
                                  log_heat = ( getTimeAsString() + ' ' + 'Температура бака');
                                  fs.appendFileSync('//opt//log_heat.txt', log_heat + "\n");
                              
                                  log_heat = ( getTimeAsString() + ' ' + 'Температура бакаaaaaaaaaaaaaa');
                                  fs.appendFileSync('//opt//log_heat.txt', log_heat + "\n");
                              }    
                              
                              function start () {
                                  var request = require ( 'request' );
                                  request ( 'http://192.168.1.11/avr_temp_out.php', function ( error, response, body ) {
                                      if ( !error && response.statusCode == 200 ) {
                                          //setState ( toaid, body );
                                          log('1 avr_temp_out: ' + body);
                                      }
                                      setTimeout ( function () {
                                          script ();
                                          }, 1000 );
                                  });
                              }
                              setInterval ( function () {
                                  start ();
                              }, 30000 );
                              

                              js-controller: 1.5.7 / node.js: v8.15.1/ npm: 6.4.1

                              admin: 3.6.0

                              javascript: 4.1.10

                              web: 2.4.1 vis: 1.1.10

                              cloud: 2.6.2

                              Server: DELL FX170 / linux: Debian 9.5 Stretch

                              Adapter: MegaD-2561, Mega-ES…

                              1 Antwort Letzte Antwort
                              0
                              • S Offline
                                S Offline
                                spectrekr
                                schrieb am zuletzt editiert von
                                #147

                                Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.

                                on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) {
                                    if (getState('admin.0.info.updatesNumber').val > 0){
                                        sendTo('telegram', obj.val);
                                        log(obj.val);
                                    }
                                });
                                
                                
                                1 Antwort Letzte Antwort
                                0
                                • aurodionovA Offline
                                  aurodionovA Offline
                                  aurodionov
                                  schrieb am zuletzt editiert von
                                  #148

                                  @spectrekr:

                                  Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.

                                  on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) {
                                      if (getState('admin.0.info.updatesNumber').val > 0){
                                          sendTo('telegram', obj.val);
                                          log(obj.val);
                                      }
                                  });
                                  
                                  ```` `  
                                  

                                  Вроде id: лишние

                                  Пишу с пульта….

                                  Пишу с пульта….

                                  1 Antwort Letzte Antwort
                                  0
                                  • S Offline
                                    S Offline
                                    spectrekr
                                    schrieb am zuletzt editiert von
                                    #149

                                    Так везде и всегда так подписываюсь на изменения, и в примерах так описано. Да и он отслеживает изменения и запускает на выполнение, только вот, насколько я понял, значение объекта в текст не может перевести.

                                    1 Antwort Letzte Antwort
                                    0
                                    • I Offline
                                      I Offline
                                      instalator
                                      schrieb am zuletzt editiert von
                                      #150

                                      @spectrekr:

                                      Так везде и всегда так подписываюсь на изменения, и в примерах так описано. Да и он отслеживает изменения и запускает на выполнение, только вот, насколько я понял, значение объекта в текст не может перевести. `
                                      Obj.val.toString()

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

                                      http://blog.instalator.ru/

                                      1 Antwort Letzte Antwort
                                      0
                                      • I Offline
                                        I Offline
                                        instalator
                                        schrieb am zuletzt editiert von
                                        #151

                                        @spectrekr:

                                        Хочу заставить бота слать информацию об обновлении, подписываюсь на драйвер, а он либо undefined присылает, либо вообще молчит.

                                        on({id: 'admin.0.info.updatesList', change: 'any'}, function (obj) {
                                            if (getState('admin.0.info.updatesNumber').val > 0){
                                                sendTo('telegram', obj.val);
                                                log(obj.val);
                                            }
                                        });
                                        
                                        ```` `  
                                        
                                        on({id: 'admin.0.info.updatesNumber', change: 'any'}, function (obj) {
                                            if (obj.newState.val > 0){
                                                sendTo('telegram', (obj.newState.val).toString());
                                                log(obj.newState.val);
                                            }
                                        });
                                        

                                        А если так?

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

                                        http://blog.instalator.ru/

                                        1 Antwort Letzte Antwort
                                        0
                                        • S Offline
                                          S Offline
                                          spectrekr
                                          schrieb am zuletzt editiert von
                                          #152

                                          Сейчас поставил по-первому способу, если не пойдет, буду пробовать вторым способом. Осталось дождаться какого нибудь обновления :-)

                                          1 Antwort Letzte Antwort
                                          0

                                          Hey! Du scheinst an dieser Unterhaltung interessiert zu sein, hast aber noch kein Konto.

                                          Hast du es satt, bei jedem Besuch durch die gleichen Beiträge zu scrollen? Wenn du dich für ein Konto anmeldest, kommst du immer genau dorthin zurück, wo du zuvor warst, und kannst dich über neue Antworten benachrichtigen lassen (entweder per E-Mail oder Push-Benachrichtigung). Du kannst auch Lesezeichen speichern und Beiträge positiv bewerten, um anderen Community-Mitgliedern deine Wertschätzung zu zeigen.

                                          Mit deinem Input könnte dieser Beitrag noch besser werden 💗

                                          Registrieren Anmelden
                                          Antworten
                                          • In einem neuen Thema antworten
                                          Anmelden zum Antworten
                                          • Älteste zuerst
                                          • Neuste zuerst
                                          • Meiste Stimmen


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          344

                                          Online

                                          32.7k

                                          Benutzer

                                          82.6k

                                          Themen

                                          1.3m

                                          Beiträge
                                          Community
                                          Impressum | Datenschutz-Bestimmungen | Nutzungsbedingungen | Einwilligungseinstellungen
                                          ioBroker Community 2014-2025
                                          logo
                                          • Anmelden

                                          • Du hast noch kein Konto? Registrieren

                                          • Anmelden oder registrieren, um zu suchen
                                          • Erster Beitrag
                                            Letzter Beitrag
                                          0
                                          • Home
                                          • Aktuell
                                          • Tags
                                          • Ungelesen 0
                                          • Kategorien
                                          • Unreplied
                                          • Beliebt
                                          • GitHub
                                          • Docu
                                          • Hilfe