QT深入解析数控机床或激光切割机的nc文件包括读取与数据处理技巧

QT深入解析数控机床或激光切割机的nc文件包括读取与数据处理技巧

代码功能说明:

这个代码是用来读取一个名为 “C:/QCY/qcy.nc” 的文件,这个文件中包含了一系列数据,每行数据可能包含 X、Y、Z 坐标值。这些坐标值可以代表某种路径或轨迹。

代码的作用是:

  1. 打开指定路径的文件。
  2. 逐行读取文件内容。
  3. 对每一行内容进行匹配,查找是否包含 X、Y、Z 坐标值,并提取出这些值。
  4. 将提取的 X、Y、Z 坐标值分别存储在 QVector<double> 类型的数组中。
  5. 如果某行中没有某个坐标值,则默认使用 0 代替。
  6. 最后,输出每一行的 X、Y、Z 坐标值,以及它们在数组中的索引。

这个代码可以帮助你解析含有 XYZ 坐标值的文件,并将它们存储在内存中以便后续处理或分析。

代码

#include <QFile>
#include <QTextStream>
#include <QDebug>
#include <QRegExp>

void readNetCDFFile(const QString& filePath) {
    // Open the file
    QFile file(filePath);
    if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
        qDebug() << "Failed to open the file.";
        return;
    }

    // Arrays to store X, Y, Z values
    QVector<double> xValues;
    QVector<double> yValues;
    QVector<double> zValues;

    // Read the content
    QTextStream in(&file);
    while (!in.atEnd()) {
        QString line = in.readLine();

        // Regular expression to match X, Y, or Z followed by a number
        QRegExp rx("(X|Y|Z)(-?\\d+(\\.\\d+)?)");

        // Initialize default values
        double xValue = 0.0;
        double yValue = 0.0;
        double zValue = 0.0;

        // Index of the regular expression in the line
        int pos = 0;

        // Loop to find all matches in the line
        while ((pos = rx.indexIn(line, pos)) != -1) {
            // Extract the matched text
            QString match = rx.cap(1);

            // Extract the number part
            QString number = rx.cap(2);
            double value = number.toDouble();

            // Assign the value to the corresponding variable
            if (match == "X") {
                xValue = value;
            } else if (match == "Y") {
                yValue = value;
            } else if (match == "Z") {
                zValue = value;
            }

            // Move the position forward to search for next match
            pos += rx.matchedLength();
        }

        // Add the values to the arrays
        xValues.append(xValue);
        yValues.append(yValue);
        zValues.append(zValue);
    }

    // Close the file
    file.close();

    // Output the values
    for (int i = 0; i < xValues.size(); ++i) {
        qDebug() << "Line" << i + 1 << "X:" << xValues[i] << "Y:" << yValues[i] << "Z:" << zValues[i];
    }
}

int main() {
    QString filePath = "C:/QCY/qcy.nc";
    readNetCDFFile(filePath);
    return 0;
}


运行过程

在这里插入图片描述
在这里插入图片描述

  • 9
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

常驻客栈

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值