程序在第一部分代码后没有继续

Program is not continuing after first portion of code

为什么下面的代码在 'break' 之后停止?如果我在 'break' 之后插入打印语句,它将打印(例如打印 "done!")。为什么 运行 不会在 'break' 之后打开..?它们各自独立工作(作为单独的 .py 文件)。

diskDetails = open("diskDetails.txt", "r")
data = open("data.txt", "w")
searchlines = diskDetails.readlines()
for i, line in enumerate(searchlines):
    if "Failed" in line:
        for l in searchlines[i-3:i+25]: print >> data, l
        print
        break

with open('data.txt') as infile, open('dataFinal.txt', 'w') as outfile:
    for line in infile:
        if line.startswith(("ID", "State", "Capacity", "Product ID", "----")):
            outfile.write(line)

dataFinal.txt 文件是空白的,因此它似乎在 'break' 之后停止。 'break' 不只是停止 'if' 循环吗?为什么它会打印 "Done!" 而不是 'with open('data.txt')... 部分?

diskDetails.txt 包含几条记录,每条记录有 27 行(我已针对此示例缩短):

ID                              : 0:1:6
Status                          : Non-Critical
Name                            : Physical Disk 0:1:6
State                           : Failed
Power Status                    : Spun Up
Bus Protocol                    : SAS
Media                           : HDD
Part of Cache Pool              : Not Applicable
Remaining Rated Write Endurance : Not Applicable
Failure Predicted               : Yes
Revision                        : ES66
Driver Version                  : Not Applicable
Model Number                    : Not Applicable
T10 PI Capable                  : No
Certified                       : Yes

代码的第一部分获取包含 'Failed' 的记录(查找失败并且 returns 上面的 2 行 (i-3) 和下面的 25 (i+25) 并输出它到一个名为 'data.txt'.

的文件

代码的第二部分(打开...)获取 data.txt 文件,查找特定行(包含 ID、状态、容量等)并将其打印到名为 dataFinal.txt

cat dataFinal.txt
ID                              : 0:1:6
State                           : Failed
Capacity                        : 558.38 GB (599550590976 bytes)
Product ID                      : ST3600057SS

这两部分代码独立运行良好(如上所示)。我怎样才能让他们在同一个 .py 文件中一起工作? 谢谢!

好吧,最后我把你的代码分成了三个部分:

result = []

# 1. Search for the first failed entry:
with open('diskDetails.txt', 'r') as f:
    lines = f.readlines()
    for idx, line in enumerate(lines):
        if ': Failed' in line:
            result = lines[idx-3:idx+12]  # save lines from 'ID' to 'Certified'
            break  # only the first match

# 2. Filter result:
keywords = ('ID', 'State', 'Capacity', 'Product ID')
result = list(filter(lambda l: str(l).startswith(keywords), result))

# 3. Save result:
with open('dataFinal.txt', 'wt') as f:
    f.writelines(result)

# $ cat dataFinal.txt 
# ID                              : 0:1:6
# State                           : Failed