解析gcode文件以提取坐标

时间:2018-03-10 14:15:09

标签: python python-3.x g-code

我有一个充满文本的gcode文件,更具体地说是为机器协调。我正在尝试读取该文件,删除无用的信息,以便我可以在它们被发送到机器之前对协调执行操作。

到目前为止,我有:

file = open('TestCube.gcode','r')
lines = file.readlines()
file.close

for line in lines:
    line = line.strip() 

现在我有一个文件中所有行的列表,我应该如何继续获取相关的X和Y坐标?

TestCube.gcode示例:

;TYPE:SKIN
G1 F1200 X-9.914 Y-9.843 E3.36222
G0 F9000 X-9.843 Y-9.914
G1 F1200 X9.914 Y9.843 E3.65844
G0 F9000 X9.914 Y9.702
G1 F1200 X-9.702 Y-9.914 E3.95254
G0 F9000 X-9.560 Y-9.914
G1 F1200 X9.914 Y9.560 E4.24451
G0 F9000 X9.914 Y9.419
G1 F1200 X-9.419 Y-9.914 E4.53437
G0 F9000 X-9.277 Y-9.914
G1 F1200 X9.914 Y9.277 E4.82211
G0 F9000 X9.914 Y9.136
G1 F1200 X-9.136 Y-9.914 E5.10772
G0 F9000 X-8.995 Y-9.914
G1 F1200 X9.914 Y8.995 E5.39123
G0 F9000 X9.914 Y8.853
G1 F1200 X-8.853 Y-9.914 E5.67260

编辑:

import re

file = open('TestCube.gcode','r')
gcode = file.readlines()

for line in gcode:
    coord = re.findall(r'[XY]-\d.\d\d\d', line)
    if coord:
        print("{} - {}".format(coord[0], coord[1]))

1 个答案:

答案 0 :(得分:0)

正则表达式似乎可以解决问题:

import re

gcode = [
    ';TYPE:SKIN',
    'G1 F1200 X-9.914 Y-9.843 E3.36222',
    'G0 F9000 X-9.843 Y-9.914',
    'G1 F1200 X9.914 Y9.843 E3.65844',
    'G0 F9000 X9.914 Y9.702',
    'G1 F1200 X-9.702 Y-9.914 E3.95254',
    'G0 F9000 X-9.560 Y-9.914',
    'G1 F1200 X9.914 Y9.560 E4.24451',
    'G0 F9000 X9.914 Y9.419',
    'G1 F1200 X-9.419 Y-9.914 E4.53437',
    'G0 F9000 X-9.277 Y-9.914',
    'G1 F1200 X9.914 Y9.277 E4.82211',
    'G0 F9000 X9.914 Y9.136',
    'G1 F1200 X-9.136 Y-9.914 E5.10772',
    'G0 F9000 X-8.995 Y-9.914',
    'G1 F1200 X9.914 Y8.995 E5.39123',
    'G0 F9000 X9.914 Y8.853',
    'G1 F1200 X-8.853 Y-9.914 E5.67260'
    ]

for line in gcode:
    coord = re.findall(r'[XY]-\d.\d\d\d', line)
    if coord:
        print("{} - {}".format(coord[0], coord[1]))

结果:

X-9.914 - Y-9.843
X-9.843 - Y-9.914
X-9.702 - Y-9.914
X-9.560 - Y-9.914
X-9.419 - Y-9.914
X-9.277 - Y-9.914
X-9.136 - Y-9.914
X-8.995 - Y-9.914
X-8.853 - Y-9.914

编辑:

请尝试以下方法。我已将您的代码与我提供的示例集成并进行了一些调整:

import re

with open('PI_25mm_cube.gcode') as gcode:
    for line in gcode:
        line = line.strip()
        coord = re.findall(r'[XY].?\d+.\d+', line)
        if coord:
            print("{} - {}".format(coord[0], coord[1]))

open替换为with,可以防止您忘记close()文件,并降低导致内存问题的风险,正如我所理解的那样。

由于不清楚您的代码是否会用于其他gcode文件,我的初始正则表达式可能不合适。使用Cura我创建了一个gcode文件并查看了提供的坐标。根据这些信息,您可能会发现模式'[XY].?\d+.\d+'更有用。 Regex101是测试这些

的绝佳网站