设为首页 收藏本站
查看: 953|回复: 0

[经验分享] Python 学习入门(9)—— set操作

[复制链接]

尚未签到

发表于 2017-5-3 09:56:01 | 显示全部楼层 |阅读模式
  python 的set和其他语言类似,是一个无序、不重复元素集,基本功能包括关系测试和消除重复元素. 集合对象还支持union(联合),intersection(交),difference(差),sysmmetric_difference(对称差集)等数学运算.

sets 支持 x in set,len(set),for x in set,作为一个无序的集合,sets不记录元素位置或者插入点。因此sets不支持 indexing, slicing, 或其它类序列(sequence-like)的操作。


#!/usr/bin/env python
# it-homer in 2013
import sys
reload(sys)
sys.setdefaultencoding('utf-8')
def test_set():
x = set('ithomer')
y = set(['i', 't', 'h', 's', 'n'])
print("%s, %s" % (x, y))      # set(['e', 'i', 'h', 'm', 'o', 'r', 't']), set(['i', 'h', 's', 't', 'n'])
# 交集
print("%s" % (x&y))           # set(['i', 'h', 't'])
f = x.intersection(y)
print(f)                      # set(['i', 'h', 't'])
# 并集
print("%s" % (x|y))           # set(['e', 'i', 'h', 'm', 'o', 'n', 's', 'r', 't'])
f = x.union(y)
print(f)                      # set(['e', 'i', 'h', 'm', 'o', 'n', 's', 'r', 't'])
# 差集
print("%s" % (x-y))           # set(['m', 'r', 'e', 'o'])
f = x.difference(y)
print(f)                      # set(['m', 'r', 'e', 'o'])
print("%s" % (y-x))           # set(['s', 'n'])
f = y.difference(x)
print(f)                      # set(['s', 'n'])
# 对称差集(项在x或y中,但不会同时出现在二者中)
print("%s" %(x^y))            # set(['e', 'm', 'o', 'n', 's', 'r'])
print("%s" %(y^x))            # set(['s', 'r', 'e', 'm', 'o', 'n'])
f = x.symmetric_difference(y) # set(['e', 'm', 'o', 'n', 's', 'r'])
print(f)
f = y.symmetric_difference(x) # set(['s', 'r', 'e', 'm', 'o', 'n'])
print(f)

a = [11, 22, 33, 44, 11, 33, 22]
b = set(a)
print(b)              # set([33, 11, 44, 22])
for i in b:
print i,            # 不换行输出 : 33 11 44 22

def test_set2():
s = set([1, 3, 5, 7, 9])
t = set("ithomer")
print(t)              # set(['e', 'i', 'h', 'm', 'o', 'r', 't'])
# 并集  
print("%s" % (s|t))   # set([1, 3, 'e', 5, 7, 'i', 9, 'm', 'o', 'r', 't', 'h'])
# 交集
print("%s" % (t&s))   # set([])
# 差集
print("%s" % (t-s))   # set(['e', 'i', 'h', 'm', 'o', 'r', 't'])
print("%s" % (s-t))   # set([7, 1, 3, 5, 9])
# 对称差集
print("%s" % (t^s))   # set([1, 3, 'e', 5, 7, 'i', 9, 'm', 'o', 'r', 't', 'h'])

print(t)              # set(['e', 'i', 'h', 'm', 'o', 'r', 't'])
t.add('y')
t.add('g')
print(t)              # set(['e', 'g', 'i', 'h', 'm', 'o', 'r', 't', 'y'])

try:
print(len(t))       # 9
t.remove('Y')
except Exception, e:
print e             # 'Y'
print(len(t))         # 9
t.remove('y')
print(len(t))         # 8

def test_set3():
s = set('ithomer')
t = set('home')
# 测试 x 是否是 s 的成员
f = 'i' in s
print(f)              # True
# 测试 x 是否不是 s 的成员
f = 'i' not in s
print(f)              # False
# 测试是否 t 中的每一个元素都在 s 中
f = t.issubset(s)
print(f)              # True
# 测试是否 t 中的每一个元素都在 s 中
f = s.issuperset(t)
print(f)              # True
# 浅复制  
print(s)              # set(['e', 'i', 'h', 'm', 'o', 'r', 't'])
f = s.copy()
print(f)              # set(['r', 'e', 't', 'i', 'h', 'm', 'o'])
f = hash('i')
print(f)

def test_set4():
s = set('ithomer')
t = set('home123')
# s |= t
s.update(t)      
print(s)              # set(['e', 'i', 'h', 'm', 'o', '1', '3', 'r', 't', '2'])

s = set('ithomer')
# s &= t
s.intersection_update(t)
print(s)              # set(['h', 'e', 'm', 'o'])
s = set('ithomer')
# s -= t
s.difference_update(t)
print(s)              # set(['i', 'r', 't'])

s = set('ithomer')
# s ^= t
s.symmetric_difference_update(t)
print(s)              # set(['i', '1', '3', 'r', 't', '2'])

s = set('ithomer')
print(s)              # set(['e', 'i', 'h', 'm', 'o', 'r', 't'])
s.add('I')
print(s)              # set(['e', 'i', 'h', 'm', 'o', 'I', 'r', 't'])
s.remove('i')         
print(s)              # set(['e', 'h', 'm', 'o', 'I', 'r', 't'])
s.discard('I')
print(s)              # set(['e', 'h', 'm', 'o', 'r', 't'])
s.pop()
print(s)              # set(['h', 'm', 'o', 'r', 't'])
s.clear()
print(s)              # set([])

if __name__ == "__main__":
#  test_set()
#  test_set2()
test_set3()
#  test_set4()

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-372405-1-1.html 上篇帖子: CityEngine使用Python脚本导出模型 下篇帖子: python类型转换、序列操作、数值操作
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表