目录

序列

切片

乘法

检查 in

序列有关函数

列表

遍历列表

添加、修改和删除列表元素

列表统计 次数、下标、求和

排序  sort()

生成列表 /列表推导式

元组 tuple

推导式与列表不同


python中常用5中序列结构:

列表、元组、集合、字典、字符串。

序列

切片

访问元素的一个方法

sname[start:end:step]

 包括开始位置,不包括end位置,step默认为1

nba = ["迈克尔•乔丹","比尔•拉塞尔","卡里姆阿卜杜勒•贾巴尔","威尔特•张伯伦",
      "埃尔文•约翰逊","科比•布莱恩特","蒂姆•邓肯","勒布朗•詹姆斯","拉里•伯德",
      "沙奎尔•奥尼尔"]
print(nba[1:5])     # 获取第2个到第5个元素
print(nba[0:5:2])   # 获取第1个、第3个和第5个元素

['比尔•拉塞尔', '卡里姆阿卜杜勒•贾巴尔', '威尔特•张伯伦', '埃尔文•约翰逊']
['迈克尔•乔丹', '卡里姆阿卜杜勒•贾巴尔', '埃尔文•约翰逊']

 nba[:]或者nba表示输出所有。

相同类型序列可以直接相加  +  ,,,但是不能是列表加元素

num = [7,14,21,28,35,42,49,56]
nba = ["史蒂芬•库里","克莱•汤普森","马努•吉诺比利","凯文•杜兰特"]
print(num + nba)

[7, 14, 21, 28, 35, 42, 49, 56, '史蒂芬•库里', '克莱•汤普森', '马努•吉诺比利', '凯文•杜兰特']

num+“开心就好”     这是错误的

乘法

就是重复n遍,也可以用来创建指定长度列表

phone = ["huawei","xiaomi","iphone"]
print(phone*3)

emptylist = [None]*5
print(emptylist)

['huawei', 'xiaomi', 'iphone', 'huawei', 'xiaomi', 'iphone', 'huawei', 'xiaomi', 'iphone']
[None, None, None, None, None]

检查 in

phone = ["huawei","xiaomi","iphone"]
print(phone)
print("huawei" in phone)

['huawei', 'xiaomi', 'iphone']
True

序列有关函数

len(listname):返回列表长度

min(listname):返回列表最小元素

max(listname):返回列表最大元素

sum():求和

sorted():排序

list():将序列转为列表

str():将序列转为字符串

reversed():反向序列中的元素

enumerate()将序列组合为一个索引序列,多用在for循环中

--------------------------------------------------------------------------------------

列表

del listname :删除列表

遍历列表

for item in listname

#输出 item
for index,item in enumerate(listname):
    #输出index 与 item
print("2018年俄罗斯世界杯四强:")
team = ["法国","比利时","英格兰","克罗地亚"]
for index,item in enumerate(team):
    print(index + 1,item)

2018年俄罗斯世界杯四强:
1 法国
2 比利时
3 英格兰
4 克罗地亚

添加、修改和删除列表元素

 添加 insert()与append()

phone = ["摩托罗拉","诺基亚","三星","OPPO"]
print(len(phone))    # 获取列表的长度
phone.append("iPhone")
print(len(phone))        # 获取列表的长度
print(phone)

4
5
['摩托罗拉', '诺基亚', '三星', 'OPPO', 'iPhone']

 

phone = ["摩托罗拉","诺基亚","三星","OPPO"]
print(len(phone))    # 获取列表的长度
phone.insert(2,"iPhone")
print(len(phone))        # 获取列表的长度
print(phone)

4
5
['摩托罗拉', '诺基亚', 'iPhone', '三星', 'OPPO']

 修改元素 

verse = ["德国队小组赛回家","西班牙传控打法还有未来吗","C罗一人对抗西班牙队"]
print(verse)
verse[2] = "梅西、C罗相约回家"    # 修改列表的第3个元素
print(verse)

['德国队小组赛回家', '西班牙传控打法还有未来吗', 'C罗一人对抗西班牙队']
['德国队小组赛回家', '西班牙传控打法还有未来吗', '梅西、C罗相约回家']

 删除元素  del       remove

verse = ["德国队小组赛回家","西班牙传控打法还有未来吗","C罗一人对抗西班牙队"]
del verse[-1]
print(verse)

['德国队小组赛回家', '西班牙传控打法还有未来吗']

 name.remove(obj)   删除指定元素

列表统计 次数、下标、求和

listname.count(obj)

listname.index(obj)    obj首次出现的下标,不存在则抛出异常

sum(iterable[,start])  求和 iterable表示要求和的列表

grade = [98,99,97,100,100,96,94,89,95,100]    # 10名学生语文成绩列表
total = sum(grade)                              # 计算总成绩
print("Python理论总成绩为:",total)

Python理论总成绩为: 968

 

grade = [98,99,97,100,100,96,94,89,95,100]    # 10名学生语文成绩列表
total = sum(grade,10)                             
print("Python理论总成绩为:",total)

Python理论总成绩为: 978

grade = [98,99,97,100,100,96,94,89,95,100]    # 10名学生语文成绩列表
total = sum(grade[0:1],10)
print("Python理论总成绩为:",total)

 Python理论总成绩为: 108

排序  sort()

与sorted()有区别,sorted()会建立一个副本

listname.sort(key=None, reverse=False)

key 表示指定一个从每个列表元素中提取一个用于比较的键(key=str.lower  表示在排序是不区分字母大小写)

False表示升序,True表示降序

grade = [98,99,97,100,100,96,94,89,95,100]    # 10名学生Python理论成绩列表
print("原列表:",grade)
grade.sort()                                     # 进行升序排列
print("升  序:",grade)
grade.sort(reverse=True)                        # 进行降序排列
print("降  序:",grade)

原列表: [98, 99, 97, 100, 100, 96, 94, 89, 95, 100]
升  序: [89, 94, 95, 96, 97, 98, 99, 100, 100, 100]
降  序: [100, 100, 100, 99, 98, 97, 96, 95, 94, 89]

生成列表 /列表推导式

import random                                           #导入random标准库
randomnumber = [random.randint(10,100) for i in range(10)]
print("生成的随机数为:",randomnumber)
price = [1200,5330,2988,6200,1998,8888]
sale = [int(x*0.5) for x in price]
print("原价格:",price)
print("打五折的价格:",sale)
price = [1200,5330,2988,6200,1998,8888]
sale = [x for x in price if x>5000]
print("原列表:",price)
print("价格高于5000的:",sale)

生成的随机数为: [73, 82, 43, 31, 40, 60, 83, 29, 41, 75]
原价格: [1200, 5330, 2988, 6200, 1998, 8888]
打五折的价格: [600, 2665, 1494, 3100, 999, 4444]
原列表: [1200, 5330, 2988, 6200, 1998, 8888]
价格高于5000的: [5330, 6200, 8888]

元组 tuple

用括号(非必须) 包围,逗号分隔的元素

verse1 = ("世界杯冠军",)
print("verse1的类型为",type(verse1))
verse2 = ("世界杯冠军")
print("verse2的类型为",type(verse2))

verse1的类型为 <class 'tuple'>
verse2的类型为 <class 'str'>

创建元组

print(tuple(range(10,20,2)))

(10, 12, 14, 16, 18)

 可以切片 可以用 for 遍历

推导式与列表不同

import random                                  #导入random标准库
randomnumber = (random.randint(10,100) for i in range(10))
randomnumber = tuple(randomnumber)           # 转换为元组
print("转换后:",randomnumber)

转换后: (75, 93, 65, 71, 58, 82, 49, 73, 71, 72)

 

number = (i for i in range(3))
print(number.__next__())      # 输出第1个元素
print(number.__next__())      # 输出第2个元素
print(number.__next__())      # 输出第3个元素
number = tuple(number)  # 转换为元组
print("转换后:",number)

0
1
2
转换后: ()

 

number = (i for i in range(4))     # 生成生成器对象
for i in number:                    # 遍历生成器对象
    print(i,end=" ")                # 输出每个元素的值
print(tuple(number))                # 转换为元组输出

0 1 2 3 ()

遍历后,原生成器对象已经不存在了! 

********************************************************

模拟购物车购物过程答案

list1=[]
for i in range(5):
    list1.append(input("请输入商品编号和商品名称进行商品入库,每次只能输入一件商品:\n"))
print(list1[:])
# print("请输入要购买的商品的编号:")
list2 = []
p = 0
for ji in range(0, 100):
    num = input("请输入要购买的商品的编号:\n")
    if num != "q":
        for item in list1:
             if item.find(num) == 0:
                list2.append(item)
                print("商品已添加到购物车,请继续添加要购买商品的商品编号")
    else:
        p = 1
        break
    if p == 1:
        break
print(list2)