for循环通过Python中的一组字符串列表来创建fi

2024-06-25 22:57:20 发布

您现在位置:Python中文网/ 问答频道 /正文

我正在尝试找到一种更有效的方法来过滤.csv文件中的ssid列表,然后将过滤结果写入另一个文件。你知道吗

目前,我拥有的代码如下所示(并且它按预期工作):

def ssidFilter():

    File = open("/home/pi/unFilter.csv", "r")
    for line in File:
        if 'Test SSID' in line:
            with open("/home/pi/dataLog.csv", "a") as finalFile:
                            finalFile.write(str(line))
        if 'Public' in line:
            with open("/home/pi/dataLog.csv", "a") as finalFile:
                            finalFile.write(str(line))
        if 'HomeNet' in line:
            with open("/home/pi/dataLog.csv", "a") as finalFile:
                            finalFile.write(str(line))
        if 'Network 1' in line:
            with open("/home/pi/gpsMaster/dataLog.csv", "a") as finalFile:
                            finalFile.write(str(line))
        if 'LimeOak' in line:
            with open("/home/pi/dataLog.csv", "a") as finalFile:
                            finalFile.write(str(line))
        if 'BlackCrow' in line:
            with open("/home/pi/dataLog.csv", "a") as finalFile:
                            finalFile.write(str(line))
        if 'GuestWiFi' in line:
            with open("/home/pi/dataLog.csv", "a") as finalFile:
                            finalFile.write(str(line))                                
    File.close()

但是,我想使用一个解决方案,它不会单独运行每个ssid。我想使用一个列表并遍历它。今天早上我问了一个关于zip函数的问题,但是没能用这部分代码来实现。你知道吗

我一直在做的事情(没有成功):

SSID = ['Test SSID' , 'Public' , '....etc...']
File = open("/home/pi/unFilter/csv" , "r")
for line in File:
    if SSID in line:
        with open("/home/pi/dataLog.csv", "a") as finalFile:
            finalFile.write(str(line))
File.close()                               

此命令的输出在“if SSID in line:”处产生错误,因为“TypeError:”in“需要字符串作为左操作数,而不是list。”

当用“if str(SSID)”替换“if SSID”时,我没有得到任何错误,但也没有返回任何结果,我猜这是因为它搜索的是整个字符串而不是单个元素。你知道吗

我也遇到过同样的类型错误,只是在尝试使用zip时,如果我使用正确的话,它会将其视为元组而不是列表。。你知道吗

File = open('/home/pi/unFilter.csv', 'r')
for line in File:
    for new in zip(SSID):
        if new in line:
            print line

我应该如何处理这个问题?你知道吗


Tags: csvinhomeifaswithlinepi
2条回答

您可以使用any遍历关键字

SSID = ['Test SSID' , 'Public' , '....etc...']
with open('/home/pi/unFilter.csv', 'r') as in_file:
    for line in infile:
        if any(item in line for item in SSID):
            with open("/home/pi/dataLog.csv", "a") as finalFile:
                finalFile.write(str(line))

一种解决方案是使用any(如另一个答案所述),但是在这种情况下,您可以解析 从您的SSID名称行,您可以使用更有效的解决方案只是测试成员的身份 在感兴趣的名称列表中找到SSID名称。你知道吗

下面的代码使用get_ssid函数,该函数尝试从第行获取SSID名称。你知道吗

有了SSID名称,测试就简单多了,速度也快多了。你知道吗

def ssidFilter(ssids_to_log, input_csv, output_csv):
    def get_ssid(line):
        # parse SSID from the line, return it
        # Here I assume it is first part of the line, delimited by ;
        return line.split(";", 1)[0]

    with open(input_csv) as in_f:
        with open(output_csv, "a") as out_f:
            for line in in_f:
                if get_ssid(line) in ssids_to_log:
                    out_f.write(str(line))

if __name__ == "__main__":
    ssids_to_log = ["Test SSID", "Public", "HomeNet", "Network 1",
                    "LimeOak", "BlackCrow", "GuestWiFi"]
    input_csv = "/home/pi/unFilter.csv"
    output_csv = "/home/pi/dataLog.csv"
    ssidFilter(ssids_to_log, input_csv, output_csv)

相关问题 更多 >