Пропустить чтение определенных частей в текстовом файле python - PullRequest
0 голосов
/ 08 апреля 2020

У меня есть файл, который выглядит следующим образом:

Solid ASCII
  facet normal -6.275966e-02 3.134884e-02 -9.975362e-01
    outer loop
      vertex   -4.624000e-01 5.000000e-01 -2.023656e-01
      vertex   -4.624742e-01 4.811628e-01 -2.029529e-01
      vertex   -5.000000e-01 5.000000e-01 -2.000000e-01
    endloop
  endface

enter image description here

Я приложил фотографию, чтобы объяснить отступ, который имеет текст в строках. Я только хочу прочитать цифры и заполнить определенный c способ, который работает, но я управляю следующим образом:

with open (r'CamaSTL.txt','r+') as infile,\
 open (r'CamaSTL2.txt','w') as outfile:
    for line in infile:
    line = infile.read()
    line = line.replace("facet normal", "")
    line = line.replace("outer loop", "")
    line = line.replace("vertex","")
    line = line.replace("endloop","")
    line = line.replace("endfacet","")
    line = line.replace("endsolid","")
outfile.write(line)

f = open('CamaSTL2.txt','r')
obj1_normal = []
obj1_v1 = []
obj1_v2 = []
obj1_v3 = []
array = []
n = []

for line in f:
    line = line.rstrip()
    if(line):
        for x in line.split():
            array.append(float(x))

i=0

while i < (len(array)):
    n=[array[i],array[i+1],array[i+2]]
    obj1_normal.append(n)
    v1 =[array[i+3], array[i+4], array[i+5]]
    obj1_v1.append(v1)
    v2 =[array[i+6],array[i+7],array[i+8]]
    obj1_v2.append(v2)
    v3 =[array[i+9],array[i+10],array[i+11]]
    obj1_v3.append (v3)
    i +=12

for row in obj1_normal:
    print (row)

Удаление слов, создание нового файла, чтение нового файла создания и разместите числа так, как я хочу. Есть ли способ не генерировать новый файл, «пропускать» чтение этих слов, а только читать и прикреплять числа? Потому что я собираюсь выполнить арифметические c операции с массивами, которые я создаю, и затем я захочу сохранить таким же образом (со словами в начале строк, потому что мне понадобится)

1 Ответ

1 голос
/ 08 апреля 2020

Я думаю, что этот подход может быть полезен для вас:


import re

fp_number_regex = re.compile(r"[-+][0-9]+\.[0-9]+[eE][-+]?[0-9]+")


def filter_floats(lines):
    for line in lines:
        r = re.findall(fp_number_regex, line)
        if r:
            yield r


if __name__ == '__main__':
    with open(r'CamaSTL.txt', 'r') as infile:
        for floats_in_line in filter_floats(infile):
            print(floats_in_line)

Вывод:

['-6.275966e-02', '-9.975362e-01']
['-4.624000e-01', '-2.023656e-01']
['-4.624742e-01', '-2.029529e-01']
['-5.000000e-01', '-2.000000e-01']

Я использую регулярное выражение (которое я нашел здесь ), чтобы соответствовать числам с плавающей запятой в строке. Функция filter_floats теперь в строке выдает список чисел с плавающей запятой, найденных в этой строке. Если их нет, линия пропускается.

...