2018-08-27-列表

2018-08-27  本文已影响0人  fanzl

一、认识列表(list)

1,列表的声明[]

声明了一个列表,列表中有5个元素,分别是90,100,34,98,89
score=[90,100,34,98,89]
print(score,type(score))
声明了一个变量,列表中的元素可以是不同数据类型
person=['樊振霖',21,'男']
print(person)

[]代表空列表

name=[]

2,将其他数据类型转换成列表(只有序列才能转换:字符串和range,字典,元祖,集合,生成式和迭代器)

chars=list('abcdef')  #将字符串转换成列表
print(chars)

numbers=list(range(10))  #将range()转换成列表
print(numbers)

二、列表的增删改查

1,查

1.1、获取单个元素:列表[下标]
tv_names=['请回答1988','琅琊榜','甄嬛传','生化危机']
print(tv_names[1],tv_names[-3])
1.2,获取部分元素(切片):list[下标1:下标2]/list[下标1:下标2:步进]
print(tv_names[1:3])
print(tv_names[-1:-4:-2])
1.3,遍历(一个一个的获取每个元素)
number=0
scores=[89,93,94,78,75,92]
for score in scores:
    if score>=80:
        number+=1
print('超过80的有%d个'%(number))

2,改(修改元素的值)

#修改列表中下标为1的元素的值
person=['小明',35,'乒乓球']
person[1]=20
print(person)

3,增(增加元素个数)

3.1、列表.append(元素),在列表的最后添加一个元素
person.append('男')
3.2、列表.insert(下标,元素),在指定的下标前插入一个元素
person.insert(0,'001')
print(person,type(person[0]))
# 练习:录入5个学生的成绩,并且保存在一个列表中
scores=[]
for x in range(5):
    score=input('请输入第%d个学生成绩:'%(x+1))
    scores.append(int(score))
print(scores,type(scores[3]))

4,删(删除列表中的元素)

4.1,del 列表[下标]
food=['辣条','棒棒糖','大蒜','火锅','饼干']
del food[2] #删除下标是2的元素
print(food)
4.2 ,列表.remove(元素)————删除列表中的某个值
food.remove('饼干')
print(food)
4.3,列表.pop(下标)————将列表中指定下标对应的元素取出来
food1=food.pop(1)
print(food,food1,sep='\n')
想进一切办法,将一个保存成绩列表中,成绩低于60的全部删除
[78,59,40,90,89,45,69,30]——>[78,90,89,69]
score1=[78,59,40,90,89,45,69,30]
for x in score1[:]:
    if x<60:
        score1.remove(x)
        print(score1)

以后遍历列表的元素的时候,我们一般遍历它的拷贝的值'[:]'

5、 python中,变量在存数据的值的时候,会根据数据类型的不同,使用,两种方式来存储

三、列表相关的运算

1、 '+操作'

2、 ‘*操作’

3,in/not in

4,列表的长度

5,相关的方法

a,列表.count(元素):统计指定元素在列表中出现次数
number=[1,2,3,4,4,4,4,5,5,5]
print(number.count(5))
b,列表.extend(序列):将序列中的元素添加到列表中
number.extend([1,2,3])
print(number)
c,列表.index(元素):获取指定元素对应的第一个下标
index=number.index(3)
print(index)
d,列表.pop(下标):省略下标将列表中最后一个元素取出
e,列表.reverse():将列表反序
numbers=[1,2,3,4,5]
numbers.reverse()
print(numbers)
f,列表.sort():对列表元素进行排序,默认是升序
numbers.sort()
print(numbers)
g,列表.clear():将列表中的所有元素清除
numbers.clear()
print(numbers)
h,列表.copy():将列表中的所有元素全部拷贝一份产生一个新的列表,相当于列表[:]

这儿的拷贝是浅拷贝

numbers=[1,2,3,4]
number2=numbers.copy()
print(number2)

6、深拷贝和浅拷贝

number1=[1,2]
numbers=[number1,3,4,'abc']

new_numbers=numbers.copy()
print(new_numbers)

import copy
new_numbers2=copy.deepcopy(numbers)
print(new_numbers2)

number1.append(100)
print(new_numbers)
print(new_numbers2)

四、认识元祖

tuple(元祖)

1,声明元祖

tuple1=(1,2,'abc',True,[1,2])
print(tuple1,type(tuple1))

注意,如果要写一个只有一个元素的元祖,需要在元素后面再加一个逗号

t2=(100,)
print(t2,type(t2))
t3=()
print(t3,type(t3))

2.查相关的

t3=('red','yellow','green','pink')
print(t3[2])
print(t3[0:3])

for item in t3:
    print(item)

3,特殊操作

point1=(100,200)
print(point1[0])
x,y=point1
print(x,y)

user=('小陆',90,98,89,100,'男')
name,*score,sex=user
print(name,score,sex)

user2=('小红',90,98,89,100,)
name,*score=user2
print(name,score)

*score,name,sex=('小红',90,98,89,100,189)
print(score,name,sex)
a=1,2,3,4  #相当于a=(1,2,3,4)

x,y=100,200 #相当于x,y=(100,200)
print(x,y)
上一篇下一篇

猜你喜欢

热点阅读