Hielscher Ultrasonics
Θα χαρούμε να συζητήσουμε τη διαδικασία σας.
Καλέστε μας: +49 3328 437-420
Στείλτε μας email: [email protected]

Καταγραφέας πραγματικού χρόνου Excel για δεδομένα XML της Hielscher Sonicator

Αυτός ο καταγραφέας πραγματικού χρόνου Excel για ηχοβολείς Hielscher είναι μια ελαφριά λύση βασισμένη σε VBA που επιτρέπει στους χρήστες να απεικονίζουν ζωντανά δεδομένα ηχοβολισμού που μεταδίδονται σε μορφή XML. Συνδέεται αυτόματα σε έναν ηχοβολέα μέσω της τοπικής του IP, διαβάζει ζωντανά δεδομένα διεργασίας, τα καταγράφει σε έναν πίνακα Excel και ενημερώνει ένα δυναμικό διάγραμμα. Αυτό επιτρέπει στους χρήστες να παρακολουθούν βασικές παραμέτρους όπως η ισχύς, το πλάτος, η ενέργεια και η θερμοκρασία σε πραγματικό χρόνο - απευθείας μέσα στο Excel.

Πώς λειτουργεί

Κατά την εκτέλεση, το σενάριο ζητά από τον χρήστη να εισάγει τη διεύθυνση προέλευσης XML των δεδομένων xml του ηχοβολέα (π.χ. http://192.168.233.233/mdata.xml). Στη συνέχεια δημιουργεί μια δομημένη γραμμή κεφαλίδας και αρχίζει να αντλεί δεδομένα κάθε δευτερόλεπτο. Κάθε νέο σημείο δεδομένων προσαρτάται στον πίνακα και ένα διάγραμμα γραμμής διασποράς εμφανίζει τις τάσεις ισχύος, πλάτους και ενέργειας με την πάροδο του χρόνου. Τυχόν τιμές σφάλματος αισθητήρα (π.χ. εάν δεν είναι συνδεδεμένος αισθητήρας) φιλτράρονται αυτόματα.

Οδηγίες για χρήστες των Windows

Ανοίξτε το Visual Basic Editor στο Excel, εισάγετε μια νέα ενότητα και επικολλήστε το πλήρες σενάριο. Μετά την εκτέλεση της μακροεντολής InitLogger, ο καταγραφέας θα ξεκινήσει αυτόματα. Βεβαιωθείτε ότι οι μακροεντολές είναι ενεργοποιημένες και ότι το Excel έχει δικαίωμα πρόσβασης στο δίκτυό σας.

Οδηγίες για χρήστες macOS

Ανοίξτε τον επεξεργαστή Visual Basic στο Excel. Εισάγετε μια νέα ενότητα και επικολλήστε το πλήρες σενάριο. Απλά εκτελέστε την ίδια μακροεντολή και τα δεδομένα θα αντληθούν χρησιμοποιώντας την παρεχόμενη διεύθυνση IP. Οι χρήστες του MacOS πρέπει να επιτρέψουν στο Excel να εκτελεί AppleScript και ενδέχεται να χρειαστεί να χορηγήσουν πρόσβαση στο δίκτυο στις προτιμήσεις του συστήματος, εάν τους ζητηθεί.

Κώδικας VBA του Excel για να φορτώσετε δεδομένα XML του ηχοβολέα στο φύλλο Excel.

Εκτελέστε τον κώδικα VBA του Excel για να φορτώσετε δεδομένα XML του ηχοβολέα στο υπολογιστικό φύλλο.

Ενημερώσεις, αποποίηση ευθυνών και άδεια χρήσης

Ανάλογα με τον τύπο της συσκευής και την έκδοση του λογισμικού που παραδίδεται, η συμβολοσειρά δεδομένων xml μπορεί να διαφέρει. Μπορεί να περιέχει διαφορετικό αριθμό τιμών και με διαφορετική σειρά ή μορφή. Ως εκ τούτου, ενδέχεται να χρειαστεί να προσαρμόσετε ανάλογα το παρακάτω σενάριο. Δεν υπάρχουν υποχρεώσεις για τεχνική υποστήριξη, διορθώσεις σφαλμάτων ή μελλοντικές ενημερώσεις. Αυτό το εργαλείο παρέχεται χωρίς εγγυήσεις ή εγγυήσεις οποιουδήποτε είδους. Αυτό αποκλείει ρητά τις σιωπηρές εγγυήσεις όπως η εμπορευσιμότητα ή η καταλληλότητα για συγκεκριμένο σκοπό. Η Hielscher Ultrasonics δεν ευθύνεται για τυχόν ζημίες, συμπεριλαμβανομένων των άμεσων, έμμεσων ή επακόλουθων ζημιών, που προκύπτουν από τη χρήση του λογισμικού. Αυτό είναι ένα παράδειγμα, μόνο. Είναι ελεύθερο να χρησιμοποιηθεί μόνο για μη εμπορικούς και ερευνητικούς σκοπούς. Επιτρέπεται η αναδιανομή με την κατάλληλη αναφορά. Απαγορεύεται αυστηρά η εμπορική μεταπώληση ή η ενσωμάτωση σε συστήματα ιδιοκτησίας χωρίς προηγούμενη γραπτή συγκατάθεση.

Εφαρμογή του Excel για τη φόρτωση δεδομένων του ηχοβολέα στο Excel.

Δεδομένα Sonicator XML σε υπολογιστικό φύλλο Excel

Αίτηση Πληροφοριών




Αυτό το βίντεο θα σας δείξει πώς να καταγράφετε δεδομένα XML του ηχοβολέα στο Microsoft Excel.

Πώς να καταγράφετε ζωντανά δεδομένα του ηχοβολέα απευθείας σε ένα φύλλο Excel


' ==============================================================================
' Realtime Excel Logger for Hielscher Sonicator XML Data
'
' Description:
' This VBA module fetches XML data from a Hielscher sonicator over the network
' (typically from a local IP like http://192.168.233.233/mdata.xml), parses it,
' logs real-time data into Excel, and visualizes selected parameters (Power, Amplitude,
' and Energy) using a live updating scatter-line chart.
'
' Disclaimer & License:
' This script is provided "as is" without any warranty. It is free for non-commercial
' use, and redistribution is permitted only with attribution. Resale or inclusion in
' commercial software is strictly prohibited without explicit permission.
' (c) Hielscher Ultrasonics GmbH (Germany), 2025. All rights reserved. https://www.hielscher.com
' Last Update: June 17th, 2025, for sonicator software version 25.0.1
' ==============================================================================

' === Realtime Excel Logger Module ===
Dim nextRow As Long                     ' Row index for logging the next data point
Dim chartObject As chartObject          ' Reference to the live chart object
Dim isRunning As Boolean                ' Controls whether logging continues

' === MAIN ENTRY POINT ===
Sub InitLogger()
    Dim ws As Worksheet
    Set ws = Sheet1                     ' Use the first worksheet

    ws.Cells.Clear                      ' Clear all existing content on the sheet

    ' Request and store the XML source IP address
    ws.Cells(1, 1).Value = "XML Source"
    ws.Cells(1, 2).Value = InputBox("Enter device IP address", "XML Source", "http://192.168.233.233/mdata.xml")

    ' Create header row starting at row 2
    ws.Cells(2, 1).Resize(1, 14).Value = Array( _
        "Timestamp", "Status", "Total Power (W)", "Net Power (W)", "Amplitude (%)", _
        "Energy (Ws)", "ADC", "Frequency (Hz)", "Temperature (°C)", "Time (s)", _
        "ControlBits", "LimitType", "SetPower (%)", "Cycle (%)")

    nextRow = 3                         ' Start logging at row 3
    isRunning = True                    ' Enable logging loop
    Application.OnTime Now + TimeSerial(0, 0, 1), "LoggerTick" ' Schedule first data fetch
End Sub

' === PERIODIC TIMER CALLBACK ===
Sub LoggerTick()
    If Not isRunning Then Exit Sub
    FetchOnce
    Application.OnTime Now + TimeSerial(0, 0, 1), "LoggerTick" ' Schedule next fetch
End Sub

' === FETCH AND LOG DATA ===
Sub FetchOnce()
    Dim ipAddress As String, rawData As String
    Dim dataFields() As String, mStart As Long, mEnd As Long
    Dim ws As Worksheet: Set ws = Sheet1

    ipAddress = Trim(ws.Cells(1, 2).Value)   ' Get IP from input cell
    If ipAddress = "" Then Exit Sub          ' Exit if IP is missing

    rawData = GetMDataXML(ipAddress)         ' Fetch the raw XML from device
    If rawData = "" Then Exit Sub            ' Exit if fetch failed

    ' Extract only the content inside  ... 
    mStart = InStr(rawData, "")
    mEnd = InStr(rawData, "")
    If mStart = 0 Or mEnd = 0 Then Exit Sub  ' Exit if tag not found

    rawData = Mid(rawData, mStart + 7, mEnd - mStart - 7)
    dataFields = Split(rawData, ";")        ' Parse by semicolon delimiter
    If UBound(dataFields) < 12 Then Exit Sub ' Ensure all fields are present

    ' Determine next available row
    nextRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row + 1

    ' Write parsed values into worksheet
    With ws
        .Cells(nextRow, 1).Value = Format(Now, "yyyy-mm-dd HH:nn:ss")           ' Timestamp (rounded to seconds)
        .Cells(nextRow, 2).Value = Val(dataFields(0))                            ' Status
        .Cells(nextRow, 3).Value = Val(dataFields(1)) / 10                       ' Total Power (W)
        .Cells(nextRow, 4).Value = Val(dataFields(2)) / 10                       ' Net Power (W)
        .Cells(nextRow, 5).Value = Val(dataFields(3)) / 10                       ' Amplitude (%)
        .Cells(nextRow, 6).Value = Val(dataFields(4))                            ' Energy (Ws)
        .Cells(nextRow, 7).Value = Val(dataFields(5)) / 10                       ' ADC
        .Cells(nextRow, 8).Value = Val(dataFields(6))                            ' Frequency (Hz)
        .Cells(nextRow, 9).Value = IIf(Val(dataFields(7)) = 2550, "", Val(dataFields(7)) / 10) ' Temperature (°C), blank if 255
        .Cells(nextRow, 10).Value = Val(dataFields(8)) / 10                      ' Time (s)
        .Cells(nextRow, 11).Value = Val(dataFields(9))                           ' ControlBits
        .Cells(nextRow, 12).Value = IIf(Val(dataFields(10)) = 0, "", Val(dataFields(10)))     ' LimitType, blank if 0
        .Cells(nextRow, 13).Value = Val(dataFields(11)) / 20                     ' SetPower (%)
        .Cells(nextRow, 14).Value = Val(dataFields(12)) / 10                     ' Cycle (%).Value = Val(dataFields(12)) / 10     ' Cycle (%)
    End With

    UpdateChart
End Sub

' === CREATE / UPDATE SCATTER-LINE CHART ===
Sub UpdateChart()
    Dim ws As Worksheet: Set ws = Sheet1
    Dim lastRow As Long: lastRow = ws.Cells(ws.Rows.Count, 1).End(xlUp).Row
    If lastRow < 4 Then Exit Sub

    ' Format timestamp column to display yyyy-mm-dd HH:mm:ss
    ws.Columns(1).NumberFormat = "yyyy-mm-dd hh:mm:ss"

    ' Create chart if not already initialized
    If chartObject Is Nothing Then
        Set chartObject = ws.ChartObjects.Add(Left:=ws.Cells(2, 16).Left, Top:=ws.Cells(2, 16).Top, Width:=500, Height:=300)
        chartObject.Name = "LiveChart"
    End If

    ' Configure the scatter line chart with latest data
    With chartObject.Chart
        .ChartType = xlXYScatterLines
        Do While .SeriesCollection.Count > 0: .SeriesCollection(1).Delete: Loop

        ' Plot Total Power
        .SeriesCollection.NewSeries
        .SeriesCollection(1).Name = "Power (W)"
        .SeriesCollection(1).XValues = ws.Range("A3:A" & lastRow)
        .SeriesCollection(1).Values = ws.Range("C3:C" & lastRow)

        ' Plot Amplitude
        .SeriesCollection.NewSeries
        .SeriesCollection(2).Name = "Amplitude (%)"
        .SeriesCollection(2).XValues = ws.Range("A3:A" & lastRow)
        .SeriesCollection(2).Values = ws.Range("E3:E" & lastRow)

        ' Plot Energy
        .SeriesCollection.NewSeries
        .SeriesCollection(3).Name = "Energy (Ws)"
        .SeriesCollection(3).XValues = ws.Range("A3:A" & lastRow)
        .SeriesCollection(3).Values = ws.Range("F3:F" & lastRow)

        .HasTitle = True
        .ChartTitle.Text = "Hielscher Sonicator: Live Chart"
        .Axes(xlCategory).HasTitle = True
        .Axes(xlCategory).AxisTitle.Text = "Time"
        .Axes(xlValue).HasTitle = True
        .Axes(xlValue).AxisTitle.Text = "Value"

        ' Format the X-axis to show MM:SS
        .Axes(xlCategory).TickLabels.NumberFormat = "mm:ss"
    End With
End Sub

' === FETCH XML VIA PLATFORM-SPECIFIC METHOD ===
Function GetMDataXML(ip As String) As String
    Dim os As String: os = Application.OperatingSystem

    ' macOS: use AppleScript shell call to curl
    If InStr(1, os, "Mac", vbTextCompare) > 0 Then
        Dim script As String
        script = "do shell script " & Chr(34) & "curl -s " & ip & Chr(34)
        On Error Resume Next
        GetMDataXML = MacScript(script)
        If Err.Number <> 0 Then GetMDataXML = ""

    ' Windows: use MSXML2.XMLHTTP request
    Else
        Dim http As Object
        Set http = CreateObject("MSXML2.XMLHTTP")
        On Error Resume Next
        http.Open "GET", ip, False
        http.Send
        If Err.Number = 0 And http.Status = 200 Then
            GetMDataXML = http.responseText
        Else
            GetMDataXML = ""
        End If
    End If
End Function


Θα χαρούμε να συζητήσουμε τη διαδικασία σας.