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
    18
    1
    643

  • 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

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

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.
  • K Offline
    K Offline
    kID
    schrieb am zuletzt editiert von
    #277

    Ну чего-то наворотил, но все же работает как-то не так.

    Скрипт

    reateState('Flag.0.Alarm_10min', false);
    createState('Flag.0.Alarm_5min', false); 
    createState('Flag.0.test', 10); 
    
    setState (("Flag.0.Alarm_5min"), true, true);
    setState (("Flag.0.test"/*test*/), 20, true);
    log("Значение" + getState("Flag.0.test").val);
    

    Если таких объектов нигде нет, то все создается в дереве javascript.0

    И далее с этими объектами работаем как обычно

    Но если я заранее в корне создаю эти объекты

    то получаю следующее
    265__________________.jpg
    или так
    265_______________.jpg
    Т.е создается объект в дереве javascript.0 а работаем уже с объектом из корня.

    Я так понимаю что ситуация как в анекдоте:

    • Чего-то меня последнее время Гондурас беспокоит

    • А вы его поменьше чешите

    Т.е. в корне создавать объекты нельзя!!

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

      @kID:

      Ну чего-то наворотил, но все же работает как-то не так.

      Скрипт

      reateState('Flag.0.Alarm_10min', false);
      createState('Flag.0.Alarm_5min', false); 
      createState('Flag.0.test', 10); 
      
      setState (("Flag.0.Alarm_5min"), true, true);
      setState (("Flag.0.test"/*test*/), 20, true);
      log("Значение" + getState("Flag.0.test").val);
      

      Если таких объектов нигде нет, то все создается в дереве javascript.0

      И далее с этими объектами работаем как обычно

      Но если я заранее в корне создаю эти объекты

      то получаю следующее

      полуторный объект.jpg

      или так

      двойной объект.jpg

      Т.е создается объект в дереве javascript.0 а работаем уже с объектом из корня.

      Я так понимаю что ситуация как в анекдоте:

      • Чего-то меня последнее время Гондурас беспокоит

      • А вы его поменьше чешите

      Т.е. в корне создавать объекты нельзя!! `
      Руками можно

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

      http://blog.instalator.ru/

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

        Раз вы руками создали в корне, то из скрипта уберите CreateState

        1 Antwort Letzte Antwort
        0
        • K Offline
          K Offline
          kID
          schrieb am zuletzt editiert von
          #280

          @spectrekr:

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

          а для createState игнорируется все что выше Javascript.X

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

            @kID:

            @spectrekr:

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

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

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

            http://blog.instalator.ru/

            1 Antwort Letzte Antwort
            0
            • A Offline
              A Offline
              Adav
              schrieb am zuletzt editiert von
              #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 Antwort Letzte Antwort
              0
              • H Offline
                H Offline
                Haus
                schrieb am zuletzt editiert von
                #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 Antwort Letzte Antwort
                0
                • A Offline
                  A Offline
                  Adav
                  schrieb am zuletzt editiert von
                  #284

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

                  1 Antwort Letzte Antwort
                  0
                  • H Offline
                    H Offline
                    Haus
                    schrieb am zuletzt editiert von
                    #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 Antwort Letzte Antwort
                    0
                    • A Offline
                      A Offline
                      Adav
                      schrieb am zuletzt editiert von
                      #286

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

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

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

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

                      1 Antwort Letzte Antwort
                      0
                      • S Offline
                        S Offline
                        smoker_vvo
                        schrieb am zuletzt editiert von
                        #287

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

                        1 Antwort Letzte Antwort
                        0
                        • H Offline
                          H Offline
                          Haus
                          schrieb am zuletzt editiert von
                          #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 Antwort Letzte Antwort
                          0
                          • S Offline
                            S Offline
                            smoker_vvo
                            schrieb am zuletzt editiert von
                            #289

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

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

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

                              @smoker_vvo:

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

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

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

                              http://blog.instalator.ru/

                              1 Antwort Letzte Antwort
                              0
                              • S Offline
                                S Offline
                                smoker_vvo
                                schrieb am zuletzt editiert von
                                #291

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

                                1 Antwort Letzte Antwort
                                0
                                • H Offline
                                  H Offline
                                  Haus
                                  schrieb am zuletzt editiert von
                                  #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 Antwort Letzte Antwort
                                  0
                                  • S Offline
                                    S Offline
                                    smoker_vvo
                                    schrieb am zuletzt editiert von
                                    #293

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

                                    1 Antwort Letzte Antwort
                                    0
                                    • S Offline
                                      S Offline
                                      smoker_vvo
                                      schrieb am zuletzt editiert von
                                      #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 Antwort Letzte Antwort
                                      0
                                      • S Offline
                                        S Offline
                                        smoker_vvo
                                        schrieb am zuletzt editiert von
                                        #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 Antwort Letzte Antwort
                                        0
                                        • I Offline
                                          I Offline
                                          instalator
                                          schrieb am zuletzt editiert von
                                          #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 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

                                          223

                                          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