我有一个程序,它从.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
值与以下行中的X
和Y
值结合起来(直到下一个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)