仓酷云

标题: 来谈谈:Python中的SET聚集操作 [打印本页]

作者: 爱飞    时间: 2015-1-14 21:04
标题: 来谈谈:Python中的SET聚集操作
小知识:对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位硬件。
作者: 柔情似水    时间: 2015-1-16 19:59
标题: 来谈谈:Python中的SET聚集操作
一定要养成在命令行下工作的习惯,要知道X-window只是运行在命令行模式下的一个应用程序。在命令行下学习虽然一开始进度较慢。
作者: 小妖女    时间: 2015-1-19 05:22
最好先搜寻一下论坛是否有您需要的文章。这样可以获得事半功倍的效果。
作者: 兰色精灵    时间: 2015-1-27 23:54
我是学习嵌入式方向的,这学期就选修了这门专业任选课。
作者: admin    时间: 2015-2-5 17:06
可以说自己收获很大,基本上完成了老师布置的任务,对于拔高的题目没有去做,因为我了解我的水平,没有时间和精力去做。?
作者: 活着的死人    时间: 2015-2-13 03:09
Linux高手更具有鼓励新手的文化精神。如何在Linux社区获得帮助,需要说明的是你要有周全的思考,准备好你的问题,不要草率的发问。
作者: 乐观    时间: 2015-3-3 13:41
众所周知,目前windows操作系统是主流,在以后相当长的时间内不会有太大的改变,其方便友好的图形界面吸引了众多的用户。
作者: 小魔女    时间: 2015-3-11 12:26
说实话小时候没想过搞IT,也计算机了解也只是一些皮毛,至于什么UNIX,Linux,听过没见过,就更别说用过了。?
作者: 再见西城    时间: 2015-3-18 18:45
linux鸟哥的私房菜,第三版,基础篇,网上有pdf下的,看它的目录和每章的介绍就行了,这个绝对原创!
作者: 冷月葬花魂    时间: 2015-3-26 16:05
众所周知,目前windows操作系统是主流,在以后相当长的时间内不会有太大的改变,其方便友好的图形界面吸引了众多的用户。




欢迎光临 仓酷云 (http://ckuyun.com/) Powered by Discuz! X3.2