Hielscher Ultrasonics
Nous nous ferons un plaisir de discuter de votre processus.
Appelez-nous : +49 3328 437-420
Envoyez-nous un courrier : [email protected]

Enregistreur Excel en temps réel pour les données XML de Hielscher Sonicator

Cet enregistreur Excel en temps réel pour les sonicateurs Hielscher est une solution légère basée sur VBA qui permet aux utilisateurs de visualiser les données de sonification en direct au format XML. Il se connecte automatiquement à un sonicateur via son IP local, lit les données de processus en direct, les enregistre dans un tableau Excel et met à jour un graphique dynamique. Les utilisateurs peuvent ainsi surveiller des paramètres clés tels que la puissance, l'amplitude, l'énergie et la température en temps réel, directement dans Excel.

Comment cela fonctionne-t-il ?

Lors de l'exécution, le script invite l'utilisateur à saisir l'adresse de la source XML des données xml de sonicator (par exemple, http://192.168.233.233/mdata.xml). Il crée ensuite une ligne d'en-tête structurée et commence à récupérer des données toutes les secondes. Chaque nouveau point de données est ajouté au tableau et un diagramme de dispersion affiche les tendances de la puissance, de l'amplitude et de l'énergie au fil du temps. Toutes les valeurs d'erreur du capteur (par exemple, si aucun capteur n'est connecté) sont automatiquement filtrées.

Instructions pour les utilisateurs de Windows

Ouvrez l'éditeur Visual Basic dans Excel, insérez un nouveau module et collez le script complet. Après avoir exécuté la macro InitLogger, l'enregistreur démarre automatiquement. Assurez-vous que les macros sont activées et qu'Excel a la permission d'accéder à votre réseau.

Instructions pour les utilisateurs de macOS

Ouvrez l'éditeur Visual Basic dans Excel. Insérez un nouveau module et collez le script complet. Il suffit d'exécuter la même macro pour que les données soient récupérées à l'aide de l'adresse IP fournie. Les utilisateurs de MacOS doivent autoriser Excel à exécuter AppleScript et peuvent avoir besoin d'accorder l'accès au réseau dans les préférences du système si cela leur est demandé.

Code Excel VBA pour charger les données XML du sonicateur dans une feuille de calcul Excel.

Exécuter le code Excel VBA pour charger les données XML du sonicateur dans la feuille de calcul.

Mises à jour, clause de non-responsabilité et licence

Selon le type d'appareil et la version du logiciel livré, la chaîne de données xml peut varier. Elle peut contenir un nombre différent de valeurs et dans un ordre ou un format différent. Il se peut donc que vous deviez adapter le script ci-dessous en conséquence. Il n'y a aucune obligation d'assistance technique, de correction de bogues ou de mises à jour futures. Cet outil est fourni sans aucune garantie de quelque nature que ce soit. Cela exclut explicitement les garanties implicites telles que la qualité marchande ou l'adéquation à un usage particulier. Hielscher Ultrasonics n'est pas responsable des dommages, y compris les dommages directs, indirects ou consécutifs, résultant de l'utilisation du logiciel. Il s'agit uniquement d'un exemple. Il peut être utilisé librement à des fins non commerciales et de recherche uniquement. La redistribution est autorisée sous réserve d'une attribution appropriée. La revente commerciale ou l'inclusion dans des systèmes propriétaires est strictement interdite sans accord écrit préalable.

Implémentation Excel pour charger les données du sonicateur dans Excel.

Sonicator XML Data to Excel Spreadsheet (Données XML vers feuille de calcul Excel)

Demande d'information




Cette vidéo vous montrera comment enregistrer les données XML du sonicateur dans Microsoft Excel.

Comment enregistrer les données en direct du sonicateur directement dans une feuille de calcul 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


Nous nous ferons un plaisir de discuter de votre processus.