我写了一个Python脚本,目的是从日志文件中提取硬盘信息。 我正在使用的日志文件格式错误。 因此,我像这样一起搜索所有值:
lineDict = dict([(line) for line in enumerate(hd.readlines())])
x = json.dumps(lineDict, indent = 1)
y = re.findall(r'Caption=.*[c-zC-Z]:|FileSystem=NTFS|Size=\d+|FreeSpace=\d+',x,re.M)
我所有的可用空间和大小(总大小)值都是字节,因此我必须遍历它们与其他值分开,以便快速将它们转换为int,然后再将这些字节值转换为人类可读的形式。 (MB,GB等): 我在弄乱那些“可用空间”和“总大小”值,以便在屏幕上很好地显示输出,并使用“总大小”和“可用空间”的管道分隔符:
getBytes = re.findall(r'\d+',cropHdds)
getBytes = [int(x) for x in getBytes]
valsL = []
for vals in getBytes:
hVals = convertBytes(vals)
valsL.append(hVals)
hrFixed = json.dumps(valsL, indent = 2)
hrDisplay = replaceMany(hrFixed.strip(),[("\n",""),('"',''),("'",""),(']',''),('[','')])
a = re.sub("\\s+", "", hrDisplay)
b = textwrap.fill(a, 14)
c = b.replace(","," | ")
hrValsF = c.center(60)
最后,我有两个列表: DriveL:
['C:', 'D:', 'E:', 'F:', 'G:', 'Z:']
DriveInfoL:
['52.7GB | 119.7GB', '22.9GB | 80.0GB', '25.2GB | 50.0GB']
我希望将这些值组合在一起,例如下面的示例:
C:,52.7GB | 119.7GB, D: 22.9GB | 80.0GB, E:'25.2GB | 50.0GB
我还有另一个变量在搜索“文件系统类型”,我可以知道我只有3个NTFS硬盘驱动器(C,D,E)。 搜索并在键盘上猛击我的头很长时间后。 我尝试了许多排序方法,例如使用奇怪的列表理解将这些字符串转换为元组或字典,最终导致内存泄漏,还尝试了一些创造性的切片符号,以某种方式我无法正确解决,因此我寻求帮助以克服这一问题障碍,我觉得我在努力工作,他们必须解决。 预先感谢您的帮助。
答案 0 :(得分:1)
您可以使用列表理解功能同时浏览两个列表
DriveL=['C:', 'D:', 'E:', 'F:', 'G:', 'Z:']
DriveInfoL=['52.7GB | 119.7GB', '22.9GB | 80.0GB', '25.2GB | 50.0GB']
Combined=[(x,y) for (x,y) in zip(DriveL,DriveInfoL)]
>>>Combined
>>>[('C:', '52.7GB | 119.7GB'),
('D:', '22.9GB | 80.0GB'),
('E:', '25.2GB | 50.0GB')]
答案 1 :(得分:0)
此代码段将创建一个字典,其中的键是驱动器号,值是内存:
DriveL = ['C:', 'D:', 'E:', 'F:', 'G:', 'Z:']
DriveInfoL = ['52.7GB | 119.7GB', '22.9GB | 80.0GB', '25.2GB | 50.0GB']
Drive_dict = {}
for i in range(3):
Drive_dict[DriveL[i]] = DriveInfoL[i]
仅考虑前3个条目。如果只想使用NTFS驱动器,则必须找到一种方法来找出DriveL
中的哪些条目是NTFS驱动器。