Hielscher Ultrasonics
Ne do të jemi të lumtur të diskutojmë procesin tuaj.
Na telefononi: +49 3328 437-420
Na dërgoni me postë: [email protected]

Regjistrues në kohë reale i Excel-it për të dhënat XML të Hielscher Sonicator

Ky regjistrues Excel në kohë reale për sonifikuesit Hielscher është një zgjidhje e lehtë e bazuar në VBA që u lejon përdoruesve të vizualizojnë të dhënat e sonifikimit të drejtpërdrejtë të transmetuara në format XML. Ai lidhet automatikisht me një sonifikues nëpërmjet IP-së së tij lokale, lexon të dhënat e procesit të drejtpërdrejtë, i regjistron ato në një tabelë Excel dhe përditëson një grafik dinamik. Kjo u mundëson përdoruesve të monitorojnë parametrat kryesorë si fuqia, amplituda, energjia dhe temperatura në kohë reale - direkt brenda Excel.

Si funksionon

Pas ekzekutimit, skripti i kërkon përdoruesit të fusë adresën burimore XML të të dhënave xml të sonifikuesit të tij (p.sh., http://192.168.233.233/mdata.xml). Pastaj krijon një rresht të strukturuar të kokës dhe fillon të marrë të dhëna çdo sekondë. Çdo pikë e re e të dhënave i shtohet tabelës dhe një grafik me vija shpërndarjeje shfaq trendet e fuqisë, amplitudës dhe energjisë me kalimin e kohës. Çdo vlerë gabimi e sensorit (p.sh., nëse nuk është i lidhur asnjë sensor) filtrohet automatikisht.

Udhëzime për përdoruesit e Windows

Hapni Visual Basic Editor në Excel, futni një modul të ri dhe ngjisni skriptin e plotë. Pas ekzekutimit të makrosë InitLogger, regjistruesi do të fillojë automatikisht. Sigurohuni që makrot janë të aktivizuara dhe që Excel ka leje për të hyrë në rrjetin tuaj.

Udhëzime për përdoruesit e macOS

Hapni Visual Basic Editor në Excel. Vendosni një modul të ri dhe ngjisni skriptin e plotë. Thjesht ekzekutoni të njëjtën makro dhe të dhënat do të merren duke përdorur IP-në e dhënë. Përdoruesit e MacOS duhet të lejojnë Excel të ekzekutojë AppleScript dhe mund të kenë nevojë të japin akses në rrjet në preferencat e sistemit nëse kërkohet.

Kodi VBA i Excel për të ngarkuar të dhënat XML të sonifikuesit në spreadsheet-in Excel.

Ekzekutoni kodin VBA të Excel për të ngarkuar të dhënat XML të sonifikatorit në spreadsheet.

Përditësime, Mohim Përgjegjësie dhe Licencë

Në varësi të llojit të pajisjes dhe versionit të softuerit të dorëzuar, vargu i të dhënave xml mund të ndryshojë. Mund të përmbajë një numër të ndryshëm vlerash dhe në një renditje ose format të ndryshëm. Prandaj, mund t'ju duhet të përshtatni skriptin më poshtë, në përputhje me rrethanat. Nuk ka detyrime për mbështetje teknike, rregullime të gabimeve ose përditësime të ardhshme. Ky mjet ofrohet pa asnjë garanci ose garanci të çfarëdo lloji. Kjo përjashton në mënyrë të qartë garancitë e nënkuptuara si tregtueshmëria ose përshtatshmëria për një qëllim të caktuar. Hielscher Ultrasonics nuk është përgjegjës për asnjë dëmtim, duke përfshirë dëmet direkte, indirekte ose pasuese, që rrjedhin nga përdorimi i softuerit. Ky është vetëm një shembull. Është falas për t'u përdorur vetëm për qëllime jo-komerciale dhe kërkimore. Rishpërndarja lejohet me atribuimin e duhur. Rishitja komerciale ose përfshirja në sistemet pronësore është rreptësisht e ndaluar pa pëlqimin paraprak me shkrim.

Implementimi në Excel për të ngarkuar të dhënat e sonifikuesit në Excel.

Të dhënat XML të Sonicator në fletëllogaritëse Excel

Kërkesë informacioni




Ky video do t'ju tregojë se si të regjistroni të dhëna XML të sonifikatorit në Microsoft Excel.

Si të regjistroni të dhënat live të sonifikuesit direkt në një spreadsheet 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


Ne do të jemi të lumtur të diskutojmë procesin tuaj.