Day004作业
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作业的更多相关文章
- python学习之老男孩python全栈第九期_数据库day004 -- 作业
https://www.cnblogs.com/YD2018/p/9451809.html 11. 查询学过“001”并且也学过编号“002”课程的同学的学号.姓名 select student.si ...
- python10作业思路及源码:类Fabric主机管理程序开发(仅供参考)
类Fabric主机管理程序开发 一,作业要求 1, 运行程序列出主机组或者主机列表(已完成) 2,选择指定主机或主机组(已完成) 3,选择主机或主机组传送文件(上传/下载)(已完成) 4,充分使用多线 ...
- SQLServer2005创建定时作业任务
SQLServer定时作业任务:即数据库自动按照定时执行的作业任务,具有周期性不需要人工干预的特点 创建步骤:(使用最高权限的账户登录--sa) 一.启动SQL Server代理(SQL Server ...
- 使用T-SQL找出执行时间过长的作业
有些时候,有些作业遇到问题执行时间过长,因此我写了一个脚本可以根据历史记录,找出执行时间过长的作业,在监控中就可以及时发现这些作业并尽早解决,代码如下: SELECT sj.name , ...
- T-SQL检查停止的复制作业代理,并启动
有时候搭建的复制在作业比较多的时候,会因为某些情况导致代理停止或出错,如果分发代理时间停止稍微过长可能导致复制延期,从而需要从新初始化复制,带来问题.因此我写了一个脚本定期检查处于停止状态的分 ...
- Python09作业思路及源码:高级FTP服务器开发(仅供参考)
高级FTP服务器开发 一,作业要求 高级FTP服务器开发 用户加密认证(完成) 多用户同时登陆(完成) 每个用户有不同家目录且只能访问自己的家目录(完成) 对用户进行磁盘配额,不同用户配额可不同(完成 ...
- 个人作业week3——代码复审
1. 软件工程师的成长 感想 看了这么多博客,收获颇丰.一方面是对大牛们的计算机之路有了一定的了解,另一方面还是态度最重要,或者说用不用功最重要.这些博客里好些都是九几年或者零几年就开始学习编 ...
- 个人作业-week2:关于微软必应词典的案例分析
第一部分 调研,评测 评测基于微软必应词典Android5.2.2客户端,手机型号为MI NOTE LTE,Android版本为6.0.1. 软件bug:关于这方面,其实有一些疑问.因为相对于市面上其 ...
- 软件工程第二次作业——git的使用
1. 参照 http://www.cnblogs.com/xinz/p/3803109.html 的第一题,每人建立一个GitHub账号,组长建立一个Project,将本组成员纳入此Porject中的 ...
随机推荐
- [转载]关于ActiveMQ集群
转载于 http://blog.csdn.net/nimmy/article/details/6247289 近日因工作关系,在研究JMS,使用ActiveMQ作为提供者,考虑到消息的重要,拟采用Ac ...
- 一文了解:Redis的AOF持久化
Redis的AOF持久化 每当Redis-Server接收到写数据时,就把命令以文本形式追加到AOF文件里,当重启Redis服务时,AOF文件里的命令会被重新执行一次,重新恢复数据.当AOF过大时将重 ...
- 监控JVM
WAS配置visualVM 在was控制台:找到应用程序服务器--java和进程管理--进程定义--JAVA虚拟机/通用JVM 参数 ,对应英文Application servers > ser ...
- 记录一次基于docker搭建jira平台
背景:项目需要选择不同测试平台,筛选一个最佳平台 现状:一台机器安装多套环境,虚拟机太繁琐 解决方案:通过Docker模拟安装测环境 1.pull docker 镜像: jira:7.11.1(目前的 ...
- 关于selenium自动化对窗口句柄的处理
首先什么是句柄?句柄就是你点击一个页面,跳转了一个新的窗口.你要操作的元素可能在原窗口上,也有可能在新窗口上. 看下图句柄1 句柄2 由这2张图可知,url不一样,证明他们是处于不同的界面,我要操作的 ...
- pringboot pom文件引入本地jar包和对其打jar包
maven引入本地jar包需要在pom文件中天剑如下配置: <dependency> <groupId>com.baidu</groupId> <artifa ...
- JavaScript中几种常见的兼容问题及解决方案
在js中好用的东西一般都存在兼容问题,以下,我整理了一些常用的兼容处理方法,自己用的时候可以把他们放在一个JS文件中,需要用到时候直接引入,会比较方便. 一.获取非行内样式 function getS ...
- Java并发编程——线程池的使用
在前面的文章中,我们使用线程的时候就去创建一个线程,这样实现起来非常简便,但是就会有一个问题: 如果并发的线程数量很多,并且每个线程都是执行一个时间很短的任务就结束了,这样频繁创建线程就会大大降低系统 ...
- 欧几里得(Euclid)与拓展的欧几里得算法
欧几里得(Euclid)与拓展的欧几里得算法 欧几里得(Euclid)与拓展的欧几里得算法 欧几里得算法 原理 实现 拓展的欧几里得算法 原理 递归求解 迭代求解 欧几里得算法 原理 欧几里得算法是一 ...
- Nacos高可用集群解决方案-Docker版本
文章主旨 本文目的是配置高可用的Nacos集群 架构图 整体架构为:Nginx + 3 x Nacos +高可用MySQL 高可用MySQL使用主从复制结构的可以参考Docker搭建MySQL主从集群 ...