1,写代码,有如下列表,按照要求实现每一个功能

li = ['alex', 'wusir', 'eric', 'rain', 'alex']

计算列表的长度并输出

print(len(li))

答:结果为5

列表中追加元素'seven',并输出添加后的列表

li.append('seven')

print(li)

结果为:['alex', 'wusir', 'eric', 'rain', 'alex', 'seven']

请在列表的第1个位置插入元素’Tony’,并输出添加后的列表

li.insert(0, 'Tony')

print(li)

结果为:

['Tony', 'alex', 'wusir', 'eric', 'rain', 'alex']

请修改列表第2个位置的元素为’Kelly’,并输出修改后的列表

li[1] = 'Kelly'

print(li)

结果为:

['alex', 'Kelly', 'eric', 'rain', 'alex']

请将列表l2=[1, 'a', 3, 4, 'heart']的每一个元素添加到列表li中,一行代码实现,不允许循环添加。

li.extend([1, 'a', 3, 4, 'heart'])

print(li)

结果为:

['alex', 'wusir', 'eric', 'rain', 'alex', 1, 'a', 3, 4, 'heart']

请将字符串s = 'qwert'的每一个元素添加到列表li中,一行代码实现,不允许循环添加。

li.extend('qwert')

print(li)

结果为:

['alex', 'wusir', 'eric', 'rain', 'alex', 'q', 'w', 'e', 'r', 't']

请删除列表中的元素'eric',并输出添加后的列表

li.remove('eric')

print(li)

结果为:

['alex', 'wusir', 'rain', 'alex']

请删除列表中的第2个元素,并输出删除的元素和删除元素后的列表

print(li.pop(1))

print(li)

结果为:

wusir

['alex', 'eric', 'rain', 'alex']

请删除列表中的第2至4个元素,并输出删除元素后的列表

del li[1:4]

print(li)

结果为:

['alex', 'alex']

请将列表所有得元素反转,并输出反转后的列表

li.reverse()

print(li)

结果为:

['alex', 'rain', 'eric', 'wusir', 'alex']

请计算出‘alex’元素在列表li中出现的次数,并输出该次数。

print(li.count('alex'))

结果:

2

2,写代码,有如下列表,利用切片实现每一个功能

li = [1, 3, 2, 'a', 4, 'b', 5, 'c']

通过对li列表的切片形成新的列表l1,l1 = [1,3,2]

l1 = li[:3]

print(l1)

通过对li列表的切片形成新的列表l2,l2 = [’a’,4,’b’]

l2 = li[3:6]

print(l2)

通过对li列表的切片形成新的列表l3,l3 = [’1,2,4,5]

l3 = li[::2]

print(l3)

通过对li列表的切片形成新的列表l4,l4 = [3,’a’,’b’]

l4 = li[1:6:2]

print(l4)

通过对li列表的切片形成新的列表l5,l5 = [‘c’]

l5 = li[-1:-2:-1] #注意这里很容易误打成li[-1],就不是切片,而是直接赋予c字符串了。

# 补充:l5 = li[-1:]直接也是输出['c'],更优雅。

print(l5)

通过对li列表的切片形成新的列表l6,l6 = [‘b’,’a’,3]

l6 = li[-3:0:-2]

print(l6)

3,写代码,有如下列表,按照要求实现每一个功能。

lis = [2, 3, 'k', ['qwe', 20, ['k1', ['tt', 3, '1']], 89], 'ab', 'adv’']

将列表lis中的’tt’变成大写(用两种方式)。

第一种:upper方法

lis[3][2][1][0] = lis[3][2][1][0].upper()

第二种:直接索引修改

lis[3][2][1][0] = 'TT'

print(lis)

将列表中的数字3变成字符串’100’(用两种方式)。

第一种方法,直接索引位置赋值修改。

lis[1] = '100'

lis[3][2][1][1] = '100'

print(lis)

第二种方法,利用对列表的删除和插入替换。

lis.insert(1, '100')

lis.pop(2)

lis2 = ['qwe', 20, ['k1', ['tt', '100', '1']], 89]

lis.pop(3)

lis.insert(3, lis2)

print(lis)

将列表中的字符串‘1’变成数字101(用两种方式)。

第一种方法,直接索引修改:

lis[3][2][1][2] = 101

print(lis)

# 第二种方法,利用对列表的删除和插入替换

lis2 = ['qwe', 20, ['k1', ['tt', 3, 101]], 89]

lis.pop(3)

lis.insert(3, lis2)

print(lis)

4,请用代码实现:

li = ['alex','eric','rain']

利用下划线将列表的每一个元素拼接成字符串"alex_eric_rain"

答:代码实现如下:

li = ['alex','eric','rain']
s = '_'.join(li)
print(s)

5,查找列表li中的元素,移除每个元素的空格,并找出以’A’或者’a’开头,并以’c’结尾的所有元素,并添加到一个新列表中,最后循环打印这个新列表。

li = [ 'taibai ' ,'alexC' ,'AbC ',' egon', ' Ritian', ' Wusir' ,' aqc' ]

答:

li = [ 'taibai ' ,'alexC' ,'AbC ',' egon', '  Ritian', '  Wusir' ,'  aqc' ]
li2 = [ ]
#print(li2)
for i in li:
#print(i.strip())
#注意逻辑运算,要先算or再算and,所以要用优先级高的括号把or的运算先括起来。
if (i.strip().startswith('A') or i.strip().startswith('a')) and i.strip().endswith('c'):
li2.append(i.strip())
#print(li2)
for j in li2:
print(j) 最终结果为:
aqc

6、开发敏感词语过滤程序,提示用户输入评论内容,如果用户输入的内容中包含特殊的字符:

敏感词列表 li = ["苍老师","东京热",”武藤兰”,”波多野结衣”]

则将用户输入的内容中的敏感词汇替换成***,并添加到一个列表中;如果用户输入的内容没有敏感词汇,则直接添加到上述的列表中。

li = ["苍老师", "东京热", "武藤兰", "波多野结衣"]
li2 = []
comment = input("请输入评论内容:").strip()
for i in li:
if i in comment: #此条判断敏感词在不在评论中可优化省略,不过为了代码易懂,也建议保留。
comment = comment.replace(i, '*'*len(i))
#print(comment)
li2.append(comment)
#print(li2)

7,有如下列表li = [1,3,4’,alex’,[3,7,8,’taibai’],5,’ritian’]

循环打印列表中的每个元素,遇到列表则再循环打印出它里面的元素。

我想要的结果是(用两种方法实现,其中一种用range做):

1

3

4

‘alex’

3

7,

8

‘taibai’

5

ritian

第一种方法:
li = [ 1, 3, 4, 'alex', [3, 7, 8, 'taibai' ], 5, 'ritian' ]
for i in li:
if type(i) == list:
for j in i:
print(j)
else:print(i) 第二种方法:(range)
for i in range(len(li)):
if type(li[i]) == list:
for j in li[i]:
print(j)
else:
print(li[i])

铁乐与猫

2018-3-21

end

铁乐学python_day04-作业的更多相关文章

  1. 铁乐学Python_day12_作业

    1.写函数,返回一个扑克牌列表,里面有52项,每一项是一个元组 例如:[('红心',2),('草花',2), -('黑桃','A')] def poker(): suit = ['红心', '梅花', ...

  2. 铁乐学python_day10_作业

    1.继续整理函数相关知识点,写博客. 2.写函数,接收n个数字,求这些参数数字的和.(动态传参) def sum_n(*args): sum = 0 for i in args: sum += i r ...

  3. 铁乐学python_day09_作业

    练习题 1.整理函数相关知识点,写博客 2.写函数,检查获取传入列表或元组对象的所有奇数位索引对应的元素, 并将其作为新列表返回给调用者. def odd_index(l): lis = [] for ...

  4. 铁乐学Python_day08作业

    1. 文件a.txt内容:每一行内容分别为商品名字,价钱,个数. apple 10 3 tesla 100000 1 mac 3000 2 lenovo 30000 3 chicken 10 3 通过 ...

  5. 铁乐学python_Day44_IO多路复用

    目录 IO模型介绍 阻塞IO(blocking IO) 非阻塞IO(non-blocking IO) 多路复用IO(IO multiplexing) 异步IO(Asynchronous I/O) IO ...

  6. 铁乐学python_Day43_协程

    铁乐学python_Day43_协程 引子 之前我们学习了线程.进程的概念,了解了在操作系统中进程是资源分配的最小单位,线程是CPU调度的最小单位. 按道理来说我们已经算是把cpu的利用率提高很多了. ...

  7. 铁乐学python_Day42_线程池

    铁乐学python_Day42_线程池 concurrent.futures 异步调用模块 concurrent.futures模块提供了高度封装的异步调用接口 ThreadPoolExecutor: ...

  8. 铁乐学python_Day42_线程-信号量事件条件

    铁乐学python_Day42_线程-信号量事件条件 线程中的信号量 同进程的一样,Semaphore管理一个内置的计数器, 每当调用acquire()时内置计数器-1:调用release() 时内置 ...

  9. 铁乐学python_Day42_锁和队列

    铁乐学python_Day42_锁和队列 例:多个线程抢占资源的情况 from threading import Thread import time def work(): global n tem ...

  10. 铁乐学python_Day39_多进程和multiprocess模块2

    铁乐学python_Day39_多进程和multiprocess模块2 锁 -- multiprocess.Lock (进程同步) 之前我们千方百计实现了程序的异步,让多个任务可以同时在几个进程中并发 ...

随机推荐

  1. sql语句中出现笛卡尔乘积 SQL查询入门篇

    2014-12-29  凡尘工作室   阅 34985  转 95 本篇文章中,主要说明SQL中的各种连接以及使用范围,以及更进一步的解释关系代数法和关系演算法对在同一条查询的不同思路. 多表连接简介 ...

  2. DataContractSerializer数据不一致下序列化

       一.数据类型的等效性 例如下面定义的两个类成员名称.定义顺序都不一样,但是在DataContract.DataMember的Name属性作用下,两个类的实例对象序列化后的xml是一样的,因此Or ...

  3. 线程5--GCD简介

    /******************************************************/  同步函数  (1)并发队列:不会开线程  (2)串行队列:不会开线程  异步函数   ...

  4. 【转】详解spring 每个jar的作用

    spring.jar 是包含有完整发布模块的单个jar 包.但是不包括mock.jar, aspects.jar, spring-portlet.jar, and spring-hibernate2. ...

  5. JVM内存问题定位

    一.查看机器资源使用状态: 使用top命令,内存占用较高的那个PID对应的进程一般就是JVM了 二.查看Swap状态: 使用free -m 命令,一般内存占用过高会导致swap占用也偏高,看看swap ...

  6. Win10+Ubuntu双系统安装

    笔者使用的是华硕FX50J装的双系统,之前使用过Dell的游闸安装过,但是没有碰到那么多问题.所以觉得有必要记录下.安装双系统之前,电脑先安装了win10(win10也崩过几次).下面开始安装双系统步 ...

  7. linux基础学习之软件安装以及常用命令(三)

    添加和查看用户: [root@localhost ~]# useradd anderson [root@localhost ~]# cat /etc/passwd 显示如下: [root@localh ...

  8. UVAlive6807 Túnel de Rata (最小生成树)

    题意 题目链接 Sol 神仙题Orz 我们考虑选的边的补集,可以很惊奇的发现,这个补集中的边恰好是原图中的一颗生成树: 并且答案就是所有边权的和减去这个边集中的边的权值: 于是我们只需要求最大生成树就 ...

  9. hibernate、java、数据库对应类型

    引自 https://my.oschina.net/heau/blog/498874 java.数据库对应类型 类型名称 显示长度 数据库类型 JAVA类型 JDBC类型索引(int) 描述     ...

  10. JavaScript try-catch语句(错误处理)

    错误处理在处理程序设计中的重要性是毋庸置疑的,任何有影响力的web应用程序都需要一套完善的错误处理机制.当然,大多数佼佼者确实做到了这一点,但通常只有服务器端应用程序才能做到如此.实际上,服务器端团队 ...