1,写代码,有如下列列表,按照要求实现每⼀一个功能
li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
1)计算列表的长度并输出

print(len(li))
2)列表中追加元素"seven",并输出添加后的列表

li.append('seven')

print(li)
3)请在列表的第1个位置插入元素"Tony",并输出添加后的列表

li.insert(1,"Tony")

print(li)
4)请修改列表第2个位置的元素为"Kelly",并输出修改后的列表

li[2] = "kelly or li[1] = "Kelly"  # 第2个位置的索引为1

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

i in l2

li.extend(l2[i])

li.exten([1,"a",3,4,"heart"])
6)请将字符串s = "qwert"的每⼀一个元素添加到列列表li中,一⾏行代码实现,不
允许循环添加。

li.extend("qwert")
7)请删除列表中的元素"eric",并输出添加后的列表

li.remove('eric')    print(li)
8)请删除列表中的第2个元素,并输出删除的元素和删除元素后的列表

li1 = li.pop(1)#  第2个元素的索引为1

print(li1)

li.pop(2)

print(li.pop(2),li)
9)请删除列表中的第2至4个元素,并输出删除元素后的列表

del li[1:4]    #第2至 4 元素的索引分别为 1,4 
10)请将列表所有得元素反转,并输出反转后的列表

li.reverse()  print(li)
11)请计算出"alex"元素在列列表li中出现的次数,并输出该次数。

li.count("alex")  print(li.count("alex")
2,写代码,有如下列列表,利利⽤用切片实现每一个功能
li = [1, 3, 2, "a", 4, "b", 5,"c"]
1)通过对li列表的切⽚片形成新的列表l1,l1 = [1,3,2]

li[0:3]
print(li) # 输出切片后的结果

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

li[3:6]

print(li[3:6]


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

l3 = [1,2,4,5]

l3 =li[0:7:2] 或者li{::2]    print(l3)

del li[::2]  #切片 一共八个字符,或者del li[1:7:2]

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

l4 = li[1:6:2]

print(l4)

# 方法2

del li[1:6:2]

li.pop()### 将最后一位切除, 然后剩下7位元素
del li[::2]# 正向进行每两位进行切割,3,“a" "b"

5)通过对li列表的切片形成新的列表l5,l5 = ["c"]

l5 = li[-1] print[l5]

del li [-1] print(li)

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

l6 = li[-3::-2]

print(l6)

del li[-8:-3:2] li.reverse() print(li)
3,写代码,有如下列列表,按照要求实现每⼀一个功能。
lis = [2, 3, "k", ["qwe", 20, ["k1", ["tt", 3, "1"]], 89], "ab", "adv"]
1)将列表lis中的"tt"变成大写(用两种方式)。

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

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

 lis[3][2][1][0] = lis[3][2][1][0].replace("t","T")

lis.pop(3) 

lis.insert(3,["qwe", 20, ["k1", ["TT", 3, "1"]])
2)将列表中的数字3变成字符串"100"(用两种方式)。

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

@2 lis[3][2][1][1] = str(lis[3][2][1][1]+97) # str 内部做运算得100  变成字符串string

@3 lis[3][2][1][1] = str(lis[3][2][1][1].replace("3","100")

@ 4投机做法, 直接把列表替换为要求给的列表

lis.pop(3)

lis.insert(3,["qwe", 20, ["k1", ["tt", '100', "1"]], 89])  # 投机

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

lis[3][2][1][2] = 101
print(lis)

lis[3][2][1][2] = int(lis[3][2][1][2]+"01") # int 内部字符串拼接
# lis[3][2][1][2] = 101
# lis[3][2][1][2] = int(lis[3][2][1][2].replace("1", "101")) # 替换
# print(lis.index(["qwe", 20, ["k1", ["tt", 3, "1"]], 89]))


#方法2,先删除对应字段,然后再insert一个字,
lis.pop(3)
print(lis)
lis.insert(3,["k1", ["tt", 3, 101]])
print(lis)

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

# 考点 让用循环取出 li[] 中的元素,然后再添加_ .

方式一: 利用for 循环解答

s = " "

for i in li :

  s += i +"_"

print(s)

print(s.strip("_")  #  去掉末尾的_

print("{}_{}_{}".format(li[0],li[1],li[2])) 或者print("%s_%s_%s" %(li[0],li[1],li[2]))

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

#  把索引和索引的内容都打印出来
li = ["alex", "WuSir", "ritian", "barry", "wenzhou"] for i in range(len(li)):
#i是索引
#li(i) 是元素
print(i,str(li[i]))

6.利用for循环和range找出100以内所有的偶数并将这些偶数插入到一个新列表
中。(两种方法)

ln = []

for i in range(101)

  #print(i)  # 打印出0-100

  if i % 2 == 0: # 打印出 0-99 中的偶数

    #print(i)

    ln.append(i)

print(ln)

方案二:

ln = []

for i in range(0.101,2)  #  利用for循环加上步长

  ln.append(i)

print(ln)

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

a =[]
for i in range(50):
if i % 3 == 0:
# print(i)
a.append(i)
print(a)

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

# 利用for循环和range从100~1,倒序打印
a = []
for i in range(100):
a.append(i)
print(a)
# a.reverse()
# print(a) a.sort(reverse=True)
print(a)
# 方法2

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

L = []
for a in range(10,100):
if a % 2 == 0:
# a = a+2
# print(a)
L.append(a)
# print(L) # 从10 -100 打印出所有的偶数 组成一个列表
L.reverse()
# print(L)
M = []
for b in L:
if b % 4 == 0:
# print(b)
M.append(b)
print(M)

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

#思路, 能被3整除,不能被3整除,两种情况都要打印出来结果
ln = []
for i in range(1,31): # 先取出迭代变量, 赋值,
if i % 3 == 0: # 然后判断是否被3 整除
# pass
ln.append("*") # 被3整除,标记* ln.append("*")
else: # 不被3整除,
ln.append(i) # 迭代添加到list》ln的最后组成列表。
print(ln) # 最终打印出满足这两个循环条件的 列表
#方法二:
for i in range(30,0,-3)
  ln.append(i)
print(ln)

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

li = ["TaiBai ", “ale xC", “AbC ", "egon", " ri TiAn", "WuSir", " aqc"]

# lst = []
#
# for el in li:
# el = el.replace(" ", "")
# if el.capitalize().startswith("A") and el.endswith("c"):
# lst.append(el)
# print(lst)

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

# lst = []
# li = ["苍⽼师", "东京热", "武藤兰", "波多野结衣"]
#
# content = input("请输入你的评论:")
# for el in li:
# if el in content:
# content = content.replace(el,"*"*len(el))
# lst.append(content)
#
# print(lst)

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"]

for el in li:

  if type(el) != list:

    print(el.lower())

  else:

    #pass

    for el1 in el:

      if type(el1) == str:

        print(el1.lower())

      else:

        print(el1)

方法二:

for el in li:
# if type(el) == list:   # 百度, 谷歌, stackoverflow
# for el2 in el:
# if type(el2) == str:
# print(el2.lower())
# else:
# print(el2)
# else:
# if type(el) == str:
# print(el.lower())
# else:
# print(el)

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

lst = [ ]

while 1:

  content = input("输入学生信息,Q退出:")

  if content.upper() == "q":

    break

  lst.append(content.upper())

print(lst)

15. 敲七游戏. 从0开始数数. 遇到7或者7的倍数要在桌上敲一下. 编程来完成敲七 ,敲完后输出一个列表.

lst = []

n = int (input("请输入一个数:")

for num in range(0,n):

  if i % 7 == 0:

   lst.append("咣”)

  else:

    lst.append(i)

print(lst)

16. (升级题) 编写程序. 完成心动女生的筛选. (升级题)
        首先. 程序会提示用户录入10位心仪女生的姓名. 然后把10位女生的名
字和序号展示出来. 由用户选择心动女生. 此时⽤用户可以选择3个心动女生. 把用
户选中的三个心动女生的名字打印出来. 供用户继续选择. 这一次选择. 只能选
择一名女生. 然后输出用户的心动女生是xxx
  运行效果:
明日默写内容
1,将列表的增删改查不不同的方法全部写出来,
例如:增:有三种,append:在后面添加。Insert按照索引添加,
extend:迭代着添加。

Day004作业的更多相关文章

  1. python学习之老男孩python全栈第九期_数据库day004 -- 作业

    https://www.cnblogs.com/YD2018/p/9451809.html 11. 查询学过“001”并且也学过编号“002”课程的同学的学号.姓名 select student.si ...

  2. python10作业思路及源码:类Fabric主机管理程序开发(仅供参考)

    类Fabric主机管理程序开发 一,作业要求 1, 运行程序列出主机组或者主机列表(已完成) 2,选择指定主机或主机组(已完成) 3,选择主机或主机组传送文件(上传/下载)(已完成) 4,充分使用多线 ...

  3. SQLServer2005创建定时作业任务

    SQLServer定时作业任务:即数据库自动按照定时执行的作业任务,具有周期性不需要人工干预的特点 创建步骤:(使用最高权限的账户登录--sa) 一.启动SQL Server代理(SQL Server ...

  4. 使用T-SQL找出执行时间过长的作业

        有些时候,有些作业遇到问题执行时间过长,因此我写了一个脚本可以根据历史记录,找出执行时间过长的作业,在监控中就可以及时发现这些作业并尽早解决,代码如下:   SELECT sj.name , ...

  5. T-SQL检查停止的复制作业代理,并启动

        有时候搭建的复制在作业比较多的时候,会因为某些情况导致代理停止或出错,如果分发代理时间停止稍微过长可能导致复制延期,从而需要从新初始化复制,带来问题.因此我写了一个脚本定期检查处于停止状态的分 ...

  6. Python09作业思路及源码:高级FTP服务器开发(仅供参考)

    高级FTP服务器开发 一,作业要求 高级FTP服务器开发 用户加密认证(完成) 多用户同时登陆(完成) 每个用户有不同家目录且只能访问自己的家目录(完成) 对用户进行磁盘配额,不同用户配额可不同(完成 ...

  7. 个人作业week3——代码复审

    1.     软件工程师的成长 感想 看了这么多博客,收获颇丰.一方面是对大牛们的计算机之路有了一定的了解,另一方面还是态度最重要,或者说用不用功最重要.这些博客里好些都是九几年或者零几年就开始学习编 ...

  8. 个人作业-week2:关于微软必应词典的案例分析

    第一部分 调研,评测 评测基于微软必应词典Android5.2.2客户端,手机型号为MI NOTE LTE,Android版本为6.0.1. 软件bug:关于这方面,其实有一些疑问.因为相对于市面上其 ...

  9. 软件工程第二次作业——git的使用

    1. 参照 http://www.cnblogs.com/xinz/p/3803109.html 的第一题,每人建立一个GitHub账号,组长建立一个Project,将本组成员纳入此Porject中的 ...

随机推荐

  1. [转载]关于ActiveMQ集群

    转载于 http://blog.csdn.net/nimmy/article/details/6247289 近日因工作关系,在研究JMS,使用ActiveMQ作为提供者,考虑到消息的重要,拟采用Ac ...

  2. 一文了解:Redis的AOF持久化

    Redis的AOF持久化 每当Redis-Server接收到写数据时,就把命令以文本形式追加到AOF文件里,当重启Redis服务时,AOF文件里的命令会被重新执行一次,重新恢复数据.当AOF过大时将重 ...

  3. 监控JVM

    WAS配置visualVM 在was控制台:找到应用程序服务器--java和进程管理--进程定义--JAVA虚拟机/通用JVM 参数 ,对应英文Application servers > ser ...

  4. 记录一次基于docker搭建jira平台

    背景:项目需要选择不同测试平台,筛选一个最佳平台 现状:一台机器安装多套环境,虚拟机太繁琐 解决方案:通过Docker模拟安装测环境 1.pull docker 镜像: jira:7.11.1(目前的 ...

  5. 关于selenium自动化对窗口句柄的处理

    首先什么是句柄?句柄就是你点击一个页面,跳转了一个新的窗口.你要操作的元素可能在原窗口上,也有可能在新窗口上. 看下图句柄1 句柄2 由这2张图可知,url不一样,证明他们是处于不同的界面,我要操作的 ...

  6. pringboot pom文件引入本地jar包和对其打jar包

    maven引入本地jar包需要在pom文件中天剑如下配置: <dependency> <groupId>com.baidu</groupId> <artifa ...

  7. JavaScript中几种常见的兼容问题及解决方案

    在js中好用的东西一般都存在兼容问题,以下,我整理了一些常用的兼容处理方法,自己用的时候可以把他们放在一个JS文件中,需要用到时候直接引入,会比较方便. 一.获取非行内样式 function getS ...

  8. Java并发编程——线程池的使用

    在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统 ...

  9. 欧几里得(Euclid)与拓展的欧几里得算法

    欧几里得(Euclid)与拓展的欧几里得算法 欧几里得(Euclid)与拓展的欧几里得算法 欧几里得算法 原理 实现 拓展的欧几里得算法 原理 递归求解 迭代求解 欧几里得算法 原理 欧几里得算法是一 ...

  10. Nacos高可用集群解决方案-Docker版本

    文章主旨 本文目的是配置高可用的Nacos集群 架构图 整体架构为:Nginx + 3 x Nacos +高可用MySQL 高可用MySQL使用主从复制结构的可以参考Docker搭建MySQL主从集群 ...