列表和元组作业及默写


1,写代码,有如下列列表,按照要求实现每⼀一个功能
li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
1)计算列列表的⻓长度并输出
2)列列表中追加元素"seven",并输出添加后的列列表
3)请在列列表的第1个位置插⼊入元素"Tony",并输出添加后的列列表
4)请修改列列表第2个位置的元素为"Kelly",并输出修改后的列列表
5)请将列列表l2=[1,"a",3,4,"heart"]的每⼀一个元素添加到列列表li中,⼀一⾏行行代码实 现,不不允许循环添加。
6)请将字符串串s = "qwert"的每⼀一个元素添加到列列表li中,⼀一⾏行行代码实现,不不 允许循环添加。
7)请删除列列表中的元素"eric",并输出添加后的列列表
8)请删除列列表中的第2个元素,并输出删除的元素和删除元素后的列列表
9)请删除列列表中的第2⾄至4个元素,并输出删除元素后的列列表
10)请将列列表所有得元素反转,并输出反转后的列列表
11)请计算出"alex"元素在列列表li中出现的次数,并输出该次数。


2,写代码,有如下列列表,利利⽤用切⽚片实现每⼀一个功能
li = [1, 3, 2, "a", 4, "b", 5,"c"]
1)通过对li列列表的切⽚片形成新的列列表l1,l1 = [1,3,2]
2)通过对li列列表的切⽚片形成新的列列表l2,l2 = ["a",4,"b"]
3)通过对li列列表的切⽚片形成新的列列表l3,l3 = ["1,2,4,5]
4)通过对li列列表的切⽚片形成新的列列表l4,l4 = [3,"a","b"]
5)通过对li列列表的切⽚片形成新的列列表l5,l5 = ["c"]
6)通过对li列列表的切⽚片形成新的列列表l6,l6 = ["b","a",3]


3,写代码,有如下列列表,按照要求实现每⼀一个功能。
lis = [2, 3, "k", ["qwe", 20, ["k1", ["tt", 3, "1"]], 89], "ab", "adv"]
1)将列列表lis中的"tt"变成⼤大写(⽤用两种⽅方式)。
2)将列列表中的数字3变成字符串串"100"(⽤用两种⽅方式)。
3)将列列表中的字符串串"1"变成数字101(⽤用两种⽅方式)。


4,请⽤用代码实现:
li = ["alex", "eric", "rain"]
利利⽤用下划线将列列表的每⼀一个元素拼接成字符串串"alex_eric_rain"

5.利利⽤用for循环和range打印出下⾯面列列表的索引。
li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]

6.利利⽤用for循环和range找出100以内所有的偶数并将这些偶数插⼊入到⼀一个新列列表 中。

7.利利⽤用for循环和range 找出50以内能被3整除的数,并将这些数插⼊入到⼀一个新列列 表中。

8.利利⽤用for循环和range从100~1,倒序打印。

9.利利⽤用for循环和range从100~10,倒序将所有的偶数添加到⼀一个新列列表中,然后对列列表的元素进⾏行行筛选,将能被4整除的数留留下来。


10,利利⽤用for循环和range,将1-30的数字⼀一次添加到⼀一个列列表中,并循环这个列列表,将能被3整除的数改成*。

11,查找列列表li中的元素,移除每个元素的空格,并找出以"A"或者"a"开头,并以"c"结尾的所有元素,并添加到⼀一个新列列表中,最后循环打印这个新列列表。
li = ["TaiBai ", “ale xC", “AbC ", "egon", " ri TiAn", "WuSir", " aqc"]


12,开发敏敏感词语过滤程序,提示⽤用户输⼊入评论内容,如果⽤用户输⼊入的内容中 包含特殊的字符:
敏敏感词列列表 li = ["苍老师", "东京热", "武藤兰", "波多野结衣"] 则将用户输入的内容中的敏敏感词汇替换成等⻓长度的*(苍⽼老老师就替换***),
并添 加到一个列列表中;如果⽤用户输⼊入的内容没有敏敏感词汇,则直接添加到上述的列列 表中。


13,有如下列列表
li = [1, 3, 4, "alex", [3, 7, 8, "TaiBai"], 5, "RiTiAn"] 循环打印列列表中的每个元素,遇到列列表则再循环打印出它⾥里里⾯面的元素。 我想要的结果是:
1
3
4
"alex"
3
7,
8
"taibai"
5
ritian


14. 把班级学⽣生数学考试成绩录⼊入到⼀一个列列表中: 并求平均值. 要求: 录⼊入的时候 要带着⼈人名录⼊入, 例例如: 张三_44

15. 敲七游戏. 从0开始数数. 遇到7或者7的倍数要在桌上敲⼀一下. 编程来完成敲 七


16. (升级题) 编写程序. 完成⼼心动⼥女女⽣生的筛选. (升级题) 

⾸首先. 程序会提示⽤用户录⼊入10位⼼心仪⼥女女⽣生的姓名. 然后把10位⼥女女⽣生的名 字和序号展示出来.
由⽤用户选择⼼心动⼥女女⽣生. 此时⽤用户可以选择3个⼼心动⼥女女⽣生. 把⽤用 户选中的三个⼼心动⼥女女⽣生的名字打印出来.
供⽤用户继续选择. 这⼀一次选择. 只能选 择⼀一名⼥女女⽣生. 然后输出⽤用户的⼼心动⼥女女⽣生是xxx
运⾏行行效果:




明⽇日默写内容
1,将列列表的增删改查不不同的⽅方法全部写出来, 例例如:增:有三种,append:在后⾯面添加。Insert按照索引添加, extend:迭代着添加。

2,默写第,13题的实现的代码。
#  参考答案

#  1,写代码,有如下列列表,按照要求实现每⼀一个功能
li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
# 1)计算列列表的⻓长度并输出
print(len(li))
# 2)列列表中追加元素"seven",并输出添加后的列列表
li.append('seven')
print(li)
# 3)请在列列表的第1个位置插⼊入元素"Tony",并输出添加后的列列表
li.insert(0, 'Tony')
print(li)
# 4)请修改列列表第2个位置的元素为"Kelly",并输出修改后的列列表
li[1] = 'Kelly'
print(li)
# 5)请将列列表l2=[1,"a",3,4,"heart"]的每⼀一个元素添加到列列表li中,⼀一⾏行行代码实 现,不不允许循环添加。
li.extend([1,"a",3,4,"heart"])
print(li)
# 6)请将字符串串s = "qwert"的每⼀一个元素添加到列列表li中,⼀一⾏行行代码实现,不不 允许循环添加。
li.extend("qwert")
print(li)
# 7)请删除列列表中的元素"eric",并输出添加后的列列表
#题目错误
# 8)请删除列列表中的第2个元素,并输出删除的元素和删除元素后的列列表
print(li.pop(1),li)
# 9)请删除列列表中的第2⾄至4个元素,并输出删除元素后的列列表
del li[1:4]
print(li)
# 10)请将列列表所有得元素反转,并输出反转后的列列表
li.reverse()
print(li)
# 11)请计算出"alex"元素在列列表li中出现的次数,并输出该次数。
print(li.count('alex'))


# 2,写代码,有如下列列表,利利⽤用切⽚片实现每⼀一个功能
li = [1, 3, 2, "a", 4, "b", 5,"c"]
# 1)通过对li列列表的切⽚片形成新的列列表l1,l1 = [1,3,2]
li1 = li[:3]
# 2)通过对li列列表的切⽚片形成新的列列表l2,l2 = ["a",4,"b"]
l2 = li[3:6]
# 3)通过对li列列表的切⽚片形成新的列列表l3,l3 = ["1,2,4,5]
l3 = li[::2]
# 4)通过对li列列表的切⽚片形成新的列列表l4,l4 = [3,"a","b"]
l4 = li[1:6:2]
# 5)通过对li列列表的切⽚片形成新的列列表l5,l5 = ["c"]
l5 = li[-1:]###加个冒号是列表,不加是字符串
# 6)通过对li列列表的切⽚片形成新的列列表l6,l6 = ["b","a",3]
l6 = li[-3::-2]


# 3,写代码,有如下列列表,按照要求实现每⼀一个功能。
# lis = [2, 3, "k", ["qwe", 20, ["k1", ["tt", 3, "1"]], 89], "ab", "adv"]
# 1)将列列表lis中的"tt"变成⼤大写(⽤用两种⽅方式)。
# 2)将列列表中的数字3变成字符串串"100"(⽤用两种⽅方式)。
# 3)将列列表中的字符串串"1"变成数字101(⽤用两种⽅方式)。
lis = [2, 3,"k", ["qwe", 20, ["k1", ["tt", 3, "1"]], 89], "ab", "adv"]
# 1)
lis[3][2][1][0] = 'TT'
lis[3][2][1][0] = lis[3][2][1][0].upper()
lis[3][2][1][0] = lis[3][2][1][0].replace('t','T')

lis[3][2][1][0] = lis[3][2][1][0].swapcase()#大变小,小变大

# 2)
lis[1] = lis[3][2][1][1] = '100'
lis[1] = lis[3][2][1][1] = str(lis[3][2][1][1] + 97)

# 3)
lis[3][2][1][2] = 101
lis[3][2][1][2] = int(lis[3][2][1][2] + '01')
lis[3][2][1][2] = int(lis[3][2][1][2]) + 100


# 4,请⽤用代码实现:
# li = ["alex", "eric", "rain"]
# 利利⽤用下划线将列列表的每⼀一个元素拼接成字符串串"alex_eric_rain"
s = '_'.join(li)## S.join(iterable) -> str
print(s)
##老师讲解的,使用代码实现
li = ["alex", "eric", "rain"]
s = ''
for item in li:
    s += item + '_'   #累加  当每次循环都想要保留上一次循环的结果的时候就要使用累加
s = s[:-1]  #最后一个多余的'_'不要
print(s)


# 5.利利⽤用for循环和range打印出下⾯面列列表的索引。
li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
for i in range(len(li)):
    print(i)
# 6.利利⽤用for循环和range找出100以内所有的偶数并将这些偶数插⼊入到⼀一个新列列表 中。
lis6 = []
for i in range(100):
    if i % 2 == 0:
        lis6.append(i)
print(lis6)
## print(list(range(0,100,2)))#如果不使用 for 循环的话可以直接这样

# 7.利利⽤用for循环和range 找出50以内能被3整除的数,并将这些数插⼊入到⼀一个新列列 表中。
lis7 = []
for i in range(50):
    if i % 3 == 0:
        lis7.append(i)
print(lis7)

# 8.利利⽤用for循环和range从100~1,倒序打印。
for i in range(100,0,-1):
    print(i)
# 9.利利⽤用for循环和range从100~10,倒序将所有的偶数添加到⼀一个新列列表中,然后对列列表的元素进⾏行行筛选,将能被4整除的数留留下来
# #老师说使用 remove 是会出问题的,不能在遍历的时候对原来的列表进行元素的删除(估计是遍历会混乱,因为元素少了,索引就变化了)具体什么问题后面再说?????。
# 我写的错误范例
lis9 = []
for i in range(100,9,-2):
    lis9.append(i)
for i in lis9: 
    if i % 4 != 0:
        lis9.remove(i)  # 这里是会出问题的,移除元素之后,下一个元素左移,遍历的时候会跳过这个元素
print(lis9)
##现在能用的就是添加进去(老师的讲解)
lst = []
for i in range(100,9,-2):
    if i % 4 == 0:
        lst.append(i) #老师说这里是偷懒了,估计是这里并不是对列表中的元素进行的操作,而是恰巧这里的i正好是列表中的元素,归根到底还是不能在遍历的同时对列表中的元素进行删除吧
print(lst)

# 10,利利⽤用for循环和range,将1-30的数字⼀一次添加到⼀一个列列表中,并循环这个列列表,将能被3整除的数改成*。
##这样不对,改过之后没有塞回去
lis10 = []
for i in range(1,31):
    lis10.append(i)
for i in lis10: ##这个 i 就是一个中间变量,(i = lis[i],i = '*', lis[i] = i)我们只是修改了这个中间变量,没有塞回去(没有lis[i] = i 这个操作),跟原来的列表一毛钱的关系都没有
    if i % 3 == 0:
        i = '*'
print(lis10)
##方法2 对的
lis10 = []
for i in range(1,31):
    lis10.append(i)
# print(lis10)
for c in range(len(lis10)):#要修改原列表就要使用索引
    if lis10[c] % 3 == 0:
        lis10[c] = '*'
print(lis10)

# 11,查找列列表li中的元素,移除每个元素的空格,并找出以"A"或者"a"开头,并以"c"结尾的所有元素,并添加到⼀一个新列列表中,最后循环打印这个新列列表。
##我写的方法1:
li = ["TaiBai ", "ale xC", "AbC ", "egon", " ri TiAn", "WuSir", " aqc"]
lis11 = []
for i in range(len(li)):##因为是装到新列表中的,所以不用改变原来的列表就行了,即不用根据索引遍历,可以直接遍历列表拿到符合条件的元素
    li[i] = li[i].replace(' ','')
    if li[i].upper().startswith('A') and li[i].endswith('c'):
        lis11.append(li[i])
for c in lis11:
    print(c)
##老师讲解的方法2:(其实和上面的思路是一致的)
li = ["TaiBai ", "ale xC", "AbC ", "egon", " ri TiAn", "WuSir", " aqc"]
lst = []
for item in li:
    content = item.replace(' ','')#去空格
    #if (content.startswith('A') or content.startswith('a'))  and content.endswith('c'):#符合条件的元素
    if content.upper().startswith('A') and content.endswith('c'):#符合条件的元素
        lst.append(content)
print(lst)

# 12,开发敏敏感词语过滤程序,提示⽤用户输⼊入评论内容,如果⽤用户输⼊入的内容中 包含特殊的字符:
# 敏敏感词列列表 li = ["苍⽼老老师", "东京热", "武藤兰", "波多野结⾐衣"] 则将⽤用户输⼊入的内容中的敏敏感词汇替换成等⻓长度的*(苍⽼老老师就替换***),并添 加到⼀一个列列表中;如果⽤用户输⼊入的内容没有敏敏感词汇,则直接添加到上述的列列 表中。
li = ["苍⽼师", "东京热", "武藤兰", "波多野结衣"]
lis12 = []
comments = input('请输入评论内容:').strip()
for el in li:#el就是每一个敏感词
    if el in comments:#判断是否包含敏感词
        comments = comments.replace(el,'*'*len(el))#替换铭感次为等长的*
lis12.append(comments)
print(lis12)



# 13,有如下列列表
# li = [1, 3, 4, "alex", [3, 7, 8, "TaiBai"], 5, "RiTiAn"] 循环打印列列表中的每个元素,遇到列列表则再循环打印出它⾥里里⾯面的元素。 我想要的结果是:
# 1
# 3
# 4
# "alex"
# 3
# 7,
# 8
# "taibai"
# 5
# ritian
#
li = [1, 3, 4, "alex", [3, 7, 8, "TaiBai"], 5, "RiTiAn"]
# #方法1:自己写的
for el in li:
    if type(el) == list:
        for i in el:
            if type(i) == str:
                print(i.lower())
            else:
                print(i)
    elif type(el) == str:
        print(el.lower())
    elif type(el) == int:
        print(el)
##老师写的
for el in li:
    if type(el) == list:
        for item in el:#循环内层列表
            print(str(item).lower())#都转换为字符串就不用再判断类型了
    else:
        print(str(el).lower())
# 14. 把班级学⽣生数学考试成绩录⼊入到⼀一个列列表中: 并求平均值. 要求: 录⼊入的时候 要带着⼈人名录⼊入, 例例如: 张三_44
##学生的成绩不是固定的,是需要持续写入的,所以先写一个成绩录入的程序
li = []
while 1:
    content = input('请输入学生的信息(输入Q退出):')
    if content.upper() == 'Q':
        break
    else:
        lst.append(content)  # 存入的格式是li = ['张三_44','李四_67','王五_56','赵六_33']
print(li)

###下面是求平均值的程序  老师讲解的
sum = 0
for el in li:
    sum += int(el.split('_')[1])  #获取到学生成绩  el.split('_')切割之后就是个列表,直接拿到列表的第二项就行了,然后累加
print(sum/len(li))  # 获取到平均值

##下面是求平均值的程序   #这个是我自己写的
sum = 0
for el in li:
    for i in el.split('_'):  # 这里是遍历判断数字,但是这里我们已经知道切割后的列表形式是['张三','44'],所以就直接拿就行了
        if i.isdigit():
            sum += int(i)
print(sum/len(li))

# 15. 敲七游戏. 从0开始数数. 遇到7或者7的倍数要在桌上敲⼀一下. 编程来完成敲 七
##老师讲解之后: 我对这个题目的理解有误,这里替换为'咣'有两种情况,一种是数字里面含有7(即题目的'遇到7',比如17,27,70...),另一种是7的倍数(比如14,21...)
###我做的,有点麻烦  先把所有的元素添加到列表中,符合条件的元素的再修改,对原列表的修改一定会涉及到索引的调用
lst = []
n =int(input('请输入一个数字:'))
for i in range(1,n+1):#这里从1开始是由于下面的运行图是从1开始的,否则0也是7的倍数
    lst.append(i)
    if '7' in str(i) or i % 7 == 0:#这里的 i 是列表中的元素,是 int 类型的,其对应的索引是(i-1)
        lst[i-1] = ''#满足条件的元素是i,它对应的索引是(i-1)
print(lst)
###老师讲解的   先判断元素是否符合条件,符合条件的就直接加入自己需要的'咣',否则就正常的添加到列表中,只涉及到对元素的操作
lst = []
n =int(input('请输入一个数字:'))
for i in range(1,n):
    if i % 7 == 0 or '7' in str(i):
        lst.append('')
    else:
        lst.append(i)
print(lst)


# 16. (升级题) 编写程序. 完成⼼心动⼥女女⽣生的筛选. (升级题) #     ⾸首先. 程序会提示⽤用户录⼊入10位⼼心仪⼥女女⽣生的姓名. 然后把10位⼥女女⽣生的名 字和序号展示出来. 由⽤用户选择⼼心动⼥女女⽣生. 
此时⽤用户可以选择3个⼼心动⼥女女⽣生. 把⽤用 户选中的三个⼼心动⼥女女⽣生的名字打印出来. 供⽤用户继续选择. 这⼀一次选择. 只能选 择⼀一名⼥女女⽣生.
然后输出⽤用户的⼼心动⼥女女⽣生是xxx
# 运⾏行行效果: lis_10 = [] lis_3 = [] for i in range(10): like_girl_10 = input(f'请输入您心仪的女生(您还可以输入{10-i}个):').strip() lis_10.append(like_girl_10) print('您当前心仪的女生有:') for i in range(len(lis_10)): print(f'编号:{i+1},名字:{lis_10[i]}') print('请输入你更喜欢的三个女生的编号:') for ii in range(3): like_girl_3 = lis_10[int(input(f'请输入第{ii+1}个女生的编号:'))-1] lis_3.append(like_girl_3) print('更喜欢的新鲜出炉:') for ii in range(len(lis_3)): print(f'编号:{ii+1},名字:{lis_3[ii]}') print('最后了,三选一') index = int(input('输入你最喜欢的人的编号:')) print(f'程序帮你选出来了,你最喜欢的是{lis_3[index-1]}') # 明⽇日默写内容 # 1,将列列表的增删改查不不同的⽅方法全部写出来, 例例如:增:有三种,append:在后⾯面添加。Insert按照索引添加, extend:迭代着添加。 """ 添加:(记忆1,2) 1. append() 追加 2. insert(位置, 元素) 插入指定元素到指定位置 #3.extend(可迭代对象) 迭代添加 把传递进去的参数进行迭代,把每一项添加到列表的末尾 (这个了解) 删除:(记忆1,2) 1. pop(index) 根据索引删除 删除并返回索引项 2. remove(元素) 根据元素删除 删除第一次出现的指定元素,如果元素不存在则报错 #3.del 用切片或者索引删除 全局删除 不常用(是关键字???) #4.clear() 清空 修改: 索引修改 lst[索引] = 元素 坑: 如果步长不是1. 元素的个数必须要和切片的个数一致 查询: for循环. """ # 2,默写第,13题的实现的代码。 li = [1, 3, 4, "alex", [3, 7, 8, "TaiBai"], 5, "RiTiAn"] for el in li: # 获取到第一层内容 if type(el) == list: # 判断元素是否是xxx数据类型 for item in el: # 循环内层列表 print(str(item).lower()) else: print(str(el).lower())
原文地址:https://www.cnblogs.com/lyfstorm/p/10056528.html