Hielscher Siêu âm
Chúng tôi sẽ vui mừng thảo luận về quá trình của bạn.
Gọi cho chúng tôi: +49 3328 437-420
Gửi thư cho chúng tôi: [email protected]

Phần mềm ghi nhật ký Excel thời gian thực cho dữ liệu XML của máy siêu âm Hielscher

Phần mềm ghi nhật ký thời gian thực cho máy siêu âm Hielscher này là một giải pháp nhẹ nhàng dựa trên VBA, cho phép người dùng hiển thị dữ liệu siêu âm trực tiếp được truyền dưới định dạng XML. Phần mềm tự động kết nối với máy siêu âm qua địa chỉ IP cục bộ, đọc dữ liệu quá trình thời gian thực, ghi lại vào bảng Excel và cập nhật biểu đồ động. Điều này cho phép người dùng theo dõi các thông số quan trọng như công suất, biên độ, năng lượng và nhiệt độ trong thời gian thực - trực tiếp trong Excel.

Cách thức hoạt động

Khi thực thi, skript sẽ yêu cầu người dùng nhập địa chỉ nguồn XML của dữ liệu XML sonicator (ví dụ: http://192.168.233.233/mdata.xml). Sau đó, skript tạo một hàng tiêu đề có cấu trúc và bắt đầu lấy dữ liệu mỗi giây. Mỗi điểm dữ liệu mới được thêm vào bảng, và biểu đồ phân tán hiển thị xu hướng công suất, biên độ và năng lượng theo thời gian. Các giá trị lỗi cảm biến (ví dụ: nếu không có cảm biến được kết nối) sẽ được tự động lọc bỏ.

Hướng dẫn cho người dùng Windows

Mở Trình soạn thảo Visual Basic trong Excel, chèn một mô-đun mới và dán toàn bộ mã lệnh. Sau khi chạy macro InitLogger, trình ghi nhật ký sẽ tự động khởi động. Đảm bảo rằng macro đã được kích hoạt và Excel có quyền truy cập vào mạng của bạn.

Hướng dẫn cho người dùng macOS

Mở Trình soạn thảo Visual Basic trong Excel. Chèn một mô-đun mới và dán toàn bộ mã lệnh. Chỉ cần chạy macro tương ứng, dữ liệu sẽ được lấy về thông qua địa chỉ IP đã cung cấp. Người dùng MacOS cần cho phép Excel chạy AppleScript và có thể phải cấp quyền truy cập mạng trong cài đặt hệ thống nếu được yêu cầu.

Mã VBA Excel để tải dữ liệu XML từ Sonicator vào bảng tính Excel.

Chạy mã VBA Excel để tải dữ liệu XML từ Sonicator vào bảng tính.

Cập nhật, Miễn trừ trách nhiệm và Giấy phép

Tùy thuộc vào loại thiết bị và phiên bản phần mềm được cung cấp, chuỗi dữ liệu XML có thể khác nhau. Nó có thể chứa số lượng giá trị khác nhau và theo thứ tự hoặc định dạng khác nhau. Do đó, bạn có thể cần điều chỉnh kịch bản bên dưới cho phù hợp. Không có nghĩa vụ hỗ trợ kỹ thuật, sửa lỗi hoặc cập nhật trong tương lai. Công cụ này được cung cấp mà không kèm theo bất kỳ bảo đảm hoặc bảo hành nào. Điều này rõ ràng loại trừ các bảo hành ngụ ý như khả năng thương mại hoặc phù hợp cho một mục đích cụ thể. Hielscher Ultrasonics không chịu trách nhiệm về bất kỳ thiệt hại nào, bao gồm thiệt hại trực tiếp, gián tiếp hoặc hậu quả, phát sinh từ việc sử dụng phần mềm. Đây chỉ là một ví dụ. Phần mềm này miễn phí để sử dụng cho mục đích phi thương mại và nghiên cứu. Việc phân phối lại được phép với điều kiện ghi rõ nguồn gốc. Việc bán lại thương mại hoặc tích hợp vào hệ thống độc quyền bị nghiêm cấm mà không có sự đồng ý bằng văn bản trước đó.

Thực hiện trong Excel để nhập dữ liệu từ Sonicator vào Excel.

Chuyển đổi dữ liệu XML của Sonicator sang bảng tính Excel

Yêu cầu thông tin




Video này sẽ hướng dẫn bạn cách ghi dữ liệu XML của Sonicator vào Microsoft Excel.

Cách ghi dữ liệu trực tiếp từ máy siêu âm (sonicator) vào bảng tính 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


Chúng tôi sẽ vui mừng thảo luận về quá trình của bạn.