程序在第一部分代码后没有继续
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
为什么下面的代码在 '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