python-day7

2018-10-09  本文已影响0人  魅影_0d2e

一、认识列表(list)

1.什么是列表

是python中的容器类的数据类型,可以用来存储多个数据, 可变的,有序的。

可变指的是列表中的值和位置以及列表的长度可变 --->决定列表可以进行增删改

有序 --> 决定可以通过下标来获取元素

2.字面量

[元素1,元素2,元素3,,...]

[]  -->空列表

列表中的元素可以是任何类型的数据 -->包括整数,布尔,浮点,字符串,字典等

二、获取列表元素

1.获取单个元素

列表[下标]

说明:列表一旦确定,列表中每个元素的下标就确定了。下标的范围0~列表长度-1/-1~列表长度

names = ['路飞', '娜美', '索隆', '山治', '罗宾']

print(names[0], names[-4])

print(names[2])

输出的结果为:路飞 娜美

                          索隆

2.获取部分元素(切片) --->结果是个列表

和字符串切片一样。

列表[起始下标:结束下标] -->从起始下标开始,获取到结束下标前为止

列表[起始下标:结束下标:步长]

print(names[1:3])

print(names[:4:2])

print(names[::-1])

print(names[:])

输出的结果为:

['娜美', '索隆']

['路飞', '索隆']

['罗宾', '山治', '索隆', '娜美', '路飞']

['路飞', '娜美', '索隆', '山治', '罗宾']

三、增删改

films = ['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女侠']

1.增(增加元素)

a.列表.append(元素)--->在列表的最后添加一个元素

films.append('美国队长')

print(films)

输出的结果为:['绿巨人', '钢铁侠', '蜘蛛侠', '神奇女侠', '美国队长']

b.列表.insert(下标,元素)  --->在指定的下标前去添加指定的元素

films.insert(1, '雷神')

print(films)

输出的结果为:['绿巨人', '雷神', '钢铁侠', '蜘蛛侠', '神奇女侠', '美国队长']

2.删(删除列表中的元素)

a.del 列表[下标]  ---> 删除列表中指定位置的元素、

注意:del语句是python中用来删除数据的语法,可以删除任何数据

b.列表.remove(元素)  --->删除列表中的指定元素

注意:如果这个元素在列表中有多个,只删除最前面的那一个

heros=['盖伦', '维克托', '托儿索', '儿童劫']

heros.remove('儿童劫')

print(heros)

输出的结果为:['盖伦', '维克托', '托儿索']

c.列表.pop() --->将列表中最后一个元素取出

列表.pop(下标) --->将列表中指定下标对应的元素取出

beauty = ['赵丽颖', '范冰冰', '周迅', '杨颖', '杨幂']

person = beauty.pop()

print(beauty, person)

person = beauty.pop(1)

print(beauty, person)

输出的结果为:

['赵丽颖', '范冰冰', '周迅', '杨颖'] 杨幂

['赵丽颖', '周迅', '杨颖'] 范冰冰

 3.改(修改列表中的元素)

列表[下标] = 新值 --->修改指定下标对应的元素

四、练习

1.遍历列表中的元素

numbers = [12, 34, 56, 5, 25]

for x in numbers:

     print(x)

for index in range(len(numbers)):

    print(index, numbers[index])

1.用一个列表,保存一个班5个学生的成绩,去求整个班的学生的总成绩

grade = [85, 87, 94, 89, 98]

sum1 =0

for y in grade:

    print(y)

    sum1 += y

print(sum1)

输出的结果为:453

2.用一个列表,保存多个人的名字(英文的),将列表中所有人的名字首字母大写

方法一

names = ['asa', 'Her', 'sher', 'Wu']

index =0

for namein names:

# 取出首字母

    first = name[0]

# 判断首字母是否是大写

    if first.isupper():

index +=1

        continue

    # 新的名字

    new_name = name.title()

names[index] = new_name

index +=1

print(names)

# 方法二

names =  ['asa', 'Her', 'sher', 'Wu']

for indexin range(len(names)):

name = names[index]

# 判断首字母是否是小写,如果小写就变为大写

    if name[0].islower():

names[index] = name.title()

print(names)

输出的结果为:

['Asa', 'Her', 'Sher', 'Wu']

# 3.删除上一个列表中,首字母是H的人的名字

names = ['asa', 'Her', 'HaHa', 'sher', 'Wu', 'Head']

for namein names[:]:

    if name[0] =='H':

        names.remove(name)

   print(names)

# 方法二

names = ['asa', 'Her', 'HaHa', 'sher', 'Wu', 'Head']

index =0

while index<len(names):

     name = names[index]

      if name[0] =='H':

          del names[index]

          continue

    index +=1

print(names)

输出的结果为:

['asa', 'sher', 'Wu']

# 用一个列表保存一个班的学生的成绩,删除成绩中不及格的学生

scores = [23, 45, 78, 32, 90, 89, 1]

for i in scores[:]:

    if i <60:

        scores.remove(i)

print(scores)

输出的结果为:

[78, 90, 89]

五、列表相关运算

1.+

列表1+列表2 --->将列表1和列表2中的元素合并,产生一个新的列表

2.*

列表*n--->将列表中的元素重复n次,产生一个新的列表

# 3.比较运算

列表1 == 列表2 --->判断两个列表中的元素是否相等

补充:比较是否相等的两种方式,==和is

一个变量有id、value和type三个·元素

id -->地址(数据在内存中存储的地址)

value-->数据的值

type-->数据的类型

python中变量存储数据的时候存的是数据的地址(id),取出来用的值(value)

== -- >判断的是值是否相等

is -->判断的地址是否相等

六、列表相关的方法

1.in和not in

列表n in 列表2  --- > 列表n是否是列表2的元素

列表n not in 列表2  --- > 列表n是否不是列表2的元素

print([1, 2, 3]in [1, 2, 3, 4, 5])           # False

print([1, 2, 3]in [[1, 2, 3], 2, 3, 4])      # True

2.len()

len(列表) --->获取指定列表的长度

print(len([1, 2, 3]))

输出的结果为:2

3.max()和minx()

max()--->获取列表中最大的元素

min()--->获取列表中最小的元素

要求:a.列表中的元素类型要一致

b.列表中的元素是支持>操作的

list1 = [1, 2, 3, 4, 5]

print('max:', max(list1))

输出的结果为:max:5

4.list()

list(数据) --->将指定的数据转换为列表

注意:只有序列可以转换为列表

序列:字符,range,列表,字典,元祖,集合,迭代器

print(list('abcdef'))

print(list(range(5)))

输出的结果为:

['a', 'b', 'c', 'd', 'e', 'f']

[0, 1, 2, 3, 4]

5.count()

列表.count(元素)--->获取指定的元素在列表中的个数

names = ['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷']

print(names.count('千与千寻'))

输出的结果为: 1

 6.extend()

列表.extend(序列) -->将序列中的元素添加到列表中

names = ['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷']

names.extend('abc')

print(names)

输出的结果为:

['千与千寻', '龙猫', '哈尔的移动城堡', '风之谷', 'a', 'b', 'c']

 7.index()

列表.index(元素)--->获取指定元素在列表中的下标

注意:如果元素在列表中有多个,获取最前面的元素的下标,如果元素不存在,会报错

 8.reverse()

列表.reverse()  --->将列表中的元素倒序

9.sort()

列表.sort()-->将列表中得元素升序排序(从小到大)

列表.sort(reverse=True)--->将列表中的元素降序排序(从大到小)

sorted(列表)  --->将列表中的元素升序排序后生成一个新的列表(不改变原来列表)

sorted(列表, reverse=True)  --->将列表中的元素降序排序后生成一个新的列表(不改变原来列表)

要求:a.列表中的元素类型要一致

           b.列表中的元素是支持>操作的

score = [12, 89, 78, 90, 78, 100]

score.sort(reverse=True)

print(score)

score = [12, 89, 78, 90, 78, 100]

new_score =sorted(score)

print(score)

score = [12, 89, 78, 90, 78, 100]

new_score =sorted(score, reverse=True)

print(score)

10.clear()

列表.clear() -->清空列表中的元素

11.copy()

列表.copy() --->将列表中的元素复制一份产生一个新的列表,和列表[:]的功能一样

上一篇下一篇

猜你喜欢

热点阅读