0

所以我正在编写带有 a pathname、 a 的代码,signature第三个参数是 a number,它表示应扫描的子目录的深度。

所以假设我有一个文件: test

In it is test1 folder,test2 folder,antivirus.py,simple.py
In test1 folder is antivirus1.py
In test2 folder is test3 folder, and antivirus2.py
In test3 folder is antivirus3.py

所以它应该是这样工作的:

>>>scan('test',rules, 0)
test\antivirus.py, found virus Virus2
test\antivirus.py, found virus Virus1
>>>
>>>scan('test',rules, 2)
test\antivirus.py, found virus Virus2
test\antivirus.py, found virus Virus1
test\test1\antivirus1.py, found virus Virus2
test\test1\antivirus1.py, found virus Virus1
test\test2\antivirus2.py, found virus Virus2
test\test2\antivirus2.py, found virus Virus1

这是我当前的代码:

def scan(pathname, signatures, depth):
    for item in os.listdir(pathname) and depth > 0:
        n = os.path.join(pathname, item)
        try:
            scan(n, signatures, depth-1)
        except:
            f = open(n, 'r')
            s = f.read()
            for virus in signatures:
                if s.find(signatures[virus]) > 0:
                    print('{}, found virus {}'.format(n,virus))
            f.close()
4

1 回答 1

2

for循环并不是这样工作的。它们的语法是for <variable> in <iterable>.

只是我们一个if声明:

if depth <= 0:
    return

for item in os.listdir(pathname):
于 2012-11-05T03:03:14.203 回答