This article looks at three different implementations of list difference sets. Difference_by for all elements in the list according to the conditional function; symmetric_difference_BY for all elements in the list according to the conditional function.

The code snippet read here is from 30-seconds-of-Python.

difference

def difference(a, b) :
  _b = set(b)
  return [item for item in a if item not in _b]

# EXAMPLES
difference([1.2.3], [1.2.4]) # [3]
Copy the code

The difference function returns the difference between two iterable objects. This function creates a set _B from B and then uses the list derivation on A, reserving only the values not contained in _B. In this function, a and B are sequentially related. A-b deletes the data contained in B from A.

A set is a special Python data type that is an unordered set of non-repeating elements. This function uses the set type directly to remove duplicate elements from a list.

difference_by

def difference_by(a, b, fn) :
  _b = set(map(fn, b))
  return [item for item in a if fn(item) not in _b]

# EXAMPLES
from math import floor
difference_by([2.1.1.2], [2.3.3.4], floor) # [1.2]
difference_by([{ 'x': 2 }, { 'x': 1 }], [{ 'x': 1}].lambda v : v['x']) # [ { x: 2 } ]
Copy the code

The difference_by function accepts two lists and a filter function. Applying the provided function to each element of the two lists returns the difference between the two original lists. The function creates a collection by applying fn to each element in B, and then combines fn with the list derivation on A, reserving only the values not contained in the previously created collection _B.

In particular, when the filter condition function is lamda x:x, the function converts to simply taking the difference between the two lists.

symmetric_difference_by

def symmetric_difference_by(a, b, fn) :
  _a, _b = set(map(fn, a)), set(map(fn, b))
  return [item for item in a if fn(item) not in _b] + [item for item in b if fn(item) not in _a]

# EXAMPLES
from math import floor
symmetric_difference_by([2.1.1.2], [2.3.3.4],floor) # [1.2, 3.4]
Copy the code

The symmetric_difference_by function returns the symmetry difference between the two original lists after applying the provided function to each list element in the two lists. The function creates two sets _A and _B by applying fn to each element in each list separately, and then combines fn with fn on each element using list understanding, reserving only values not contained in other sets created previously (in A, not in _B; In B, not in _A.) .

In particular, when the filter condition function is lamda x:x, the function is converted to directly find the difference of symmetry between the two lists.