Skip to content
  • Home
  • Aktuell
  • Tags
  • 0 Ungelesen 0
  • Kategorien
  • Unreplied
  • Beliebt
  • 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

  • Standard: (Kein Skin)
  • Kein Skin
Einklappen
ioBroker Logo

Community Forum

donate donate
  1. ioBroker Community Home
  2. Deutsch
  3. ioBroker Allgemein
  4. Frage: "Workflow" für Steuerung über Alexa

NEWS

  • Weihnachtsangebot 2025! 🎄
    BluefoxB
    Bluefox
    24
    1
    1.3k

  • UPDATE 31.10.: Amazon Alexa - ioBroker Skill läuft aus ?
    apollon77A
    apollon77
    48
    3
    9.3k

  • Monatsrückblick – September 2025
    BluefoxB
    Bluefox
    14
    1
    2.6k

Frage: "Workflow" für Steuerung über Alexa

Geplant Angeheftet Gesperrt Verschoben ioBroker Allgemein
alexa
10 Beiträge 2 Kommentatoren 1.0k Aufrufe 1 Watching
  • Ä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.
  • D Offline
    D Offline
    do1osc
    schrieb am zuletzt editiert von
    #1

    Hallo,
    wie macht ihr die Sprachsteuerung mit Alexa?

    Bisher habe ich immer bool-Datenpunkte angelegt, und dann ein Skript geschrieben, das dann das Ergebnis als Sprache über Alma ausgibt. Den Datenpunkt habe ich dann über ein "Gerät" im IOT-Adapter gesteuert. Damit ich nicht immer "einschalten" hinterher sagen muss, habe ich dafür noch eine Routine über die Alexa-App angelegt.
    Das heiß, ich brauche nur zu sagen "Alexa, Balkon Temperatur Aktuell"

    Nun muss ich aber alles einmal neu machen, und dieser Weg scheint mir sehr aufwendig.
    Es gibt ja noch das Custom-IoBroker-Skill, aber das hat irgendwie Probleme mit PUNKT und KOMMA. Außerdem muss man dann immer sagen: "Alexa, frage IoBroker nach Balkon Temperatur Aktuell".

    Das ist aus meiner Sicht auch nicht sehr schön, aber etwas einfacher (komfortabler) als Routinen mit der App anzulegen.

    Wie macht ihr das ? Gibt es noch eine andere Möglichkeit ?

    PS: Ich habe aktuell ca. 150 Geräte-Einträge im IOT.

    dslraserD 1 Antwort Letzte Antwort
    0
    • D do1osc

      Hallo,
      wie macht ihr die Sprachsteuerung mit Alexa?

      Bisher habe ich immer bool-Datenpunkte angelegt, und dann ein Skript geschrieben, das dann das Ergebnis als Sprache über Alma ausgibt. Den Datenpunkt habe ich dann über ein "Gerät" im IOT-Adapter gesteuert. Damit ich nicht immer "einschalten" hinterher sagen muss, habe ich dafür noch eine Routine über die Alexa-App angelegt.
      Das heiß, ich brauche nur zu sagen "Alexa, Balkon Temperatur Aktuell"

      Nun muss ich aber alles einmal neu machen, und dieser Weg scheint mir sehr aufwendig.
      Es gibt ja noch das Custom-IoBroker-Skill, aber das hat irgendwie Probleme mit PUNKT und KOMMA. Außerdem muss man dann immer sagen: "Alexa, frage IoBroker nach Balkon Temperatur Aktuell".

      Das ist aus meiner Sicht auch nicht sehr schön, aber etwas einfacher (komfortabler) als Routinen mit der App anzulegen.

      Wie macht ihr das ? Gibt es noch eine andere Möglichkeit ?

      PS: Ich habe aktuell ca. 150 Geräte-Einträge im IOT.

      dslraserD Offline
      dslraserD Offline
      dslraser
      Forum Testing Most Active
      schrieb am zuletzt editiert von
      #2

      @do1osc
      Ich habe aktuell in der Alexa App über iot
      Bildschirmfoto 2020-04-09 um 11.27.05.png
      Auch ich habe einige Routinen, aber nicht so viele. Ca. 70 Geräte sind alleine für die Fernseher Sender Steuerung. Da habe ich jeweils einen eigenen Datenpunkt als Button angelegt und in iot als Switch. Die Sender/SmartNamen in iot heißen dann auch so wie sie geschaltet werden.

      Beispiele:

      Bildschirmfoto 2020-04-09 um 11.33.23.png

      Da reicht dann der Befehl: "Alexa, rtl an" Das ist dann alles ohne Routine möglich.
      Nur da, wo ich das "an" nicht sagen möchte, z.B. Alexa, wie ist die Temperatur im Garten, oder Alexa, welche Fenster sind noch auf, da habe ich eine Routine angelegt und den SmartNamen so gewählt, das Alex ihn sowieso nicht verstehen würde und sie es somit nicht verwechseln kann.

      Beispiele für Ansagen:

      Bildschirmfoto 2020-04-09 um 11.39.16.png

      Alle anderen Geräte sind oft über die entsprechenden Adapter mit den passenden Namen und Funktionen (ohne Routinen, z.B. Heizung/Licht usw.)

      Beispiel Licht über HUE Adapter Lampen

      Bildschirmfoto 2020-04-09 um 11.41.28.png

      1 Antwort Letzte Antwort
      0
      • D Offline
        D Offline
        do1osc
        schrieb am zuletzt editiert von
        #3

        @dslraser Wie hast du das denn mit dem Auslesen der von Alexa empfangenen Befehle gemacht ?
        Für jeden Text ein onChange-Trigger ?

        dslraserD 1 Antwort Letzte Antwort
        0
        • D do1osc

          @dslraser Wie hast du das denn mit dem Auslesen der von Alexa empfangenen Befehle gemacht ?
          Für jeden Text ein onChange-Trigger ?

          dslraserD Offline
          dslraserD Offline
          dslraser
          Forum Testing Most Active
          schrieb am zuletzt editiert von
          #4

          @do1osc sagte in Frage: "Workflow" für Steuerung über Alexa:

          @dslraser Wie hast du das denn mit dem Auslesen der von Alexa empfangenen Befehle gemacht ?
          Für jeden Text ein onChange-Trigger ?

          Wie meinst Du das ? Wo habe ich das geschrieben ?

          1 Antwort Letzte Antwort
          0
          • D Offline
            D Offline
            do1osc
            schrieb am zuletzt editiert von
            #5

            @dslraser Naja, du musst ja die Texte abfrage, und vergleichen in einem Script, um dann die Entsprechenden Aktionen auszuführen. Ich würde das in einem Script machen mit einer Switch-Case-Anweisung, um dann die Datenpunkte entsprechend zu setzen, welche die einzelnen Aktionen starten.
            Hast du das auch so gemacht ?

            dslraserD 2 Antworten Letzte Antwort
            0
            • D do1osc

              @dslraser Naja, du musst ja die Texte abfrage, und vergleichen in einem Script, um dann die Entsprechenden Aktionen auszuführen. Ich würde das in einem Script machen mit einer Switch-Case-Anweisung, um dann die Datenpunkte entsprechend zu setzen, welche die einzelnen Aktionen starten.
              Hast du das auch so gemacht ?

              dslraserD Offline
              dslraserD Offline
              dslraser
              Forum Testing Most Active
              schrieb am zuletzt editiert von dslraser
              #6

              @do1osc sagte in Frage: "Workflow" für Steuerung über Alexa:

              Naja, du musst ja die Texte abfrage, und vergleichen in einem Script, um dann die Entsprechenden Aktionen auszuführen.

              Ich mache keine Textvergleiche (in der History/Summary oder ähnlich, nur in wenigen Fällen)
              Ich versuche es nochmal zu beschreiben.

              Ich lege mir z.B. für einen Fernsehsender einen eigenen Datenpunkt als Button an. Dann ein kleines Blockly mit Trigger auf den Button (Trigger auf wurde aktualisiert) Den Datenpunkt legt das Blockly gleich mit an, samt SmartNamen für den IOT Adapter. Das SmartGerät ist dann nach dem ersten Blockly start schon im IOT(als Switch im IOT, obwohl es ein Button ist)
              Danach dann noch den Befehl, Alexa, suche neue Geräte und der Sender z.B. r. t. l. wird gefunden. Es ist dann nichts weiter nötig. Alexa, r. t. l. an
              Das Gerät wird erkannt und "geschaltet". Der eigene Datenpunkt wird aktualisiert und das Blockly wird ausgeführt.

              1 Antwort Letzte Antwort
              0
              • D do1osc

                @dslraser Naja, du musst ja die Texte abfrage, und vergleichen in einem Script, um dann die Entsprechenden Aktionen auszuführen. Ich würde das in einem Script machen mit einer Switch-Case-Anweisung, um dann die Datenpunkte entsprechend zu setzen, welche die einzelnen Aktionen starten.
                Hast du das auch so gemacht ?

                dslraserD Offline
                dslraserD Offline
                dslraser
                Forum Testing Most Active
                schrieb am zuletzt editiert von dslraser
                #7

                @do1osc sagte in Frage: "Workflow" für Steuerung über Alexa:

                Hast du das auch so gemacht ?

                Nein.

                Hier noch ein praktisches Beispiel, bleiben wir beim Fernsehsender RTL.

                Eigene Datenpunkte (hier unter 0_userdata.0)

                Bildschirmfoto 2020-04-10 um 09.10.07.png

                Das Blockly dafür. Hier dürfen zwei ECHOS (Wohnzimmer und Küche) die Sender auf der VU im Wohnzimmer schalten, aber nur wenn die VU (SAT Box) auch an ist. Der untere Teil ist für eine zweite VU im Schlafzimmer.

                Bildschirmfoto 2020-04-10 um 09.07.36.png

                IOT SmartGerät

                Bildschirmfoto 2020-04-10 um 09.10.41.png

                Alexa, schalte r. t. l. an (meistens reicht aber auch Alexa r. t. l. an)

                Test Blockly, wo der Erfolg ins Log geschrieben wird.
                Bildschirmfoto 2020-04-10 um 09.20.26.png

                Bildschirmfoto 2020-04-10 um 09.11.12.png

                <xml xmlns="http://www.w3.org/1999/xhtml">
                 <block type="procedures_defcustomnoreturn" id="P8Wvq+IZ;O;QkSBhUR6d" x="113" y="137">
                   <mutation statements="false"></mutation>
                   <field name="NAME">DP_anlegen</field>
                   <field name="SCRIPT">/**
 * Create states under 0_userdata.0 or javascript.x
 * Current Version:     https://github.com/Mic-M/iobroker.createUserStates
 * Support:             https://forum.iobroker.net/topic/26839/
 * Autor:               Mic (ioBroker) | Mic-M (github)
 * Version:             1.1 (26 January 2020)
 * Example:             see https://github.com/Mic-M/iobroker.createUserStates#beispiel
 * -----------------------------------------------
 * PLEASE NOTE: Per https://github.com/ioBroker/ioBroker.javascript/issues/474, the used function setObject() 
 *              executes the callback PRIOR to completing the state creation. Therefore, we use a setTimeout and counter. 
 * -----------------------------------------------
 * @param {string} where          Where to create the state: '0_userdata.0' or 'javascript.x'.
 * @param {boolean} force         Force state creation (overwrite), if state is existing.
 * @param {array} statesToCreate  State(s) to create. single array or array of arrays
 * @param {object} [callback]     Optional: a callback function -- This provided function will be executed after all states are created.
 */
function createUserStates(where, force, statesToCreate, callback = undefined) {
 
    const WARN = false; // Only for 0_userdata.0: Throws warning in log, if state is already existing and force=false. Default is false, so no warning in log, if state exists.
    const LOG_DEBUG = false; // To debug this function, set to true
    // Per issue #474 (https://github.com/ioBroker/ioBroker.javascript/issues/474), the used function setObject() executes the callback 
    // before the state is actual created. Therefore, we use a setTimeout and counter as a workaround.
    const DELAY = 50; // Delay in milliseconds (ms). Increase this to 100, if it is not working.

    // Validate "where"
    if (where.endsWith('.')) where = where.slice(0, -1); // Remove trailing dot
    if ( (where.match(/^((javascript\.([1-9][0-9]|[0-9]))$|0_userdata\.0$)/) == null) ) {
        log('This script does not support to create states under [' + where + ']', 'error');
        return;
    }

    // Prepare "statesToCreate" since we also allow a single state to create
    if(!Array.isArray(statesToCreate[0])) statesToCreate = [statesToCreate]; // wrap into array, if just one array and not inside an array

    // Add "where" to STATES_TO_CREATE
    for (let i = 0; i < statesToCreate.length; i++) {
        let lpPath = statesToCreate[i][0].replace(/\.*\./g, '.'); // replace all multiple dots like '..', '...' with a single '.'
        lpPath = lpPath.replace(/^((javascript\.([1-9][0-9]|[0-9])\.)|0_userdata\.0\.)/,'') // remove any javascript.x. / 0_userdata.0. from beginning
        lpPath = where + '.' + lpPath; // add where to beginning of string
        statesToCreate[i][0] = lpPath;
    }

    if (where != '0_userdata.0') {
        // Create States under javascript.x
        let numStates = statesToCreate.length;
        statesToCreate.forEach(function(loopParam) {
            if (LOG_DEBUG) log('[Debug] Now we are creating new state [' + loopParam[0] + ']');
            let loopInit = (loopParam[1]['def'] == undefined) ? null : loopParam[1]['def']; // mimic same behavior as createState if no init value is provided
            createState(loopParam[0], loopInit, force, loopParam[1], function() {
                numStates--;
                if (numStates === 0) {
                    if (LOG_DEBUG) log('[Debug] All states processed.');
                    if (typeof callback === 'function') { // execute if a function was provided to parameter callback
                        if (LOG_DEBUG) log('[Debug] Function to callback parameter was provided');
                        return callback();
                    } else {
                        return;
                    }
                }
            });
        });
    } else {
        // Create States under 0_userdata.0
        let numStates = statesToCreate.length;
        let counter = -1;
        statesToCreate.forEach(function(loopParam) {
            counter += 1;
            if (LOG_DEBUG) log ('[Debug] Currently processing following state: [' + loopParam[0] + ']');
            if( ($(loopParam[0]).length > 0) && (existsState(loopParam[0])) ) { // Workaround due to https://github.com/ioBroker/ioBroker.javascript/issues/478
                // State is existing.
                if (WARN && !force) log('State [' + loopParam[0] + '] is already existing and will no longer be created.', 'warn');
                if (!WARN && LOG_DEBUG) log('[Debug] State [' + loopParam[0] + '] is already existing. Option force (=overwrite) is set to [' + force + '].');
                if(!force) {
                    // State exists and shall not be overwritten since force=false
                    // So, we do not proceed.
                    numStates--;
                    if (numStates === 0) {
                        if (LOG_DEBUG) log('[Debug] All states successfully processed!');
                        if (typeof callback === 'function') { // execute if a function was provided to parameter callback
                            if (LOG_DEBUG) log('[Debug] An optional callback function was provided, which we are going to execute now.');
                            return callback();
                        }
                    } else {
                        // We need to go out and continue with next element in loop.
                        return; // https://stackoverflow.com/questions/18452920/continue-in-cursor-foreach
                    }
                } // if(!force)
            }

            // State is not existing or force = true, so we are continuing to create the state through setObject().
            let obj = {};
            obj.type = 'state';
            obj.native = {};
            obj.common = loopParam[1];
            setObject(loopParam[0], obj, function (err) {
                if (err) {
                    log('Cannot write object for state [' + loopParam[0] + ']: ' + err);
                } else {
                    if (LOG_DEBUG) log('[Debug] Now we are creating new state [' + loopParam[0] + ']')
                    let init = null;
                    if(loopParam[1].def === undefined) {
                        if(loopParam[1].type === 'number') init = 0;
                        if(loopParam[1].type === 'boolean') init = false;
                        if(loopParam[1].type === 'string') init = '';
                    } else {
                        init = loopParam[1].def;
                    }
                    setTimeout(function() {
                        setState(loopParam[0], init, true, function() {
                            if (LOG_DEBUG) log('[Debug] setState durchgeführt: ' + loopParam[0]);
                            numStates--;
                            if (numStates === 0) {
                                if (LOG_DEBUG) log('[Debug] All states processed.');
                                if (typeof callback === 'function') { // execute if a function was provided to parameter callback
                                    if (LOG_DEBUG) log('[Debug] Function to callback parameter was provided');
                                    return callback();
                                }
                            }
                        });
                    }, DELAY + (20 * counter) );
                }
            });
        });
    }
}

let statesToCreate = [
    ['TV_System.VU.Sender.05RTL', {'name':'05RTL', 'type':'boolean', 'read':true, 'write':true, 'role':'button', 'def':true, "smartName": {"de": " r. t. l. ","smartType": "SWITCH"} }],
    
];    
createUserStates('0_userdata.0', true, statesToCreate);
</field>
                   <comment pinned="false" h="80" w="160">Beschreibe diese Funktion …</comment>
                 </block>
                 <block type="procedures_callcustomnoreturn" id="%p%Gz[YgiI]6-UL4u}:`" disabled="true" x="113" y="187">
                   <mutation name="DP_anlegen"></mutation>
                   <next>
                     <block type="on_ext" id="?/e)8GsBz`VGVn]:[8OQ">
                       <mutation items="1"></mutation>
                       <field name="CONDITION">any</field>
                       <field name="ACK_CONDITION"></field>
                       <value name="OID0">
                         <shadow type="field_oid" id=",lv9ZsolE+vCtpc(_;%Q">
                           <field name="oid">0_userdata.0.TV_System.VU.Sender.05RTL</field>
                         </shadow>
                       </value>
                       <statement name="STATEMENT">
                         <block type="debug" id="-Vhq#pdf$~61$E:z=:1#">
                           <field name="Severity">log</field>
                           <value name="TEXT">
                             <shadow type="text" id="CFWS;buYk|F{mb1s?g%*">
                               <field name="TEXT">RTL wird jetzt eingeschaltet !</field>
                             </shadow>
                           </value>
                         </block>
                       </statement>
                     </block>
                   </next>
                 </block>
                </xml>
                

                Zum ausprobieren den Baustein DP_anlegen (die Funktion) aktivieren und einmal das Blockly starten. Danach die Funktion wieder deaktivieren. Den Speicherort für die eigenen Datenpunkte kannst Du in der Funktion (ganz unten in der Funktion selbst bestimmen)

                da </> rein klicken

                Mit dieser Funktion kannst Du beliebig viele Datenpunkte auf einmal anlegen. Ich nutze die in einzelnen Blocklys. Du könntest aber auch alle auf einmal anlegen und alles in ein Blockly packen.

                1 Antwort Letzte Antwort
                0
                • D Offline
                  D Offline
                  do1osc
                  schrieb am zuletzt editiert von
                  #8

                  Ahhh, Okay, das habe ich jetzt verstanden.
                  Danke für die ausführliche Beschreibung!

                  Du hast geschrieben, für "Temperatur im Garten" nutzt du aber die History und Routinen als Dummy.
                  Kannst du mir das bitte auch noch mal genau erklären?

                  Ich möchte gerne erst mal eine Übersicht haben, bevor ich mit allem anfange...

                  Mit freundlichen Grüßen, Sven

                  dslraserD 1 Antwort Letzte Antwort
                  0
                  • D do1osc

                    Ahhh, Okay, das habe ich jetzt verstanden.
                    Danke für die ausführliche Beschreibung!

                    Du hast geschrieben, für "Temperatur im Garten" nutzt du aber die History und Routinen als Dummy.
                    Kannst du mir das bitte auch noch mal genau erklären?

                    Ich möchte gerne erst mal eine Übersicht haben, bevor ich mit allem anfange...

                    Mit freundlichen Grüßen, Sven

                    dslraserD Offline
                    dslraserD Offline
                    dslraser
                    Forum Testing Most Active
                    schrieb am zuletzt editiert von dslraser
                    #9

                    @do1osc sagte in Frage: "Workflow" für Steuerung über Alexa:

                    Du hast geschrieben, für "Temperatur im Garten" nutzt du aber die History und Routinen als Dummy.
                    Kannst du mir das bitte auch noch mal genau erklären?

                    Das habe ich nicht geschrieben. Ich habe das hier geschrieben:

                    Nur da, wo ich das "an" nicht sagen möchte, z.B. Alexa, wie ist die Temperatur im Garten, oder Alexa, welche Fenster sind noch auf, da habe ich eine Routine angelegt und den SmartNamen so gewählt, das Alex ihn sowieso nicht verstehen würde und sie es somit nicht verwechseln kann.

                    Für die "Ansagen" nutze ich Routinen, weil man dann die Fragen formulieren kann wie man will.
                    Beispiele habe ich hier geschrieben.

                    https://forum.iobroker.net/post/273896

                    1 Antwort Letzte Antwort
                    0
                    • D Offline
                      D Offline
                      do1osc
                      schrieb am zuletzt editiert von
                      #10

                      Ahhh.. Okay, Danke.
                      Dann kann ich die Feiertage jetzt ja mal nutzen :-)

                      Nochmals vielen Dank für die Unterstützung...

                      1 Antwort Letzte Antwort
                      0
                      Antworten
                      • In einem neuen Thema antworten
                      Anmelden zum Antworten
                      • Älteste zuerst
                      • Neuste zuerst
                      • Meiste Stimmen


                      Support us

                      ioBroker
                      Community Adapters
                      Donate
                      FAQ Cloud / IOT
                      HowTo: Node.js-Update
                      HowTo: Backup/Restore
                      Downloads
                      BLOG

                      696

                      Online

                      32.5k

                      Benutzer

                      81.7k

                      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