Входные строки должны быть преобразованы в кортежи - PullRequest
0 голосов
/ 28 января 2019

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

4 * 2 ^ 3 + 4 ^ 1 2 * 1 ^ 2 + 2 ^ 3

и может быть больше строк.Что мне нужно сделать, это извлечь значение, которое находится перед знаком *, поэтому для первой строки, которая является 4.Затем мне нужно сделать кортеж g = [(2,3),(4,1)], чтобы пары кортежей были разделены +, а затем сама пара - ^.

my_input = open('input.txt').readlines()
lines = [str(line) for line in 
open('input.txt','r').read().split('\n')]
per_line = str(lines[0]).split('*')
x = int(per_line[0])
terms = str(per_line[1].split('+'))

Теперь, если я print terms, я получу ['2 ^ 3 ', ' 4 ^ 1'], а если я print x, я получу 4, так что, похоже, это работает.Но теперь мне нужно получить эти значения в описанной форме кортежа.Если я снова разделю на '^', я не получу необходимый результат, но вместо этого ["['2 ", " 3 ', ' 4 ", " 1']"], который не работает.Я попробовал это с factors = str(terms.split('^')).

Также мне нужно сделать это итерацией, чтобы она работала для всех строк, но я могу сделать это позже.Сначала я хочу убедиться, что он работает только для первой строки.

Есть предложения?

Ответы [ 4 ]

0 голосов
/ 28 января 2019

Если вы анализируете общие выражения, вы можете вместо этого построить дерево разбора:

from lark import Lark

parser = Lark('''
    ?sum: product
        | sum "+" product       -> add
        | sum "-" product       -> sub

    ?product:
        | product "*" exponent  -> mul
        | product "/" exponent  -> div
        | exponent

    ?exponent:
        | item "^" exponent     -> exp
        | item

    ?item: NUMBER               -> number
        | "-" item              -> neg
        | "(" sum ")"

    %import common.NUMBER
    %import common.WS
    %ignore WS''', start='sum')

s = '4 * 2 ^ 3 + 4 ^ 1'
tree = parser.parse(s)
print(tree.pretty())

В результате:

add
  mul
    number      4
    exp
      number    2
      number    3
  exp
    number      4
    number      1
0 голосов
/ 28 января 2019

Сначала я собрал бы все числа в строке, назначил их соответствующим кортежам, а затем назначил их списку.

my_input = open('input.txt').readlines()
lines = [str(line) for line in
open('input.txt','r').read().split('\n')]
per_line = str(lines[0]).split('*')
x = int(per_line[0])
terms = str(per_line[1].split('+'))

#Start Soln Here ->
to_parse = terms.replace('^', ',')
#Tuples to populate final list g
a = ()
b = ()
#To hold int-converted values from file stream
operands = []
for i in to_parse:
    if i.isdigit():
        operands.append(int(i))
    #to prevent the inclusion of operators.
    else:
        continue
#operands list is populated now... Last thing to do is assign them to your tuples!
a = operands[0], operands[1]
b = operands[2], operands[3]
g = [a,b]
#test output
print(g)

Возвращает

[(2, 3), (4, 1)]

Process finished with exit code 0

Этонемного болтливое решение, но оно должно сделать работу

0 голосов
/ 28 января 2019

Вот лучший способ сделать это:

import re

x = []
g = []
with open('input.txt') as infile:
    for line in infile:
        nums = re.split(r'[\*\^\+]', line)
        x.append(int(nums[0]))
        g.append((int(nums[1]), int(nums[2])))

print(x) # [4, 2]
print(g) # [(2, 3), (1, 2)]
0 голосов
/ 28 января 2019

Теперь, если я print terms, я получаю ['2 ^ 3 ', ' 4 ^ 1']

Затем для каждого значения (строки) в terms вам нужно разделить на '^', а затем привести каждый результатint и упаковать в кортеж:

g = [tuple(map(int, x.split('^'))) for x in terms]

, то есть

  1. , берущий каждую строку, например.'2 ^ 3 '
  2. разбиение его на список, например.['2 ', '3 ']
  3. применение функции int к каждому элементу списка с map
  4. , создающим кортеж результата отображения
...