Инвертирование порядка строк в списке

У меня возникли трудности с написанием программы на 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 = []
Другие вопросы по тегам