Python之 访问set

由于set存储的是无序集合,所以我们没法通过索引来访问。

访问 set中的某个元素实际上就是判断一个元素是否在set中。

例如,存储了班里同学名字的set:


>>> s = set(['Adam', 'Lisa', 'Bart', 'Paul'])


我们可以用 in 操作符判断:

Bart是该班的同学吗?


>>> 'Bart' in s True


Bill是该班的同学吗?


>>> 'Bill' in s False


bart是该班的同学吗?


>>> 'bart' in s False


看来大小写很重要,'Bart' 和 'bart'被认为是两个不同的元素。

Python之 set的特点

set的内部结构和dict很像,唯一区别是不存储value,因此,判断一个元素是否在set中速度很快。

set存储的元素和dict的key类似,必须是不变对象,因此,任何可变对象是不能放入set中的。

最后,set存储的元素也是没有顺序的。

set的这些特点,可以应用在哪些地方呢?

星期一到星期日可以用字符串'MON', 'TUE', ... 'SUN'表示。

假设我们让用户输入星期一至星期日的某天,如何判断用户的输入是否是一个有效的星期呢?

可以用 if 语句判断,但这样做非常繁琐:


x = '???' # 用户输入的字符串 if x!= 'MON' and x!= 'TUE' and x!= 'WED' ... and x!= 'SUN': print 'input error' else: print 'input ok'


注意:if 语句中的...表示没有列出的其它星期名称,测试时,请输入完整。

如果事先创建好一个set,包含'MON' ~ 'SUN':


weekdays = set(['MON', 'TUE', 'WED', 'THU', 'FRI', 'SAT', 'SUN'])


再判断输入是否有效,只需要判断该字符串是否在set中:


x = '???' # 用户输入的字符串 if x in weekdays: print 'input ok' else: print 'input error'


这样一来,代码就简单多了。

Python之 遍历set

由于 set 也是一个集合,所以,遍历 set 和遍历 list 类似,都可以通过 for 循环实现。

直接使用 for 循环可以遍历 set 的元素:


>>> s = set(['Adam', 'Lisa', 'Bart']) >>> for name in s: ... print name ... Lisa Adam Bart


注意: 观察 for 循环在遍历set时,元素的顺序和list的顺序很可能是不同的,而且不同的机器上运行的结果也可能不同。

Python之 更新set

由于set存储的是一组不重复的无序元素,因此,更新set主要做两件事:

一是把新的元素添加到set中,二是把已有元素从set中删除。

添加元素时,用set的add()方法:


>>> s = set([1, 2, 3]) >>> s.add(4) >>> print s set([1, 2, 3, 4])


如果添加的元素已经存在于set中,add()不会报错,但是不会加进去了:


>>> s = set([1, 2, 3]) >>> s.add(3) >>> print s set([1, 2, 3])


删除set中的元素时,用set的remove()方法:


>>> s = set([1, 2, 3, 4]) >>> s.remove(4) >>> print s set([1, 2, 3])


如果删除的元素不存在set中,remove()会报错:


>>> s = set([1, 2, 3]) >>> s.remove(4) Traceback (most recent call last): File "<stdin>", line 1, in <module> KeyError: 4


所以用add()可以直接添加,而remove()前需要判断。