菜比之路

走菜比的路,让大牛说去吧
  博客园  :: 首页  :: 新随笔  :: 联系 :: 管理

【python】序列、元组、集合、字典和range函数

Posted on 2015-01-28 11:31  毕加索的ma  阅读(775)  评论(0编辑  收藏  举报

列表(有序):

序列的每个元素都可以用2种索引的表达方式,一种是正数索引,另一种是负数索引。

序列切片,作用是访问序列中一定范围的元素,格式“序列名[A:B]”,其中A为所切片的第一个元素的索引号,而B为切片后剩下的第一个元素的索引号。data[:]是整个data列表

 

data=[1,2,3,4,5,6,7,8,9]
print(data[3:6])
#>>>[4, 5, 6]
print(data[:])  #指没有进行切片
#>>>[1,2,3,4,5,6,7,8,9]
print( data[-3:])  #包含最后一个元素
#>>>[7, 8, 9]

  

 “步长”的引用,格式“序列名[A:B:C]”,作用按照步长进行切片,C可以为正数也可以为负数,正数是从左向右进行切片;负数时,从右向左进行切片。

data=[1,2,3,4,5,6,7,8,9]
print(data[::-1])  ##反向输出,步长默认为-1
# >>>[9, 8, 7, 6, 5, 4, 3, 2, 1]
print(data[::1])  ##正向输出,默认为1
# >>>[1, 2, 3, 4, 5, 6, 7, 8, 9]
print(data[-3::-2]) ##步长为负数,改变了切片方向
# >>>[7, 5, 3, 1]

  

 遍历列表:

方法一:

alist=["a","b","c","d","e"]
for index in range(len(alist)):
    print (alist[index]+ " index is {0:d}.".format(index))

 

方法二:

 

alist=["a","b","c","d","e"]
for index,item in enumerate(alist):##使用enumerate函数
    print ("{0:s} index is {1:d}" .format(item,index))

 

列表的常用内置方法:

 

 

range()函数

#语法range[start, end) # 步长默认为1

range(1,5) #代表从1到5(不包含5)
#>>> [1, 2, 3, 4]
range(5) #代表从0到5(不包含5) 实际等于range(0,5,1)
#>>> [0, 1, 2, 3, 4]
range(1,5,2) #代表从1到5,步长为2(不包含5)
# >>>[1, 3]

  

 

元组(有序)

用“()”包裹,也叫只读的列表。关系:列表可以改变值,元组不可以做任何更改,一般用于存储配置信息。

list(tuple): 把元组转换为列表

tuple=("a","b","c")
list=list(tuple) #把元组转换为列表
print(list)
#>>>['a', 'b', 'c']

  

字典(无序):

dic={} #创建空字典
dic["prot"]=80 #向空字典添加键值对
dic["local"]="TJ"
dic["host"]="paulwinflo"
print (dic)
#>>>{'prot': 80, 'host': 'paulwinflo'}
del dic["host"]##删除host键值对
print (dic.keys())##获取字典的所有键,返回是一个list迭代器,可以用list() 转换为列表
print (dic.values())##获取字典所有值,返回是一个list迭代器,可以用list() 转换为列表
print (dic.items())##获取键值对元组
dic.clear()##清空指点
del dic ##删除字典

  

dict():工厂函数用来创建字典,若无任何参数,则创建空字典

a=dict()  ##创建空字典
b=dict(zip(("x","y"),(2,4)))##借用zip创建字典,zip有点像拧麻花
print(b)
#>>>{'x': 2, 'y': 4}
c=dict([["x",1],["y",2]])##借用序列创建字典
print(c)
#>>>'y': 2, 'x': 1}
d=dict(x=1,y=3,c=3)##借用等式创建字典
print(d)
#>>>{'y': 3, 'x': 1, 'c': 3}

fromkeys():dict.fromkeys(seq[, value])

创建一个元素具有相同值的字典。fromkeys() 函数用于创建一个新字典,以序列 seq 中元素做字典的键,value 为字典所有键对应的初始值。

list={}.fromkeys(("x","y"),(2,4))
print(list)
#>>>{'x': (2, 4), 'y': (2, 4)}  

dict.update(dict2):函数把字典dict2的键/值对更新到dict里

dict = {'Name': 'Zara', 'Age': 7}
dict2 = {'Sex': 'female'}
dict.update(dict2)
print(dict)
#>>>{'Name': 'Zara', 'Age': 7, 'Sex': 'female'}

 

遍历字典

 

#方法一
dic = {'x': 'A', 'y': 'B', 'z': 'C' }
for k, v in dic.items():
    print (k, '=', v)

#方法二
dic = {'x': 'A', 'y': 'B', 'z': 'C' }
for item in dic:
    print (item+ "="+dic.get(item))  ##使用get比使用dic[item]安全些

  

集合(无序):

集合(set)是一个无序的不重复元素序列,他可以做关系运算(交,差、并)。 可以使用大括号 { } 或者 set() 函数创建集合,注意:创建一个空集合必须用 set() 而不是 { },因为 { } 是用来创建一个空字典。

basket = {'apple', 'orange', 'apple', 'pear', 'orange', 'banana'} ##元组
print(basket)
#>>>{'apple', 'banana', 'orange', 'pear'}
word = set('abracadabra')
print(word)
#>>>{'r', 'c', 'b', 'a', 'd'}

"""关系运算"""
list1={1,3,5,7,9}
list2={1,3,4,5,6}

##交集
print(list1.intersection(list2))
print(list1&list2)
#>>>{1, 3, 5}

##并集
print(list1.union(list2))
print(list1|list2)
#>>>{1, 3, 4, 5, 6, 7, 9}

##差集(in list1 not in list2)
print(list1.difference(list2))
print(list1-list2)
#>>>{9, 7}

"""操作"""

group={"a","b","c","d"}
group.add("e")
print(group)
#>>>{'e', 'a', 'd', 'b', 'c'}
group.remove("a")
print(group)
#>>>{'e', 'd', 'b', 'c'}
group.discard("b")  ##都是删除元素,与remove 类似,但是discard 删除不存在的元素时候不会报错,而使用remove的时候会
print(group)
#>>>{'e', 'd', 'c'}