|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
小知识:对CentOS提供支持将是OpenLogic首次支持一个完整的Linux操作系统。
python的set和其他说话相似,是一个无序不反复元素集,根本功效包含关系测试和清除反复元素.聚集对象还支撑union(结合),intersection(交),difference(差)和sysmmetricdifference(对称差集)等数学运算.
sets支撑xinset,len(set),和forxinset。作为一个无序的聚集,sets不记载元素地位或许拔出点。是以,sets不支撑indexing,slicing,或其它类序列(sequence-like)的操作。
>>>basket=[’apple’,’orange’,’apple’,’pear’,’orange’,’banana’]
>>>fruit=set(basket)#createasetwithoutduplicates
>>>fruit
set([’orange’,’pear’,’apple’,’banana’])
>>>’orange’infruit#fastmembershiptesting
True
>>>’crabgrass’infruit
False
>>>#Demonstratesetoperationsonuniquelettersfromtwowords
...
>>>a=set(’abracadabra’)
>>>b=set(’alacazam’)
>>>a#uniquelettersina
set([’a’,’r’,’b’,’c’,’d’])
>>>a-b#lettersinabutnotinb
set([’r’,’d’,’b’])
>>>a|b#lettersineitheraorb
set([’a’,’c’,’r’,’d’,’b’,’m’,’z’,’l’])
>>>a&b#lettersinbothaandb
set([’a’,’c’])
>>>a^b#lettersinaorbbutnotboth
set([’r’,’d’,’b’,’m’,’z’,’l’])
len(s)
set的长度
xins
测试x能否是s的成员
xnotins
测试x能否不是s的成员
s.issubset(t)
s<=t
测试能否s中的每个元素都在t中
s.issuperset(t)
s>=t
测试能否t中的每个元素都在s中
s.union(t)
s|t
前往一个新的set包括s和t中的每个元素
s.intersection(t)
s&t
前往一个新的set包括s和t中的公共元素
s.difference(t)
s-t
前往一个新的set包括s中有然则t中没有的元素
s.symmetric_difference(t)
s^t
前往一个新的set包括s和t中不反复的元素
s.copy()
前往set“s”的一个浅复制
请留意:union(),intersection(),difference()和symmetric_difference()的非运算符(non-operator,就是形如s.union()如许的)版本将会接收任何iterable作为参数。相反,它们的运算符版本(operatorbasedcounterparts)请求参数必需是sets。如许可以免潜伏的毛病,如:为了更可读而应用set(abc)&cbs来替换set(abc).intersection(cbs)。从2.3.1版本中做的更改:之前一切参数都必需是sets。
别的,Set和ImmutableSet二者都支撑set与set之间的比拟。两个sets在也只要在这类情形下是相等的:每个set中的元素都是另外一个中的元素(两者互为subset)。一个set比另外一个set小,只要在第一个set是第二个set的subset时(是一个subset,然则其实不相等)。一个set比另外一个set打,只要在第一个set是第二个set的superset时(是一个superset,然则其实不相等)。
子set和相等比拟其实不发生完全的排序功效。例如:随意率性两个sets都不相等也不互为子set,是以以下的运算都邑前往False:a<b,a==b,或许a>b。是以,sets不供给__cmp__办法。
由于sets只界说了部门排序功效(subset关系),list.sort()办法的输入关于sets的列表没有界说。
运算符
运算成果
hash(s)
前往s的hash值
上面这个表列出了关于Set可用二关于ImmutableSet弗成用的运算:
运算符(voperator)
等价于
运算成果
s.update(t)
s|=t
前往增长了set“t”中元素后的set“s”
s.intersection_update(t)
s&=t
前往只保存含有set“t”中元素的set“s”
s.difference_update(t)
s-=t
前往删除set“t”中含有的元素后的set“s”
s.symmetric_difference_update(t)
s^=t
前往含有set“t”或许set“s”中有而不是二者都有的元素的set“s”
s.add(x)
向set“s”中增长元素x
s.remove(x)
从set“s”中删除元素x,假如不存在则激发KeyError
s.discard(x)
假如在set“s”中存在元素x,则删除
s.pop()
删除而且前往set“s”中的一个不肯定的元素,假如为空则激发KeyError
s.clear()
删除set“s”中的一切元素
请留意:非运算符版本的update(),intersection_update(),difference_update()和symmetric_difference_update()将会接收随意率性iterable作为参数。从2.3.1版本做的更改:之前一切参数都必需是sets。
还请留意:这个模块还包括一个union_update()办法,它是update()办法的一个体名。包括这个办法是为了向后兼容。法式员们应当多应用update()办法,由于这个办法也被内置的set()和frozenset()类型支撑。
小知识:Linux主要的UNIX工具软件、应用程序和网络协议。它支持32位和64位硬件。 |
|