使用 python 从.txt文件从字符串中提取数字时"Value error: Mixing iteration and read methods would lose data "消息



我有一个程序,它从.txt文件中获取数字并将其放入array。问题是这些数字不是孤立的或有序的.txt文件看起来像这样:

G40 Z=10
A=30 X10 Y50
A=30 X40 Y15
A=50 X39 Y14
G40 Z=11
A=30 X10 Y50
A=30 X40 Y15
A=50 X39 Y14

输出应该是一个新的.txt文件,具有以下数组格式

X Y Z
10 50 10
40 15 10
39 14 10
10 50 11
40 15 11
39 14 11

这就是我到目前为止所做的,尽管我不确定如何将我的输出写入新文件…

inputfile = open('circletest1.gcode' , 'r')
def find_between( s, first, last ):
      try:
          start = s.index( first ) + len( first )
          end = s.index( last, start )
          return s[start:end]
      except ValueError:
          return ""
for i in range(203): inputfile.next() # skip first 203 lines
while True:
    my_text = inputfile.readline()
    z = find_between(my_text, "Z =", " ")
    x = find_between(my_text, "X", " ")
    y = find_between(my_text, "Y", " ")
    print(x ," ", y, " ", z)
    if not my_text:break
inputfile.close()

有一段时间我收到缩进错误,但我相信我已经解决了这个问题。现在我得到的错误消息是"值错误:混合迭代和读取方法会丢失数据"。

我不知道从这里去哪里,也不知道如何将我的结果导入另一个单独的新txt文件。

另外,在我的代码中,是否有一种方法可以在循环之外保留z值,直到分配新的z值?

如果我理解正确,您希望将以G开头的行中的Z值与以下行中的XY值结合起来(直到下一个G行)。

如果是这样,我将使用单个循环,仅在以A开始的行上打印,并仅在以G开始的行上保存新的Z值。我将使用regex进行行解析,但如果您愿意,也可以使用简单的字符串操作(我使用split,然后跳过相关项的第一个或多个字母)。

import itertools
import re
z = None
with open('circletest1.gcode') as input_file:
    for line in itertools.islice(203, None):  # islice to skip the first 203 lines
        if line.startswith("G"):
            z = re.search(r"Z=(d+)", line).group(1)
        elif line.startswith("A"):
            x, y = re.search(r"X(d+) Y(d+)", line).groups()
            print(x, y, z)

最新更新