0

Nach einlesen rfid Chip bestimmten Datensatz öffnen

Hallo,

 

ich bin grade dabei uns eine Materialverwaltung mit einem Barcode System für Material und einem rfid Chip für die Mitarbeiter aufzubauen.

Ich habe ein Formular zur Erfassung der Daten, in diesem sollen der Barcode und der rfid chip ausgelesen werden, um dann per Button das Material in die Verbrauchsliste mit dem jeweiligen Abholer einzutragen.

Dazu habe ich ein Textfeld 'NFC' in dem Formular , das in der Tab_Mitarbeiter mit dem Textfeld 'Code' verglichen wird. Sobald diese übereinstimmen, soll der Mitarbeiter Name in dem Formular in das Textfeld 'Mitarbeiter Name' eingetragen werden.

 

Hier der Code dazu:

let myNFC := NFC;
'Mitarbeiter Name' := first(select Mitarbeiter where text(Code) = myNFC and text(Code) > null).'Name voll'

Dieser wird in dem Feld 'NFC' augeführt unter "Nach Änderungen folgendes Skript ausführen".

 

Funktioniert mit einer einfach zur Testzwecken benutzten Zahl wie "1234" auch, aber nicht mit dem einlesen eines rfid Chips über ein USB Anschluss. Dieser gibt solch eine Zahlen/Buchstaben Kombi aus: "100000078b0f8209".

 

Hat da jemand eine Idee, warum der Code da nicht mehr greift?

 

Gruß Mirko

13 Antworten

null
    • Mirko.1
    • vor 6 Jahren
    • Gemeldet - anzeigen

    Hab das jetzt auch mal mit dem Scanner getestet.

     

    Das Problem scheinen wirklich die Buchstaben zu sein, sobald ich einen Code mit Buchstaben einlese und hinterlege, wird der Code nicht erkannt, ein reiner EAN Code nur aus Buchstaben aber wird erkannt.

     

    Woran kann das liegen?

     

    Grüße Mirko

    • Leonid_Semik
    • vor 6 Jahren
    • Gemeldet - anzeigen

    Hallo Mirko,

    da EAN nur aus Zahlen besteht, gehe ich von den Tippfehler aus (...ein reiner EAN Code nur aus Buchstaben aber wird erkannt.) Kann es sein dass das Feld NFC doch als Zahl angelegt ist?

    Leo

    • Mirko.1
    • vor 6 Jahren
    • Gemeldet - anzeigen

    Hallo Leo,

     

    richtig, war ein Tipfehler, "ein EAN Code nur aus Zahlen wird erkannt".

    Das Feld ist definitiv ein Textfeld, komischerweise gehen wie gesagt reine Zahlenkombinationen, egal welcher Länge, aber sobald ein Buchstabe dazwischen ist greift der Trigger nicht mehr?

     

    Grüße Mirko

    • Leonid_Semik
    • vor 6 Jahren
    • Gemeldet - anzeigen

    let myNFC := text(NFC);
    'Mitarbeiter Name' := first(select Mitarbeiter [ text(Code) = myNFC and text(Code)]).'Name voll'

    • Mirko.1
    • vor 6 Jahren
    • Gemeldet - anzeigen

    Haut leider nicht hin, bekomme dann immer nur den ersten Datensatz der Tabelle Mitarbeiter angezeigt.

    • Leonid_Semik
    • vor 6 Jahren
    • Gemeldet - anzeigen

    Interessant. Wenn NFC und Code definitiv Textfelder sind dann vielleicht so:

    —-

    if NFC then

    let myNFC:=NFC;

    let myE:=select Mitarbeiter;

     'Mitarbeiter Name' := first (myE [Code=myNFC]).'Name voll'

    end

    —-

    • Mirko.1
    • vor 6 Jahren
    • Gemeldet - anzeigen

    Hallo Leo,

     

    so funktioniert es!? Gibts da auch eine Erklärung für, da wär ich im Leben nicht drauf gekommen!

    • Leonid_Semik
    • vor 6 Jahren
    • Gemeldet - anzeigen

    Ich weiß nicht genau. Die Bediengung text(Code) > null sieht merkwürdig aus, vielleicht kommt Ninox mit matematischen Vergleichen von Texten nicht klar.

    So wie ich geschrieben prüft Ninox ob NFC einen Wert hat, wenn Ja dann wird in der Tabelle weiter gesucht, Da die Vergleichsfelder definitiv Textfelder sind braucht man text() gar nicht. Und die Eckklammern sind für mich sicherer als where Funktion.

    Leo

    • Patrik_Ronschke
    • vor 1 Jahr
    • Gemeldet - anzeigen

    Hallo zusammen, 

    hat jemand hiermit schon Erfahrungen gemacht? 

    Ich versuche auch auch per USB-RFID Interface Daten in Ninox zu schreiben. 

    Mirko wie genau hast du das umgesetzt? 

     

    LG Patrik

    • Ninox Widgets & User Interfaces
    • Jakob_Jordan
    • vor 7 Monaten
    • Gemeldet - anzeigen

    Wie hat denn überhaupt ein RFID Scanner Zugang zu Ninox. Also was genau wird vom Scanner wie übertragen? Ein Kunde hat folgenden Scanner: https://www.chainway.net/Products/Info/142 Direkt mit Android Gerät draufgeschnallt. Ninox App konnte dort schon installiert werden. Aber wie geht es weiter? 😅

    • T_Bartzsch
    • vor 7 Monaten
    • Gemeldet - anzeigen

    Ein RFID-Scanner funktioniert - wie auch ein Bar-/QRCode Scanner - am Ende wie ein simples Texteingabe-Gerät. Ein gewähltes Datenfeld wird mit dem erkannten String beschrieben. Gerade in Verbindung mit Ninox ergeben sich daraus ein paar Klippen, die man umschiffen muss. Z.B. fehlt die Möglichkeit, in Ninox ein bestimmtes Feld zu "fokussieren", so dass man zb. über ein Dashboard schon immer das Scan-Eingabe-Feld aktiv halten kann und direkt "losscannen" kann. Da muss man an Workarounds basteln, damit das klappt... Die 2. Anforderung ist der sog. "Terminator" - also was das Gerät nach einem erfolgreichen Scan macht. Wenn es gar nix macht, muss der Anwender den eingescannten String bestätigen. Barcode Scanner kann man meist mit verschiedenen Terminator-Funktionen programmieren. CR/LF oder TAB... Ein simuliertes "Enter" macht in Ninox keinen Sinn, da der User dann jedesmal wieder in das "Scan" Feld klicken muss... mit TAB kommt man in Ninox da zum Glück etwas weiter... (ich sitze übrigens gerade heute an einer Lösung mit nur einem Feld und Piepton über HTML, mal sehen wie weit ich komme.

    Ich habe erst kürzlich einen RFID Scanner selbst via Arduino IDE zusammengebaut, welcher erkannte RFID Codes direkt über die API in die NINOX schreibt ... auch sowas ist machbar.

      • Ninox Widgets & User Interfaces
      • Jakob_Jordan
      • vor 7 Monaten
      • Gemeldet - anzeigen

       Super vielen Dank für die ausführliche Antwort :) Das hilft schon mal sehr für das Verständnis. Wenn es wie eine Tastatur funktioniert ist alles fein. Dann können wir auch offline bleiben mit der Ninox App. Das Fokus problem lösen wir über unser customInput, das sich merken kann ob es nach jedem Datenbank Update aktiv bleiben soll oder nicht. Eine coole Idee die mir gerade einfällt wäre ein bestimmter Tastatur Key der den Fokus beendet oder sogar andere Auswahlmöglichkeiten triggert (Produkt wechseln z.B.)...

      also super feedback, da sprudeln die ideen :D

    • T_Bartzsch
    • vor 7 Monaten
    • Gemeldet - anzeigen
     said:
    Woran kann das liegen?

    Hast Du mal Testweise den Code des Mitarbeiters auf die gleiche Weise eingelesen? Es kann sein, dass der RFID Reader zusätzliche Steuerzeichen ausgibt, die Ninox verschluckt bzw. nicht anzeigt, die aber trotzdem da sind... du müsstest nach dem Scannen den Code evtl. erstmal etwas formatieren, könntest zB. die vorderen 7 Ziffern entfernen, mit extractx() nur Zahlen und Buchstaben aus dem eingelesenen Code holen usw... dann hast Du einen sauberen String.