len()函数计算的是str的字符数
list
Python内置的一种数据类型是列表:list。list是一种有序的集合,可以随时添加和删除其中的元素。
d就是一个list
len(d)=3
其中d[0]是aaaa,d[-1]是cccc,d[-2]是bbbb
list是一个可变的有序表,所以,可以往list中追加元素到末尾
d.append('dddd')
d就变为['aaaa','bbbb','cccc',‘dddd’]
也可以把元素插入到指定的位置,比如索引号为1的位置
d.insert(1,'eeee')
要删除list末尾的元素,用pop()方法
要删除指定位置的元素,用pop(i)方法,其中i是索引位置
要把某个元素替换成别的元素,可以直接赋值给对应的索引位置
list里面的元素的数据类型也可以不同
list元素也可以是另一个list
Python的循环有两种,一种是for...in循环,依次把list或tuple中的每个元素迭代出来
for dd in d:
print(dd)
Python提供一个range()函数,可以生成一个整数序列
for i:range(101):
sum=sum+i
print(sum)
range()可以通过list()函数转换成list
如:list(range(5))
print(list(range(5)))
>>>[0,1,2,3,4]
第二种循环是while循环,只要条件满足,就不断循环,条件不满足时退出循环。
dict
Python内置了字典:dict的支持,dict全称dictionary,在其他语言中也称为map,使用键-值(key-value)存储,具有极快的查找速度。dict用大括号,list用中括号
e.g
d={'a':95,'b':85,'c':75}
print(d['a'])
>>>95
如果key不存在,dict就会报错。
要避免key不存在的错误,有两种办法:
一是通过in判断key是否存在:
print('d' in d)
>>>False
二是通过dict提供的get方法,如果key不存在,可以返回None,或者自己指定的value:
print(d.get('d')
>>>None
print(d.get('d',-1)
>>>-1
和list比较,dict有以下几个特点:
- 查找和插入的速度极快,不会随着key的增加而变慢;
- 需要占用大量的内存,内存浪费多。
而list相反:
- 查找和插入的时间随着元素的增加而增加;
- 占用空间小,浪费内存很少。
set
set和dict类似,也是一组key的集合,但不存储value。由于key不能重复,所以,在set中,没有重复的key。
要创建一个set,需要提供一个list作为输入集合:
s=set([1,2,3])
通过add(key)方法可以添加元素到set中:
s.add(4)
print(s)
>>>{1,2,3,4}
通过remove(key)方法可以删除set中元素:
s.remove(4)
print(s)
>>>{1,2,3}
set可以看成数学意义上的无序和无重复元素的集合,因此,两个set可以做数学意义上的交集、并集等操作:s1=set([1,2,3])
s2=set([2,3,4)]
print(s1&s2)
>>>{2,3}
print(s1|s2)
>>>{1,2,3,4}
凡是可作用于for
循环的对象都是Iterable
类型;
凡是可作用于next()
函数的对象都是Iterator
类型,它们表示一个惰性计算的序列;
集合数据类型如list
、dict
、str
等是Iterable
但不是Iterator
,不过可以通过iter()
函数获得一个Iterator
对象。
Python的for
循环本质上就是通过不断调用next()
函数实现的,例如:
for x in [1, 2, 3, 4, 5]:
pass
实际上完全等价于:
# 首先获得Iterator对象:
it = iter([1, 2, 3, 4, 5])
# 循环:
while True:
try:
# 获得下一个值:
x = next(it)
except StopIteration:
# 遇到StopIteration就退出循环
break