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

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

Community Forum

donate donate
  1. ioBroker Community Home
  2. Русский
  3. ioBroker
  4. Скрипты
  5. ioBroker скрипты
  6. Вопросы по написанию скриптов

NEWS

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

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

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

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

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

    @kID:

    @spectrekr:

    Раз вы руками создали в корне, то из скрипта уберите CreateState `
    Да я все понял. Я чего хотел показать - что используя одинаковый ID в случае с getState ищется первое вхождение с корня объектов

    а для createState игнорируется все что выше Javascript.X `
    Это так работает функция createState. Создает переменные в инстанции Javascript драйвера.

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

    http://blog.instalator.ru/

    1 Reply Last reply
    0
    • A Offline
      A Offline
      Adav
      wrote on last edited by
      #282

      Появилась задача включать выключать драйвер из скрипта. Необходимость возникла по следующей причине - драйвер, работающий с оборудованием, в случае отключения оборудования продолжает пытаться до него достучаться и слать ошибки в логи. Оборудование не всегда должно быть включенным. Поэтому логично с выключением оборудования принудительно отключать и драйвер, занимающийся его опросом.

      Управление драйвером пробовал делать через setState, к примеру в тесте управления включением-выключением history:

      setState("system.adapter.history.0.alive", true); и setState("system.adapter.history.0.alive", false);

      Оно так работает и я получаю желаемое. Но… отключение драйвера - все нормально, а вот включение всякий раз дает ошибку в логе (но в итоге все равно делает что надо):

      history.0 2017-04-27 11:22:54.125 info starting. Version 1.6.2 in /opt/iobroker/node_modules/iobroker.history, node: v4.8.2

      host.AdavHome 2017-04-27 11:22:53.290 info instance system.adapter.history.0 started with pid 11319

      host.AdavHome 2017-04-27 11:22:23.277 info Restart adapter system.adapter.history.0 because enabled

      host.AdavHome 2017-04-27 11:22:23.276 error instance system.adapter.history.0 terminated with code 7 (Adapter already running)

      host.AdavHome 2017-04-27 11:22:22.402 info instance system.adapter.history.0 started with pid 11285

      host.AdavHome 2017-04-27 11:22:22.402 info "system.adapter.history.0" enabled

      host.AdavHome 2017-04-27 11:22:22.402 info object change system.adapter.history.0

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

      Может есть какой-то способ сделать это иначе или я что-то не так делаю?

      1 Reply Last reply
      0
      • H Offline
        H Offline
        Haus
        wrote on last edited by
        #283

        @Adav:

        Появилась задача включать выключать драйвер из скрипта. Необходимость возникла по следующей причине - драйвер, работающий с оборудованием, в случае отключения оборудования продолжает пытаться до него достучаться и слать ошибки в логи. Оборудование не всегда должно быть включенным. Поэтому логично с выключением оборудования принудительно отключать и драйвер, занимающийся его опросом.

        Управление драйвером пробовал делать через setState, к примеру в тесте управления включением-выключением history:

        setState("system.adapter.history.0.alive", true); и setState("system.adapter.history.0.alive", false);

        Оно так работает и я получаю желаемое. Но… отключение драйвера - все нормально, а вот включение всякий раз дает ошибку в логе (но в итоге все равно делает что надо):

        history.0 2017-04-27 11:22:54.125 info starting. Version 1.6.2 in /opt/iobroker/node_modules/iobroker.history, node: v4.8.2

        host.AdavHome 2017-04-27 11:22:53.290 info instance system.adapter.history.0 started with pid 11319

        host.AdavHome 2017-04-27 11:22:23.277 info Restart adapter system.adapter.history.0 because enabled

        host.AdavHome 2017-04-27 11:22:23.276 error instance system.adapter.history.0 terminated with code 7 (Adapter already running)

        host.AdavHome 2017-04-27 11:22:22.402 info instance system.adapter.history.0 started with pid 11285

        host.AdavHome 2017-04-27 11:22:22.402 info "system.adapter.history.0" enabled

        host.AdavHome 2017-04-27 11:22:22.402 info object change system.adapter.history.0

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

        Может есть какой-то способ сделать это иначе или я что-то не так делаю? `
        alive - это ка бы индикатор для чтения

        В драйвере Javascript включи опцию Разрешить команду "setObject"

        var obj = getObject("system.adapter.history.0");
        obj.common.enabled = false;  //or true
        setObject("system.adapter.history.0", obj);
        
        

        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 Reply Last reply
        0
        • A Offline
          A Offline
          Adav
          wrote on last edited by
          #284

          Разобрался, все работает, спасибо!

          1 Reply Last reply
          0
          • H Offline
            H Offline
            Haus
            wrote on last edited by
            #285

            @Adav:

            Function "setObject" is not allowed. Use adapter settings to allow it.

            В каком месте у адаптера это разрешается? `
            В админке драйвера Javascript включи опцию Разрешить команду "setObject"

            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 Reply Last reply
            0
            • A Offline
              A Offline
              Adav
              wrote on last edited by
              #286

              Оказалось можно одной строкой при той же идее, проверил - нормально!

              extendObject('system.adapter.history.0', {common: {enabled: false}});

              ну и соответственно true

              Еще раз спасибо! :)

              1 Reply Last reply
              0
              • S Offline
                S Offline
                smoker_vvo
                wrote on last edited by
                #287

                Доброго дня. Поможите советом: как запустить скрипт по нажатию кнопки и то же самое по времени.

                1 Reply Last reply
                0
                • H Offline
                  H Offline
                  Haus
                  wrote on last edited by
                  #288

                  @smoker_vvo:

                  Доброго дня. Поможите советом: как запустить скрипт по нажатию кнопки и то же самое по времени. `
                  В vis, виджет кнопка, ID объекта javascript.0.scriptEnabled.scriptname

                  var volumeId = "sayit.0.tts.volume";
                  // Устанавливаем в 6:59 громкость 90
                  schedule("59 6 * * *", function(){
                      setState(volumeId,90,function(){
                         log('Установлена громкость '+ getState(volumeId).val);
                      });
                  });
                  

                  или так

                  // Скрипт запускается каждые 10 сек.
                  function temperatur() {
                      сам скрипт
                  }
                  schedule('*/10 * * * * *', temperatur);
                  temperatur();
                  

                  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 Reply Last reply
                  0
                  • S Offline
                    S Offline
                    smoker_vvo
                    wrote on last edited by
                    #289

                    Ага, спасиб. По времени интересует типа отправить в 7, 12 и 17 часов, а еще сообщить о событии через 30 минут после его начала.

                    Типа включился насос и если через 30 минут он не выключился - ТРЕВОГА…... А если выключился - то молчим в тряпочку.

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

                      @smoker_vvo:

                      Ага, спасиб. По времени интересует типа отправить в 7, 12 и 17 часов, а еще сообщить о событии через 30 минут после его начала.

                      Типа включился насос и если через 30 минут он не выключился - ТРЕВОГА…... А если выключился - то молчим в тряпочку. `
                      Ищи на форуме скрипт часов

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

                      http://blog.instalator.ru/

                      1 Reply Last reply
                      0
                      • S Offline
                        S Offline
                        smoker_vvo
                        wrote on last edited by
                        #291

                        Угум-с и так уже начинаю немецкий изучать :lol: :lol: :lol:

                        1 Reply Last reply
                        0
                        • H Offline
                          H Offline
                          Haus
                          wrote on last edited by
                          #292

                          @smoker_vvo:

                          Угум-с и так уже начинаю немецкий изучать :lol: :lol: :lol: `
                          На русском, в немецкой ветке примеров конечно пабольше :) :)

                          http://forum.iobroker.net/viewtopic.php?f=26&t=495

                          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 Reply Last reply
                          0
                          • S Offline
                            S Offline
                            smoker_vvo
                            wrote on last edited by
                            #293

                            О как! Использую скрипт от electric69 а вот этот топик как то пропустил… Ща попробуем.

                            1 Reply Last reply
                            0
                            • S Offline
                              S Offline
                              smoker_vvo
                              wrote on last edited by
                              #294

                              вопрос. почему этот скрипт шлет сообщения каждую минуту, где я накосячил?

                              schedule("* 7,12,17 * * *", function () {

                              log("Сообщение о температуре дома");

                              //setState (idSayIt, volume+';'+hour+':'+min+';Температура на улице:'+temp2.val+' °');

                              sendTo("telegram.0", "Температура на улице: " +getState("mqtt.0.myhome.Temp.Street").val+' °'+", в Зале: " +getState("mqtt.0.myhome.Temp.Zal").val+' °'+", в Гараже: " +getState("mqtt.0.myhome.Temp.Garage").val+' °'+", на Кухне: " +getState("mqtt.0.myhome.Temp.Kitchen").val+' °'+", на Мансарде :" +getState("mqtt.0.myhome.Temp.Mansarda").val+' °');

                              });

                              По идее должен отправлять в 7, 12 и 17 часов. начинает слать в 7 и потом ежеминутно пока не выключишь. меня хватает на 5 мин. :(

                              1 Reply Last reply
                              0
                              • S Offline
                                S Offline
                                smoker_vvo
                                wrote on last edited by
                                #295

                                лог:

                                javascript.0 2017-05-04 07:11:00.960 info script.js.Статус_Дома.Отчет_о_температуре: Сообщение о температуре дома

                                mqtt.0 2017-05-04 07:10:02.572 info send2Server sayit.0.tts.playing[sayit/0/tts/playing]

                                sayit.0 2017-05-04 07:10:01.867 info saying: 7:10 Пора выходить на работу!

                                javascript.0 2017-05-04 07:10:00.972 info script.js.Статус_Дома.Отчет_о_температуре: Сообщение о температуре дома

                                mqtt.0 2017-05-04 07:10:00.865 info send2Server sayit.0.tts.playing[sayit/0/tts/playing]

                                sayit.0 2017-05-04 07:10:00.849 info saying: C:\ioBroker\node_modules\iobroker.sayit/scifi.mp3

                                mqtt.0 2017-05-04 07:10:00.834 info send2Server sayit.0.tts.text[sayit/0/tts/text]

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

                                  @smoker_vvo:

                                  вопрос. почему этот скрипт шлет сообщения каждую минуту, где я накосячил?

                                  schedule("* 7,12,17 * * *", function () {

                                  log("Сообщение о температуре дома");

                                  //setState (idSayIt, volume+';'+hour+':'+min+';Температура на улице:'+temp2.val+' °');

                                  sendTo("telegram.0", "Температура на улице: " +getState("mqtt.0.myhome.Temp.Street").val+' °'+", в Зале: " +getState("mqtt.0.myhome.Temp.Zal").val+' °'+", в Гараже: " +getState("mqtt.0.myhome.Temp.Garage").val+' °'+", на Кухне: " +getState("mqtt.0.myhome.Temp.Kitchen").val+' °'+", на Мансарде :" +getState("mqtt.0.myhome.Temp.Mansarda").val+' °');

                                  });

                                  По идее должен отправлять в 7, 12 и 17 часов. начинает слать в 7 и потом ежеминутно пока не выключишь. меня хватает на 5 мин. :( `
                                  Потому что код на форуме надо оборачивать в соответствующий тэг, подправьте. https://crontab.guru

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

                                  http://blog.instalator.ru/

                                  1 Reply Last reply
                                  0
                                  • S Offline
                                    S Offline
                                    smoker_vvo
                                    wrote on last edited by
                                    #297
                                    schedule("* 7,12,17 * * *", function () {
                                    log("Сообщение о температуре дома");
                                    //setState (idSayIt, volume+';'+hour+':'+min+';Температура на улице:'+temp2.val+' °');
                                    sendTo("telegram.0", "Температура на улице: " +getState("mqtt.0.myhome.Temp.Street").val+' °'+", в Зале: " +getState("mqtt.0.myhome.Temp.Zal").val+' °'+", в Гараже: " +getState("mqtt.0.myhome.Temp.Garage").val+' °'+", на Кухне: " +getState("mqtt.0.myhome.Temp.Kitchen").val+' °'+", на Мансарде :" +getState("mqtt.0.myhome.Temp.Mansarda").val+' °');
                                    
                                    });
                                    

                                    Учел исправил, за ссылку Зенкуем!! Понял где проблема.

                                    1 Reply Last reply
                                    0
                                    • S Offline
                                      S Offline
                                      smoker_vvo
                                      wrote on last edited by
                                      #298

                                      Доброго времени! Ну я опять с вопросом. вот код:

                                      schedule("0 7/5 * * *", function () {
                                          log("Сообщение о температуре дома");
                                      //setState (idSayIt, volume+';'+hour+':'+min+';Температура на улице:'+temp2.val+' °');
                                          sendTo("telegram.0", "Температура на улице: " +getState("mqtt.0.myhome.Temp.Street").val+' °'+", в Зале: " +getState("mqtt.0.myhome.Temp.Zal").val+' °'+", в Гараже: " +getState("mqtt.0.myhome.Temp.Garage").val+' °'+", на Кухне: " +getState("mqtt.0.myhome.Temp.Kitchen").val+' °'+", на Мансарде :" +getState("mqtt.0.myhome.Temp.Mansarda").val+' °');
                                      
                                      });
                                      

                                      С учетом последних ссылок должно работать в 7, 12, 17 часов… НО! в 7 уведомление получаю, а далее - ни чего. Где искать??

                                      1 Reply Last reply
                                      0
                                      • H Offline
                                        H Offline
                                        Haus
                                        wrote on last edited by
                                        #299

                                        @smoker_vvo:

                                        Доброго времени! Ну я опять с вопросом. вот код:

                                        schedule("0 7/5 * * *", function () {
                                            log("Сообщение о температуре дома");
                                        //setState (idSayIt, volume+';'+hour+':'+min+';Температура на улице:'+temp2.val+' °');
                                            sendTo("telegram.0", "Температура на улице: " +getState("mqtt.0.myhome.Temp.Street").val+' °'+", в Зале: " +getState("mqtt.0.myhome.Temp.Zal").val+' °'+", в Гараже: " +getState("mqtt.0.myhome.Temp.Garage").val+' °'+", на Кухне: " +getState("mqtt.0.myhome.Temp.Kitchen").val+' °'+", на Мансарде :" +getState("mqtt.0.myhome.Temp.Mansarda").val+' °');
                                               
                                        });
                                        

                                        С учетом последних ссылок должно работать в 7, 12, 17 часов… НО! в 7 уведомление получаю, а далее - ни чего. Где искать?? `

                                        schedule("0 7,12,17 * * *", function () {
                                        

                                        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 Reply Last reply
                                        0
                                        • S Offline
                                          S Offline
                                          smoker_vvo
                                          wrote on last edited by
                                          #300

                                          Да, все работает. Но теперь следующая загвоздка. Пытаюсь добавить в сообщение дату код выглядит так:

                                          schedule("*30 6 * * *", function () {
                                            var idSayIt = "sayit.0.tts.text";
                                            //formatDate(new Date(), "WW, dd, mm, yyyy"); // => День недели "Вторник";
                                            var date = new Date();
                                            var day = date.getDay(); // 0-воскр. 6-суббота
                                            var hour = date.getHours();
                                            var min = (date.getMinutes()<10?'0':'') + date.getMinutes(); // если минута меньше 10, то добавляем 0
                                            var volume = 100;
                                                  //setState (idSayIt, volume+';'+hour+':'+min);
                                                  //setState (idSayIt, volume+';'+date);
                                                  sendTo("telegram.0", "Сегодня" +date+ "Статус пожарной сигнализации: " +getState("home.fire_all.color").val);
                                             log('Пожарная сигнализация '+day +date);
                                          
                                          });
                                          

                                          и все бы ни чего, если бы дата не выводилась в таком формате:

                                          Пожарная сигнализация 3Wed May 10 2017 20:14:00 GMT+1000 (RTZ 9 (зима))

                                          как привести к виду: Среда 10 Мая 2017 20:14

                                          1 Reply Last reply
                                          0

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

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

                                          With your input, this post could be even better 💗

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


                                          Support us

                                          ioBroker
                                          Community Adapters
                                          Donate

                                          588

                                          Online

                                          32.7k

                                          Users

                                          82.6k

                                          Topics

                                          1.3m

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

                                          • Don't have an account? Register

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