Hielscher Ultrasonics
Kami akan dengan senang hati mendiskusikan proses Anda.
Hubungi kami: +49 3328 437-420
Kirimkan email kepada kami: [email protected]

Pencatat Excel Waktu Nyata untuk Data XML Hielscher Sonicator

Pencatat Excel realtime untuk sonikator Hielscher ini adalah solusi berbasis VBA ringan yang memungkinkan pengguna memvisualisasikan data sonikasi langsung yang dialirkan dalam format XML. Alat ini secara otomatis terhubung ke sonikator melalui IP lokal, membaca data proses langsung, mencatatnya ke dalam tabel Excel, dan memperbarui bagan dinamis. Hal ini memungkinkan pengguna untuk memantau parameter utama seperti daya, amplitudo, energi, dan suhu secara real time-langsung di dalam Excel.

Bagaimana cara kerjanya

Setelah dieksekusi, skrip akan meminta pengguna untuk memasukkan alamat sumber XML dari data xml sonicator mereka (misalnya, http://192.168.233.233/mdata.xml). Kemudian, skrip ini membuat baris header terstruktur dan mulai mengambil data setiap detik. Setiap titik data baru ditambahkan ke tabel, dan grafik garis sebar menampilkan tren daya, amplitudo, dan energi dari waktu ke waktu. Setiap nilai kesalahan sensor (misalnya, jika tidak ada sensor yang terhubung) secara otomatis disaring.

Petunjuk untuk Pengguna Windows

Buka Visual Basic Editor di Excel, masukkan modul baru, dan tempelkan skrip lengkap. Setelah menjalankan makro InitLogger, pencatat log akan mulai secara otomatis. Pastikan makro diaktifkan dan Excel memiliki izin untuk mengakses jaringan Anda.

Petunjuk untuk Pengguna macOS

Buka Editor Visual Basic di Excel. Sisipkan modul baru, dan tempelkan skrip lengkapnya. Cukup jalankan makro yang sama, dan data akan diambil menggunakan IP yang disediakan. Pengguna MacOS harus mengizinkan Excel untuk menjalankan AppleScript dan mungkin perlu memberikan akses jaringan di bawah preferensi sistem jika diminta.

Kode VBA Excel untuk memuat data XML sonikator ke dalam lembar kerja Excel.

Jalankan kode VBA Excel untuk memuat data XML sonikator ke dalam spreadsheet.

Pembaruan, Penafian dan Lisensi

Bergantung pada jenis perangkat dan versi perangkat lunak yang dikirimkan, string data xml dapat bervariasi. Ini mungkin berisi jumlah nilai yang berbeda dan dalam urutan atau format yang berbeda. Oleh karena itu, Anda mungkin perlu menyesuaikan skrip di bawah ini. Tidak ada kewajiban untuk dukungan teknis, perbaikan bug, atau pembaruan di masa mendatang. Alat ini disediakan tanpa jaminan atau garansi dalam bentuk apa pun. Ini secara eksplisit mengecualikan jaminan tersirat seperti dapat diperjualbelikan atau kesesuaian untuk tujuan tertentu. Hielscher Ultrasonics tidak bertanggung jawab atas segala kerusakan, termasuk kerusakan langsung, tidak langsung, atau konsekuensial, yang timbul dari penggunaan perangkat lunak. Ini hanya sebuah contoh. Perangkat lunak ini bebas digunakan untuk tujuan non-komersial dan penelitian saja. Redistribusi diizinkan dengan atribusi yang tepat. Dilarang keras menjual kembali secara komersial atau memasukkannya ke dalam sistem hak milik tanpa persetujuan tertulis sebelumnya.

Implementasi Excel untuk memuat data sonikator ke dalam Excel.

Data XML Sonicator ke Spreadsheet Excel

Permintaan Informasi




Video ini akan menunjukkan kepada Anda cara merekam data XML sonikator di Microsoft Excel.

Cara merekam data langsung sonikator secara langsung ke dalam 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


Kami akan dengan senang hati mendiskusikan proses Anda.