python 数据类型 datatype
python 数据类型 datatype
-
列表list
-
元组tuple
-
集合set
-
字典dictionary
-
字符串string
一、列表list
list :python的一种数据类型。是可变的,有序的对象。可以删除和增加元素。
1 列表常用的几种方法
list.append(x)
list.extend(iterable)
>>> ls=[1,2,'a',3] >>> ls.append('b') >>> ls [1, 2, 'a', 3, 'b'] >>> t=(3,7) >>> ls.extend(t) >>> ls [1, 2, 'a', 3, 'b', 3, 7] >>>
list.remove(x) 从列表中删除x 元素
list.pop(i) 返回删除的元素的值,i为索引号 ,如果不指定参数,默认从列表最后开始删除元素
list.insert(i,x) 指定在某个索引号插入一个元素x
list.count(x) 计算x 元素在列表中出现的次数
list.index(x) 返回x 元素在列表中出现的索引号,如果列表中有多个x, 返回第一个
list.copy() 复制这个列表,会产生新的对象
>>> a=ls.copy() >>> a [2, 'a', 3, 7, 3] >>> id(a) 54370632 >>> a.ppend('s') Traceback (most recent call last): File "<pyshell#22>", line 1, in <module> a.ppend('s') AttributeError: 'list' object has no attribute 'ppend' >>> a.append('s') >>> a [2, 'a', 3, 7, 3, 's'] >>> ls [2, 'a', 3, 7, 3] >>>
list.sort(key=None,reverse=False) 对列表进行排序 如果列表中有多个数据类型,直接调用sort() 会报错
list.reverse() 反转列表
2.操作
- 切片
- 索引
- 取长度len()
3.将列表当做stack 使用
>>> stack=[4,5,6] >>> stack.append('a') >>> stack.append('b') >>> stack [4, 5, 6, 'a', 'b'] >>> stack.pop() 'b' >>> stack.pop() 'a' >>>
4.将列表当做队列queue使用
>>> queue=[4,5,6] >>> queue.append(7) >>> queue.append('u') >>> queue [4, 5, 6, 7, 'u'] >>> queue.pop(0) 4 >>> queue.pop(0) 5 >>> queue [6, 7, 'u'] >>>
列表解析式list comprehension
>>> ls=[i for i in range(6)] >>> ls [0, 1, 2, 3, 4, 5]
del statement
del 语句可用来删除列表中某个元素,与pop() 返回一个value 不同,pop 可用来删除slice ,
del 也可以用来删除整个变量,当你再次引用这个名字,会引发 NameError
for example
>>> ls=[3.5,'df',478,'dfd'] >>> del ls[0] >>> ls ['df', 478, 'dfd'] >>> del ls[0:2] >>> del SyntaxError: invalid syntax >>> ls ['dfd'] >>> del ls >>> ls Traceback (most recent call last): File "<pyshell#62>", line 1, in <module> ls NameError: name 'ls' is not defined >>>
二、tuple and sequence
字符串,列表,都是序列数据类型,元组也是,都可以进行切片,索引
元组是不可变的对象
当定义一个元组,只有一个元素,要使用逗号commas,定义空元组时要用()
>>> t=1,2,3 >>> type(t) <class 'tuple'> >>> t[0] 1 >>> t[0]='asd' Traceback (most recent call last): File "<pyshell#66>", line 1, in <module> t[0]='asd' TypeError: 'tuple' object does not support item assignment >>> #but they can contain mutable object >>> v=([1,2,3],[4,53]) >>> v[0].append('a') >>> v ([1, 2, 3, 'a'], [4, 53]) >>>
>>> t (1, 2, 3) >>> x,y,z=t >>> x 1 >>> y 2 >>> z 3 >>> v2=(3,) >>> v2=() >>> type(v2) <class 'tuple'> >>>
三、集合set
A set is an unordered collection with no duplicate elements.
set 是一种无序的集合,集合里的元素不能重复
集合的特点:
- 互异性
- 无序性 :没有索引
- 确定性
在python 中,列表,字典不可放入到集合中
创建集合:创建空集合不能用{} ,要用set() ,{}会创建一个空字典
#创建集合 set1=set() #创建空集合 set1={'a','b','c',(1,2)}
定义不可变集合:
f_set_test=frozenset(set_test)
>>> f_set_test
frozenset({'l', 'e', 'h', 'o'})
集合关系运算
set2={1,2,3,4,5,6,7,8}
set3={3,4,5,6,7,8,9,10}
set2 & set3
print(set2 & set3)
print(set2 | set3)
print(set2 - set3)
in
not in
^ 对称差集
集合方法
向集合添加元素:
从集合删除元素:
remove方法如果删除的元素在集合里没有会报错,而discard 不会,返回None。pop()方法,括号里不能有参数,但是是随机删除里面的值。
difference 求差集
union 求并集
intersection求交集
isdisjoint 判断有无共同集合 ,返回布尔值
issubset 判断是不是它的子集 返回布尔值
issuperset判断是不是包含它 返回布尔值
清除集合
clear 方法
set1.clear()
四、dict 字典(无序)
字典是按键-值的关系,一个键对应一个值,键必须是不可变的数据类型。
初始化定义字典:
dic={}
常用操作
- 增加一个key-value D[key]=value
- 判断一个key在不在这个字典里 in 关键字
- 根据key取值 dic[key]
- 更新字典 update D.update(D2)
- 删除字典的key pop(key)
- 遍历字典 for loop
- 得到所有value D.values()
- 得到所有key D.keys()
- 得到所有key-value D.items()
>>> d={1:'a',2:'b',3:'c'} >>> d.items() dict_items([(1, 'a'), (2, 'b'), (3, 'c')]) >>> a=d.items() >>> type(a) <class 'dict_items'> >>> list(a) [(1, 'a'), (2, 'b'), (3, 'c')] >>> b=list(a) >>> b [(1, 'a'), (2, 'b'), (3, 'c')] >>> type(b[0]) <class 'tuple'> >>> d.keys() dict_keys([1, 2, 3]) >>> c=list(d.keys()) >>> c [1, 2, 3] >>> for i in c: print(i) 1 2 3 >>> d.values() dict_values(['a', 'b', 'c']) >>> for key,value in d.items() SyntaxError: invalid syntax >>> for key,value in d.items(): print(key,value)
把数据放入dict的方法,除了初始化时指定外,还可以通过key放入:
如果key不存在,就会报错
可以用in 来判断,或者get方法
get方法
如果不存在会返回NOne,注意:返回None
的时候Python的交互式命令行不显示结果。不能通过get来改变字典的value,这个方法只能是获得值
要删除一个key,用pop(key)
方法,对应的value也会从dict中删除
和list比较,dict有以下几个特点:
- 查找和插入的速度极快,不会随着key的增加而变慢;
- 需要占用大量的内存,内存浪费多。
而list相反:
- 查找和插入的时间随着元素的增加而增加;
- 占用空间小,浪费内存很少。
所以,dict是用空间来换取时间的一种方法