Python学习笔记(十)——小甲鱼第二十八、二十九讲

Python学习笔记(十)——小甲鱼第二十八、二十九讲

0、确保里边元素的唯一性

 

1、用frozenset()

 

2、用函数len()

 

3、会报错,因为集合是无序的

 

4、不一样

>>> set1 = {[1,2]}

Traceback (most recent call last):

  File "<pyshell#0>", line 1, in <module>

    set1 = {[1,2]}

TypeError: unhashable type: 'list'

>>> set2 = set([1,2])

>>> set2

{1, 2}

Python学习笔记(十)——小甲鱼第二十八、二十九讲

5、

>>> set1={1,1.0}

>>> set1

 

6、利用add()和remove()

 

 

集合(s).方法名

等价符号

方法说明

s.issubset(t)

s <= t

子集测试(允许不严格意义上的子集):s 中所有的元素都是 t 的成员

 

s < t

子集测试(严格意义上):s != t 而且 s 中所有的元素都是 t 的成员

s.issuperset(t)

s >= t

超集测试(允许不严格意义上的超集):t 中所有的元素都是 s 的成员

 

s > t

超集测试(严格意义上):s != t 而且 t 中所有的元素都是 s 的成员

s.union(t)

s | t

合并操作:s "或" t 中的元素

s.intersection(t)

s & t

交集操作:s "与" t 中的元素

s.difference

s - t

差分操作:在 s 中存在,在 t 中不存在的元素

s.symmetric_difference(t)

s ^ t

对称差分操作:s "或" t 中的元素,但不是 s 和 t 共有的元素

s.copy()

 

返回 s 的拷贝(浅复制)

以下方法仅适用于可变集合

   

s.update

s |= t

将 t 中的元素添加到 s 中

s.intersection_update(t)

s &= t

交集修改操作:s 中仅包括 s 和 t *有的成员

s.difference_update(t)

s -= t

差修改操作:s 中包括仅属于 s 但不属于 t 的成员

s.symmetric_difference_update(t)

s ^= t

对称差分修改操作:s 中包括仅属于 s 或仅属于 t 的成员

s.add(obj)

 

加操作:将 obj 添加到 s

s.remove(obj)

 

删除操作:将 obj 从 s 中删除,如果 s 中不存在 obj,将引发异常

s.discard(obj)

 

丢弃操作:将 obj 从 s 中删除,如果 s 中不存在 obj,也没事儿^_^

s.pop()

 

弹出操作:移除并返回 s 中的任意一个元素

s.clear()

 

清除操作:清除 s 中的所有元素

 

Python学习笔记(十)——小甲鱼第二十八、二十九讲

Python学习笔记(十)——小甲鱼第二十八、二十九讲

 

打开模式

执行操作

'r'

以只读方式打开文件(默认)

'w'

以写入的方式打开文件,会覆盖已存在的文件

'x'

如果文件已经存在,使用此模式打开将引发异常

'a'

以写入模式打开,如果文件存在,则在末尾追加写入

'b'

以二进制模式打开文件

't'

以文本模式打开(默认)

'+'

可读写模式(可添加到其他模式中使用)

'U'

通用换行符支持

 

文件对象方法

执行操作

f.close()

关闭文件

f.read([size=-1])

从文件读取size个字符,当未给定size或给定负值的时候,读取剩余的所有字符,然后作为字符串返回

f.readline([size=-1])

从文件中读取并返回一行(包括行结束符),如果有size有定义则返回size个字符

f.write(str)

将字符串str写入文件

f.writelines(seq)

向文件写入字符串序列seq,seq应该是一个返回字符串的可迭代对象

f.seek(offset, from)

在文件中移动文件指针,从from(0代表文件起始位置,1代表当前位置,2代表文件末尾)偏移offset个字节

f.tell()

返回当前在文件中的位置

f.truncate([size=file.tell()])

截取文件到size个字节,默认是截取到文件指针当前位置

 

0、第二种

 

1、默认为可读、文本的模式打开

 

2、可写入二进制模式

 

3、避免缓存数据丢失

 

4、list(f)

 

5、

for each_line in f:

print(each_line)

 

6、返回从文件指针开始的连续10个字符

 

7、f.tell()

 

8、因为f.seek()定位的文件指针是按字节为单位进行计算的,而record.txt是以GBK进行编码,f.seek(46)刚好位于字符“小”的中间位置,因此按照GBK编码的形式无法将其解码