巧用Python中set集合对比两个文本文件

"""
1.读取文件
2.使用set集合
s.add( x )  添加
x in s 是否在集合中
>>> basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'}
>>> print(basket)                      # 这里演示的是去重功能
{'orange', 'banana', 'pear', 'apple'}
>>> 'orange' in basket                 # 快速判断元素是否在集合内
True
>>> 'crabgrass' in basket
False

>>> # 下面展示两个集合间的运算.
...
>>> a = set('abracadabra')
>>> b = set('alacazam')
>>> a                                  
{'a', 'r', 'b', 'c', 'd'}
>>> a - b                              # 集合a中包含而集合b中不包含的元素
{'r', 'd', 'b'}
>>> a | b                              # 集合a或b中包含的所有元素
{'a', 'c', 'r', 'd', 'b', 'm', 'z', 'l'}
>>> a & b                              # 集合a和b中都包含了的元素
{'a', 'c'}
>>> a ^ b                              # 不同时包含于a和b的元素
{'r', 'd', 'b', 'm', 'z', 'l'}
"""
print('s')
def file_2_set(filepath):
    with open(filepath,'rt',encoding='utf-8') as f:
        lines=f.readlines()
        print(type(lines))
        # print(lines)
        set2 = set(lines)
        print(str(filepath)+" length: "+str(len(set2)))
        # for line in lines:
        #     print(type(lines))
        return set2
def a_b(a,b):
    print("[+]包含"+str(a)+"不包含"+str(b))
    return a-b
def aorb(a,b):
    print("两个集合之和")
    return (a|b)
def ajiaob(a,b):
    print("[+] 都包含的:")
    return(a&b)
def anotb(a,b):
    print("不同时包含的")
    return (a^b)

def main():
    filepath="/etc/passwd"
    file_2_set(filepath)
if __name__ =="__main__":
    main()
posted @ 2023-07-31 23:21  菜就多练forever  阅读(30)  评论(0编辑  收藏  举报