繁体   English   中英

将列表中的元组与列表进行比较,并返回唯一的元组

[英]Compare List with tuples against list and return unique tuples

好的,所以我已经进行了一段时间了,我仍然在用python砍,这似乎超出了我的范围。 我有一个元组列表和简单的旧列表(确切的术语可能有误,如果是这样,请让我知道如何正确地陈述它。我喜欢学习)。 我试图将每个元组中的值与列表中的值进行比较,并返回所有唯一元组。 所以这是我的代码(由于其中一些是内部类型的东西而被修改):

from suds.client import Client
from suds.transport.https import WindowsHttpAuthenticated
import requests, base64


soapurl = 'soapurl'
username = base64.b64decode('base64codehere').split(':')[0]
password = base64.b64decode('base64codehere').split(':')[1]
apiuser = base64.b64decode('differentbase64codehere').split(':')[0]
apipass = base64.b64decode('differentbase64codehere').split(':')[1]
ntlm = WindowsHttpAuthenticated(username=username, password=password)
client = Client(soapurl, transport=ntlm)
result = client.service.method(serverName='a1bcefg')
soapfiltered = []
for item in result[0]:
    soapfiltered.extend(list(item[i] for i in [0, 1, 6, 7]))
soapfiltered = zip(*[iter(soapfiltered)]*4)
apifiltered = []
for i in range(0, 11000, 1000):
    apiUrl = 'apiurl/?sort=id&limit=0&offset=' + str(i) +'&order=desc'
    apiData = requests.get(apiUrl, verify=False, auth=(apiuser, apipass)).json()
    for response in apiData['data']:
        apifiltered.append(str(response['hostname']))

这基本上给了我这个:

apifiltered(限制输出,因为apifiltered中几乎有3.8k响应)

['A1BCEFG001', 'A1BCEFG339', 'A1BCEFGDED444', 'A1BCEFG343', 'A1BCEFG2700', 'A1BCEFG1133', 'A1BCEFGDED321', 'A1BCEFG347', 'A1BCEFG371', 'A1BCEFG373']

soapfiltered(限制输出,因为soapfiltered中大约有4k响应)

[(63258, A1BCEFG001, A5001195, Live), (63259, A1BCEFGDED444, A5001196, Live), (63260, A1BCEFGDED321, A5001194, Live), (63261, A1BCEFGDED2743, A5001199, Live), (63262, A1BCEFG339, A5001193, Live), (63263, A1BCEFGDED2745, A5001197, Live), (63264, A1BCEFGDED2746, A5001206, Live), (63265, A1BCEFGDED2747, A5001202, Live), (63266, A1BCEFGDED2748, A5001205, Live), (63387, A1BCEFG1193, A5004312, Live)]

所以,我要尽可能做到的是这样的:

[(63261, A1BCEFGDED2743, A5001199, Live), (63263, A1BCEFGDED2745, A5001197, Live), (63264, A1BCEFGDED2746, A5001206, Live), (63265, A1BCEFGDED2747, A5001202, Live), (63266, A1BCEFGDED2748, A5001205, Live), (63387, A1BCEFG1193, A5004312, Live)]

我已经看过其他解决方案,但似乎无法获得想要的结果。 从我的工作开始,我将继续为您提供任何帮助。 如果需要任何其他信息,请询问,我将尽我所能。 谢谢。

编辑说明(TLDR;):我有一个列表:

apifiltered = ['A1BCEFG001', 'A1BCEFG339', 'A1BCEFGDED444', 'A1BCEFG343', 'A1BCEFG2700', 'A1BCEFG1133', 'A1BCEFGDED321', 'A1BCEFG347', 'A1BCEFG371', 'A1BCEFG373']

和元组列表:

soapfiltered = [(63258, A1BCEFG001, A5001195, Live), (63259, A1BCEFGDED444, A5001196, Live), (63260, A1BCEFGDED321, A5001194, Live), (63261, A1BCEFGDED2743, A5001199, Live), (63262, A1BCEFG339, A5001193, Live), (63263, A1BCEFGDED2745, A5001197, Live), (63264, A1BCEFGDED2746, A5001206, Live), (63265, A1BCEFGDED2747, A5001202, Live), (63266, A1BCEFGDED2748, A5001205, Live), (63387, A1BCEFG1193, A5004312, Live)]

我想将soapfiltered与apifiltered进行比较,并从soapfiltered中删除任何元组,其中soapfiltered中每个元组的[1]值与apifiltered中找到的值匹配。

预期结果:

expected = [(63261, A1BCEFGDED2743, A5001199, Live), (63263, A1BCEFGDED2745, A5001197, Live), (63264, A1BCEFGDED2746, A5001206, Live), (63265, A1BCEFGDED2747, A5001202, Live), (63266, A1BCEFGDED2748, A5001205, Live), (63387, A1BCEFG1193, A5004312, Live)]

还需要编辑:

@szabad给出了一个很好的答案:

expected = [tup for tup in smdbfiltered if tup[1] not in apifiltered]

因此,这很棒,但是在元组中,tup [3]不同于“ Live”,如下所示:

[(56536, A1BCEFG744-r, Retired, Prod 1CP)]

我也需要从预期结果中删除这些内容。 有人可以提供包含第一个问题和这个问题的解决方案吗?

 filtered = [tup for tup in soapfiltered if tup[3] == 'Live' and tup[1] not in apifiltered]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM