无法将列表中的长字符串与列表中的短字符串连接起来

时间:2018-10-29 16:44:23

标签: python string list slice long-integer

我写了一个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)。 搜索并在键盘上猛击我的头很长时间后。 我尝试了许多排序方法,例如使用奇怪的列表理解将这些字符串转换为元组或字典,最终导致内存泄漏,还尝试了一些创造性的切片符号,以某种方式我无法正确解决,因此我寻求帮助以克服这一问题障碍,我觉得我在努力工作,他们必须解决。 预先感谢您的帮助。

2 个答案:

答案 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驱动器。