ich wissen muss, wenn ein dict in einen anderen enthalten ist, 3 in Python rekursiv:Recusively Test, wenn dict in dict enthalten
first = {"one":"un", "two":"deux", "three":"trois" , "sub": { "s1": "sone" }}
second = {"one":"un", "two":"deux", "three":"trois", "foo":"bar", "sub": { "s1": "sone", "s2": "stwo"}}
Verwendung von Wörterbuch Ansichten in Test if dict contained in dict beschrieben wie eine sehr schöne Art und Weise ist , behandelt aber keinen Rekursionsfall.
kam ich mit dieser Funktion auf:
def isIn(inside, outside):
for k, v in inside.items():
try:
if isinstance(v,dict):
if not isIn(v, outside[k]):
return False
else:
if v != outside[k]:
return False
except KeyError:
return False
return True
Welche Arbeit:
>>> first.items() <= second.items()
False
>>> isIn(first, second)
True
Aber gibt es eine bessere (pythonic) Art und Weise?
Wenn das erste Argument leer ist, wird jedes zweites Argument den Test bestehen. Zum Beispiel: 'isIn ({}, 9999) == Wahr '. – FMc