Инвертирование порядка строк в списке
У меня возникли трудности с написанием программы на Python. Я хотел бы, чтобы программа считала строки между набором символов, изменила порядок строк и затем записала их в новый файл. Ввод:
AN10 G17 G21 G90
N20 '2014_12_08_Banding_Test_4
N30 M3 S1B
N40G00X0.000Y0.000Z17.000
N50 G00X0.001Y0.001Z17.000
N60 G01Z0.000F3900.0
N70 G01X0.251
N80 G01X149.999
N90 G01Y0.251
N100 G01X149.749
N110 G01X149.499Z-8.169
N120 G01X148.249Z-8.173
N130 G01X146.999Z-8.183
N140 G01X145.499Z-8.201
...
N3140 G01Y0.501
Пока что мой код:
with open('Source.nc') as infile, open('Output.nc', 'w') as outfile:
copy = False
strings_A = ("G01Y", ".251")
strings_B = ("G01Y", ".501")
content = infile.readlines()
for lines in content:
lines.splitlines(1)
if all(x in lines for x in strings_A):
copy = True
elif all(x in lines for x in strings_B):
copy = False
elif copy:
outfile.writelines(reversed(lines))
Я думаю, что я не понимаю что-то о разнице между строками и многострочными строками. Я был бы очень признателен за помощь здесь!
Заранее спасибо, Артур
1 ответ
Строка имеет несколько строк, если она содержит символы новой строки \n
,
Вы можете думать о файле как об одной длинной строке, содержащей символы новой строки:
s = infile.read()
Или вы можете рассматривать это как список строк:
lines = infile.readlines()
Если у вас есть многострочная строка, вы можете разбить ее на список строк:
lines = s.splitlines(False)
# which is basically a special form of:
lines = s.split('\n')
Если вы хотите построчно обрабатывать файл, все следующие методы эквивалентны (в действительности, если не в эффективности):
with open(filename, 'r') as f:
s = f.read()
lines = s.splitlines()
for line in lines:
# do something
pass
with open(filename, 'r') as f:
lines = f.readlines()
for line in lines:
# do something
pass
# this last option is the most pythonic one,
# it uses the fact that any file object can be treated as a list of lines
with open(filename, 'r') as f
for line in f:
# do something
pass
РЕДАКТИРОВАТЬ Теперь решение вашей проблемы:
with open('Source.nc') as infile, open('Output.nc', 'w') as outfile:
copy = False
strings_A = ("G01Y", ".251")
strings_B = ("G01Y", ".501")
target_lines = []
for line in infile:
if copy and all(x in line for x in strings_B):
outfile.writelines(reversed(target_lines))
break
if copy:
target_lines.append(line)
if all(x in line for x in strings_A):
copy = True
Это скопирует все строки между строкой, которая соответствует all(x in line for x in strings_A)
и строка, которая соответствует all(x in line for x in strings_B)
в выходной файл в обратном порядке. Идентификационные строки НЕ включены в вывод (я надеюсь, что это было намерение). Порядок if
пункты намеренно для достижения этой цели.
Также имейте в виду, что идентификационные тесты (all(x in line for x in strings_A)
) вы используете, работаете как поиск по подстроке, а не по совпадению слов, опять же, я не знаю, было ли это вашим намерением.
РЕДАКТИРОВАТЬ2 В ответ на комментарий:
with open('Source.nc') as infile, open('Output.nc', 'w') as outfile:
strings_A = ("G01Y", ".251")
strings_B = ("G01Y", ".501")
do_reverse = False
lines_to_reverse = []
for line in infile:
if all(x in line for x in strings_B):
do_reverse = False
outfile.writelines(reversed(lines_to_reverse))
outfile.writeline(line)
continue
if do_reverse:
lines_to_reverse.append(line)
continue
else:
outfile.writeline(line)
if all(x in line for x in strings_A):
do_reverse = True
lines_to_reverse = []