列表元素的修改
一.列表
service = ['https','ftp','ssh','mysql']
#通过索引,重新赋值
service[0] = 'http' ##通过索引改变列表service的第一个元素
print(service)
# 通过切片赋值
service[:2] = ['samba','dns','firewalld'] ##通过切片更改列表service的前两个元素
print(service)
service = ['ftp','http','ssh','http','ftp','mysql','ssh']
##查看元素在列表中出现的次数
print(service.count('ftp'))
##查看指定元素的索引值()
print(service.index('ssh')) ##查看指定元素的索引值,默认显示靠前的
print(service.index('ssh',4,7)) ##查看指定元素的索引值,并指定索引范围
二.排序
service = ['ftp','http','ssh','http','ftp','mysql','ssh']
##默认是按照ASCII码进行排序的
service.sort()
print(service)
service.sort(reverse=True) ##逆序
print(service)
import random ##用数字呈现ASCII的排序,导入随机模块
li = list(range(0,101)) ##按照正常从小到大的顺序
print(li)
random.shuffle(li) ##随机排列
print(li)
列表的练习
“”"
(1)有一个列表,其中包括 10 个元素,
例如这个列表是[1,2,3,4,5,6,7,8,9,0],
要求将列表中的每个元素一次向前移动一个位置,
第一个元素到列表的最后,然后输出这个列表。
最终样式是[2,3,4,5,6,7,8,9,0,1]
(2)问题描述:按照下面的要求实现对列表的操作:
产生一个列表,其中有 40 个元素,每个元素是 50 到 100 的一个随机整数
如果这个列表中的数据代表着某个班级 40 人的分数,请计算成绩低于平均分的学生人数
对上面的列表元素从大到小排序并输出li.sort(reverse=True)
“”"
(1)
# li = [1,2,3,4,5,6,7,8,9,0]
# print(li)
# li2 = li.pop(0)
# print(li2)
# li.append(li2)
# print(li)
(2)
import random
score = []
**# 循环40次**
for count in range(40):
num = random.randint(50,100) ##num值的范围
score.append(num)
print('40人的分数为:',score)
sum_score = sum(score) ##成绩求和
print(sum_score)
ave_num = sum_score/40
**# 将小于平均成绩的成绩找出来 组成新的列表 并求列表的长度**
less_ave = []
for i in score: ##遍历列表score
if i < ave_num:
less_ave.append(i)
long = len(less_ave)
print(long)
print('平均分数为:%.1f' %(ave_num))
print('有%d个学生低于平均分数:'%(long))
score.sort(reverse=True) ##从大到小排序
print('排序结果:',score)
排序:
scores = (100,89,45,77,65)
##第一种方式
scoreli = list(scores) ##转换为列表,两种方式列表都可以
scoreli.sort()
print(scoreli)
##第二种方式 ##直接对元组排序(元组概念看下一节)
scores = sorted(scores)
print(scores)