Python程序设计--第2章 python序列

灵活高效的序列,最能体现python特点的部分

#                          2   python序列
#序列的下标从0开始,支持双向索引,最右边为-1,既len(x)-1
#                          2.1列表
#一对[]中,可以修改         
#                          2.1.1 列表的创建与删除
a_list=[123,'aa',[12,23]]
a_list=[]    #空列表或  
a_list=list()  #空列表,上式更方便
#使用list()函数,可以将元组、range对象,字符串或其他类型的可迭代对象的数据转换为列表
a=(123,4,6)   #元组tuple,元组的值不可以修改
a_list=list(a)    #将tuple改为list类型
x=range(1,10,2)   #range数据类型
a_list=list(x)    #将range类型转换为list
x=list('abc123')  #['a', 'b', 'c', '1', '2', '3']

#range([start,] stop [,step])   #起点:默认值0,终止值:不包含该值,步长:默认1,返回值为range类型
#                         2.1.2   列表元素的增加
x=[1,2,3]
y=[4,5]
x=x+y   #列表的 + 运算符
x.extend(y)  #extend操作,与 + 操作效果一样

x.append(9)   #不是x=x.append(9) !!!
x.insert(-1,6)  #使6成为索引处的新值,而不是在末尾
x.insert(len(x),7)  #在末尾插入

x=[1,2]
x=x*2    #列表的 * 运算,[1, 2, 1, 2]

# 重头依次取出并删除各个元素          pop
x=[1,2,3]
while len(x)>0:
    a=x.pop(0)   #缺省为尾部取出

x=[1,2,3]
i=x.index(2)   #值不存在会抛出异常  index
b=20
if b in x:     #通过 in 判断值是否在列表中  in
    i=x.index(b)

#切片操作,起点:截止:步长,注意:截止但不包括,各个参数含义与range一致
x=[1,2,3]
y=x[1:1]   #y为[]空列表
x='abc123'
y=x[:3]  #y='abc'

x=['a','b']
y='-'.join(x)   # a-b   join函数的应用

#  列表的排序
x=[3,9,1]
x.sort()   #缺省为升序,1,3,9
x.sort(reverse=True)   #降序排列,9,3,1

#逆序排列2
x=[3,9,1]
x.sort()
x.reverse()

#python基于值的内存管理,有时它的行为与你的想象不同
x=[3,9,1]
y=x   #这里让y和x指向同一个地址,即id()值相同,对x进行的操作==对y操作,即所谓的浅复制
x[0]=2   #此时 y[0]==2       !!!

#deepcopy
import copy
x=[1,2]
y=copy.deepcopy(x)
y[0]=4
print(x)  #[1,2]


# 列表推导式,生成列表的简单方式,一句话可以代替一段代码[x for x in]
x=[i*2 for i in range(1,5)]   #[2,4,6,8]
#相当于
x=[]
for i in range(1,5):
    x.append(i*2)

x=[1,2,3,4,5,6,-1,9,-3]
y=[i for i in x if i>0]    #添加条件的列表推导式

#检索最高分名单            
scores={'zhang':80,'wang':88,'li':88,'zhao':78}
n_max=max(scores.values())
best=[name for name,score in scores.items() if score==n_max]
#列表推导式中可以使用复杂的表达式
x=['good' if i>80 else 'pass' for i in scores.values() if i>=60] 

#                2.2  元组 tuple
#简单的可将元组理解为只读的列表,其执行效率高
#元组不支持sort(),reverse()操作
x=('a')      #str类型
x=('a',)     #tuple类型,只含有一个元素
x=(1,2,3,'a','b')

#序列解包
a=(1,2,3)
x,y,z=1,2,3   #多个变量同时赋值
x,y,z=a       #利用序列解包同时给多个变量赋值
b=['a',2,3]
x,y,z=b

#      2.3 字典dict
#将dict理解为一种特殊的列表,其键为下标,便于保存键-值对数据
a={} #空字典
dic={'a':1,'b':2,'c':3}   #字典dict,key不可以重复,字符串,数字等可作为key
x,y,z=dic   #默认对键值进行操作,等效于
x,y,z=dic.keys()    #'a','b','c'
x,y,z=dic.items()   #tuple类型x=('a',1)
x,y,z=dic.values()  #1,2,3

x=dic['b']  #键值的访问,键为下标,不存在的键出发异常
x=dic.get('b',0)   #get()函数访问键值,可以设置键不存在时的默认值
dic['abc']=123     #新建或更新键值对
m_key='x'
dic[m_key]=dic.get(m_key,0)+1  #实现类似缺省字典的功能 defaultdict
dic['x']=dic.get('x',0)+1 


from collections import defaultdict
x=defaultdict(int)    #defaultdict自动初始化
x['3']+=1    #x[3]自动初始化为0

#字典的按键值排序,字典不支持.sort(),.reverse()函数
x={}
x['a']=2
x['c']=8
x['b']=5
key=list(x.keys())    #利用list函数将字典的keys()转换成list
key.sort()
for i in key:
    print(x[i])

#                2.4 集合 set
#与字典一样使用大括号,集合中每个元素都是唯一的,对于大量数据,集合的效率较高
a={3,5}    #集合赋初始值
a.add(7)   #set不支持append(),而使用add
a.add(3)   #自动忽略重复的值

#使用set函数将列表、元组等对象转换为set,自动去掉重复的值
lis_1=[1,2,3,1]
set_1=set(lis_1)   #1,2,3
x={}      #dict类型,不是空集合
x=set()   #空集合
#集合不支持sort
#集合中元素不可通过下标访问,x[0],可在for 循环中访问



#pop函数
x=[1,2,3]
y=x.pop()   #y=3,list从后面截取
x=(1,2,3)
#y=x.pop()   #tuple不支持pop操作
x={'a':1,'b':2,'c':3}
y=x.pop('b')  #dict必须有key值
x={1,2,3}
y=x.pop()    #y=1,set从前面截取


#生成不重复的随机整数函数1--使用列表
def RandomInt(number,start,end):
    data=[]
    if end-start+1<number:
        number=end-start+1
    import random
    n=0
    while n<number:
        x=random.randint(start,end)
        if x not in data:
            data.append(x)
            n+=1
    return data

x=RandomInt(6,1,100)
x=RandomInt(number=5,start=6,end=80)

x.sort()
x.reverse()


#生成不重复的随机整数函数2--使用集合
def RandomInt2(number,start,end):
    data=set()
    if end-start+1<number:
        number=end-start+1
    import random
    while len(data)<number:
        x=random.randint(start,end)
        data.add(x)
    return data

y=RandomInt2(6,1,100)
#集合不支持.sort()和.reverse()

#生成不重复的随机整数函数3--使用字典
def RandomInt3(number,start,end):
    data={}
    if end-start+1<number:
        number=end-start+1
    import random
    while len(data)<number:
        x=random.randint(start,end)
        data[x]=1
    return list(data.keys())

y=RandomInt3(6,1,100)
#小结 
#列表list支持sort、reverse,通过append新增,通过下标访问;元组tuple相当于只读list,字符串str可以当做特殊list处理。3者均可以通过下标访问。
#字典dict用于键值对的保存,不支持sort,通过键访问值;通过get()方法访问不存在的键值不触发错误,还可以赋缺省值
#集合set相当于dict的keys,通过add新增,值不重复,不可以通过下标访问。

 

posted @ 2019-07-15 09:43  notis  阅读(362)  评论(0编辑  收藏  举报