从文本文件创建表时,输出会重复多次

时间:2016-04-23 13:16:15

标签: python python-3.x text input output

我在使用文本文件中的值创建表时遇到了一些麻烦。我的文本文件如下所示:

e432,6/5/3,6962,c8429,A,4324
e340,2/3/5,566623,c1210,A,3201
e4202,6/5/3,4232,c8419,E,4232
e3230,2/3/5,66632,c1120,A,53204
e4202,6/5/3,61962,c8429,A,4322

我想生成一个包含数组的表,其中:最后一列(amountpaid)值小于第三列(最终总数),如果第五列(状态)等于'A'。在减去最终总金额和支付金额时,可以找到优秀总金额。

我生成表格的代码是:

data = open("pJoptionc.txt", "r")
info=data.readlines()
data.close
for li in info:
        status=li.split(",")[4]
        finaltotal=int(li.split(",")[2])
        amountpaid=int(li.split(",")[5])
        totalrev=0
        headers = ["Estimate Number", "Date", "Final Total", "Customer Number", "Status", "Amount Paid", "Outstanding Amount"]
        print("    ".join(headers))
        for line in open("pJoptionc.txt", "r"):
            line = line.strip().split(",")
            line.append(str(int(line[2]) - int(line[5])))
            if line[2] == line[5] or line[4] in ("E"):
                continue
            for i, word in enumerate(line):
                print(word.ljust(len(headers[i - (i > 4)])), end="    " * ((i - (i > 4)) != len(headers) - 1))
            print()
            outstandingrev =(finaltotal) - (amountpaid) 
    totalrev += int(outstandingrev)
    print("The total amount of outstanding revenue is...")
    print("£",totalrev)

我想要的输出是

Estimate Number    Date    Final Total    Customer Number    Status    Amount Paid    Outstanding Amount
e432               6/5/3    6962           c8429              A         4324           2638           
e340               2/3/5    566623         c1210              A         3201           563422         
e3230              2/3/5    66632          c1120              A         53204          13428          
e4202              6/5/3    61962          c8429              A         4322           57640          
The total amount of outstanding revenue is...
£ 13428

但是,当我运行代码时,输​​出是反复重复的表,负值在未结数量列中。我正在使用python 3.4.3。

2 个答案:

答案 0 :(得分:0)

你在循环中再次读取文件,所以它会重复你在表格中的每一行。试着这样做: (注意这次文件行上只有for个循环)

headers = ["Estimate Number", "Date", "Final Total", "Customer Number", "Status", "Amount Paid", "Outstanding Amount"]
print("    ".join(headers))
data = open("pJoptionc.txt", "r")
info=data.readlines()
data.close()
totalrev=0
for li in info:
    line = li.strip().split(",")
    status=line[4]
    finaltotal=int(line[2])
    amountpaid=int(line[5])

    line.append(str(int(line[2]) - int(line[5])))
    if line[2] == line[5] or line[4] in ("E"):
        continue
    for i, word in enumerate(line):
        print(word.ljust(len(headers[i - (i > 4)])), end="    " * ((i - (i > 4)) != len(headers) - 1))
    print()
    outstandingrev =(finaltotal) - (amountpaid) 
    totalrev += int(outstandingrev)
print("The total amount of outstanding revenue is...")
print("£",totalrev)

**旁注:您可能想查看csv模块: this article

答案 1 :(得分:0)

该表一遍又一遍地重复,因为您读取了脚本顶部的文件,然后再次为文件中的每一行重新打开文件。

以下是使用namedtuple的一种方法:

from collections import namedtuple

# define a named tuple for storing each line (record)
fields = ['Estimate_Number', 'Date', 'Final_Total', 'Customer_Number', 'Status', 'Amount_Paid']
record = namedtuple('record', fields)

# first print the header
for field in fields:
    print('%-17s' % field.replace('_', ' '), end='')
print('Outstanding')

totalOutstanding = 0

# open the file using a context manager (the with keyword)
with open("pJoptionc.txt", "r") as data:

    for line in data:

        # strip the newline character, split on the comma and create a record
        row = record(*line.strip().split(','))

        # we can access each field by name now to make the code more readable  
        outstanding = int(row.Final_Total) - int(row.Amount_Paid)

        # print the output
        if outstanding:
            for field in fields:
                print('%-17s' % getattr(row, field), end='')
            print(outstanding)
            totalOutstanding += outstanding

print('Total Outstanding is... %s' % totalOutstanding)

参考文献: