会员合并集以后,还可能要去去除内部员工:
假定之前的得到的会员id集合,二进制表示为 '0b11001', 内部员工是会员id集合,二进制表示'0b1110'
emp_bits = '0b1110' # 内部员工二进制表示(id: 1,2,3)
emp_bit = int(emp_bits, 2)
user_id_bits = '0b11001' # 筛选出部分会员二进制表示(id: 0,3,4)
user_id_bit = int(user_id_bits, 2)
# 要去去除内部员工,类似要去
"""
内部员工 0b1110
部分会员 0b11001
筛选结果 0b10001
"""
new_user_id_bits = emp_bit & user_id_bit ^ user_id_bit
print(bin(new_user_id_bits))
这个处理两千万几id也就20m的空间左右,比用set()-set()应该可以省下不少内存