一.列表:

1. 什么是列表
  列表是一个可变的数据类型 ,列表由[]来表示, 每一项元素使用逗号隔开.

  列表什么都能装. 能装对象的对象. 列表可以装大量的数据

2. 列表的索引和切片
  列表和字符串一样. 也有索引和切片. 只不过切出来的内容是列表
  索引的下标从0开始
  [起始位置:结束位置:步长]

3. 列表的增删改查*
 1. 增加
  append() 追加
  insert(index, 元素) 在index位置添加元素
  extend() 迭代添加

lst = ["清风徐来","水波不兴",]
lst.append("") #追加,在原有基础的后面添加
lst.insert(1,"大江东去浪淘尽") #在xxx位置插入xxx
lst.extend(["大江东去浪淘尽","千古风流人物","故垒西边"])# 迭代添加主要内容 

 2. 删除
  pop(index) 按照位置删除元素 又返回值,返回被删除的数据
  remove(元素) 直接删除元素
  del 切片.
  clear() 清空列表

lst = ["赵四", "施瓦星格", "黄渤", "郭达森", "赛利亚"]

data = lst.pop(2) # 返回被删除的数据
print(data)
print(lst) lst.remove("赵四") # 删除元素.
lst.remove("刘能") # 如果不存在会报错 切片删除
del lst[1:3] 清空
lst.clear()
print(lst)

 3. 修改
  索引修改
  切片修改

lst = ["王者农药", "魔兽世界", "DNF", "逆水寒", "反恐精英"]
lst[0] = "扫雷"
print(lst)
lst[3] = "吃鸡" lst[1:3] = ["跑跑卡丁车"] # 先删除后添加
lst[1::2] = ["QQ华夏","QQ三国"] # 切片修改的时候. 如果步长不是1. 注意元素的个数
print(lst)

  4. 查询

lst = ["锅包肉", "好人家火锅", "巫山烤鱼", "清水煮白菜", "烤鸭"]
for el in lst: # element(元素)
print(el)

   5. 常用操作
     1. sort() 排序 reverse=True降序
     2. reverse() 翻转
     3. len() 求长度
     4. 列表的嵌套
       降维. 一层一层看

二.元组:

 只读列表. 其本身不能修改
 使用()表示元组
 如果元祖中只有一个元素(元素, )
 空元组: tuple()
 元祖是一个可迭代对象, 可以使用for循环

三.range

  range(n) 从0到n-1
  range(m,n) 从m到n-1
  range(m,n,q) 从m到n-1 每q个取1个
  综上就是切片

range:指定范围,生成指定数字。

for i in range(1,10):
print(i) for i in range(1,10,2): # 步长
print(i) for i in range(10,1,-2): # 反向步长
print(i)

7. 使用range和for循环来获取列表中的索引

for i in range(len(列表)):
i 索引
列表[i] 元素 

 四.enumerate:

  枚举,对于一个可迭代的(iterable)/可遍历的对象(如列表、字符串),enumerate将其组成一个索引序列,利用它可以同时获得索引和值。

li = ['锄禾日当午','汗滴禾下土','谁知盘中餐','粒粒皆辛苦']
for i in enumerate(li):
print(i)

 ##(0, '锄禾日当午')
  (1, '汗滴禾下土')
  (2, '谁知盘中餐')
  (3, '粒粒皆辛苦')

for index,name in enumerate(li,1):
print(index,name)
for index, name in enumerate(li, 100): # 起始位置默认是0,可更改
print(index, name)    
 

 练习:

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

print(len(li)) # 5

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

li.append("seven")
print(li) # ['alex', 'WuSir', 'ritian', 'barry', 'wenzhou','seven']

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

li.insert(0,"Tony")
print(li) #['Tony', 'alex', 'WuSir', 'ritian', 'barry', 'wenzhou']

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

li[1] = 'Kelly'
print(li) # ['alex', 'Kelly', 'ritian', 'barry', 'wenzhou']
(5)请将列表l2=[1,"a",3,4,"heart"]的每一个元素添加到列表li中,一行代码实

现,不允许循环添加。

l2=[1,"a",3,4,"heart"]
li.extend(l2)
# print(li) # ['alex', 'WuSir', 'ritian', 'barry', 'wenzhou', 1, 'a', 3, 4, 'heart']

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

s = "qwert"
li.extend(s)
print(li) # ['alex', 'WuSir', 'ritian', 'barry', 'wenzhou', 'q', 'w', 'e', 'r', 't']

(7)请添加元素"eric",并输出添加后的列表

li.append("eric")
print(li) #['alex', 'WuSir', 'ritian', 'barry', 'wenzhou', 'eric']

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

l2 = li.pop(1)
print(l2) # WuSir
print(li) # ['alex', 'ritian', 'barry', 'wenzhou']

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

del li[1:4]
print(li) # ['alex', 'wenzhou']

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

li = li[-1::-1]
print(li) # ['wenzhou', 'barry', 'ritian', 'WuSir', 'alex']

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

n = li.count("alex")
print(n) # 1

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

l1 = li[0:3]
print(l1)

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

l2 = li[3:6]
print(l2)

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

l3 = li[0:-1:2]
print(l3)

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

l4 = li[1:-2:2]
print(l4)

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

l5 = li[-1]
print(l5)

(6)通过对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"]
(1)将列表lis中的"tt"变成大写(用两种方式)。
方法一:

lis[3][2][1][0] = "TT"
print(lis)

方法二:

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

(2)将列表中的数字3变成字符串"100"(用两种方式)。
方法一:

lis[1] ="100"
lis[3][2][1][1] = "100"
print(lis)

方法二:

lis[1] = str(lis[1] + 97)
lis[3][2][1][1] = str(lis[3][2][1][1] + 97)
print(lis)

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

#方法一:
lis[3][2][1][2] = 101
print(lis)
#方法二:
lis[3][2][1][2] = int("101")
print(lis)

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

li = ["alex", "eric", "rain"]
sum = ""
for i in li:
sum = sum + i + "_"
print(sum[:-1])

5.利用for循环和range打印出下面列表的索引。

li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
for el in range(len(li)):
print(el)
print(li[el])

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

li = []
for le in range(101):
if le % 2 == 0:
li.append(le)
print(li) # 方法一
li = []
for le in range(0,101,2):
li.append(le)
print(li) # 方法二

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

li = []
# 方法一:
for le in range(51):
if le % 3 == 0:
li.append(le)
print(li)
#方法二:
for le in range(0,51,3):
li.append(le)
print(li)

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

for le in range(100,0,-1):
print(le)

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

#方法一:
li = []
l2 = []
for le in range(100,9,-1):
if le % 2 == 0:
li.append(le)
for l3 in li:
if l3 % 4 == 0:
l2.append(l3)
print(l2)
# 方法二:
li = []
for le in range(100,9,-2):
li.append(le)
for l3 in li:
if l3 % 4 != 0:
li.remove(l3)
print(li)

10,利用for循环和range,将1-30的数字一次添加到一个列表中,并循环这个

列表,将能被3整除的数改成*

li = []
l2 = []
for i in range(1,31):
li.append(i)
for n in li:
if n % 3 == 0:
n = "*"
else:
pass
l2.append(n)
print(l2)

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

li = ["TaiBai","ale xC","AbC ","egon","ri TiAn","WuSir"," aqc"]
l2 = []
for i in li:
i = i.replace(" ","")
if (i.startswith("A")or i.startswith("a")) and i.endswith("c"):
l2.append(i)
print(i)

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

敏感词列表 li = ["苍老师", "东京热", "武藤兰", "波多野结衣"]
则将用户输入的内容中的敏感词汇替换成等长度的*(苍老师就替换***),并添
加到一个列表中;如果用户输入的内容没有敏感词汇,则直接添加到上述的列表中。

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

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"]
new_li = []
for i in li:
if i == li[4]:
for n in i:
if n == li[4][3]:
n2 = n.lower()
new_li.append(n2)
else:
new_li.append(n)
elif i == li[-1]:
i2 = i.lower()
new_li.append(i2)
else:
new_li.append(i)
for l2 in new_li:
print(l2)
# 方法二:
li = [1, 3, 4, "alex", [3, 7, 8, "TaiBai"], 5, "RiTiAn"]
new_li = []
for i in li:
if type(i) == list:
for le in i:
if type(le) == str:
print(le.lower())
else:
if type(i) == str:
print(i.lower())
else:
print(i)

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

li = []
while 1:
str_input = input('请输入你的姓名和分数(格式:张三_44),输入Q退出:')
if str_input.lower() == 'q':
break
else:
ret = str_input.split('_')
li.append(ret[1])

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

new_li = []
num = int(input("请输入一个数字"))
for i in range(1,num + 1):
if i % 7 == 0 or '7' in str(i):
new_li.append("咣")
else:
new_li.append(i)
print(new_li)

  

列表的操作,元组,range; enumerate的更多相关文章

  1. 列表的嵌套,元组和range()方法

    列表嵌套: 列表内嵌套列表 li = ['a','b',[1,2,3,["李白",'苏轼'],4,5],'c'] #取出"李白" print(li[2][3][ ...

  2. 列表的初识,列表的索引切片,列表的增删改查,列表的嵌套,元组的初识,range

    1 内容总览 列表的初识 列表的索引切片 列表的增删改查 列表的嵌套 元组的初识(了解) 元组的简单应用(了解) range 2 具体内容 列表的初识 why: str: 存储少量的数据.切片出来全都 ...

  3. python基础学习 str,list,dict,set,range,enumerate

    一.字符串 s = 'python' s1 = 'python' + 'learn' #相加其实就是简单拼接 s2 = 'python' * 5 #相乘其实就是复制自己多少次,再拼接在一起 字符串切片 ...

  4. (转载)Python 列表(list)操作

    (转载)http://blog.csdn.net/facevoid/article/details/5338048 创建列表sample_list = ['a',1,('a','b')] Python ...

  5. Day4--Python--列表增删改查,元组,range

    # 一.列表# 能装东西的东西 列表中装的数据是没有限制的,大小基本上够用# 列表用[]表示# 有索引和切片 [start,end,step] ###增删改查 (重点) # 1.新增 # appent ...

  6. Python 列表(list)操作

    创建列表 sample_list = ['a',1,('a','b')] Python 列表操作 sample_list = ['a','b',0,1,3] 得到列表中的某一个值 value_star ...

  7. python 基础之列表的操作和列表的相关函数

    一.列表的相关操作 1.列表的拼接 list1 = [1,2]list2 = [3,4]listvar = list1 + list2print(listvar) 2.列表的重复 lst = [1,2 ...

  8. day7:字符串的操作/方法&字符串的格式化format&列表的操作

    字符串的相关操作 1.字符串的拼接 strvar = "vegeta"+"ble" print(strvar) # vegetable 2.字符串的重复 str ...

  9. Python中关于列表排序并保留id/enumerate()使用方法

    新手才开始写博客,不周之处请原谅,有错误请指正. >>> a = [1,4,2,5,3]>>> b = sorted(enumerate(a),key = lamb ...

随机推荐

  1. S初始化生产环境数据

    一.将开发机的库文件导出10.10.1.139开发机服务器,桌面上的BAT文件,将数据库表结构和表数据导出来,导到E:\Repository,设置SADMIN密码永不过期BAT文件内容如下: ::导出 ...

  2. 编写DLL

    想想还是把这个记录下吧,虽然不难,但由于平时写得不多,老是搞忘了. 1.我们来编写一个简单的DLL程序. 首先,我们来看下入口函数DllMain().DllMain()有3个参数: (1)hModul ...

  3. 141. Linked List Cycle (List; Two-Pointers)

    Given a linked list, determine if it has a cycle in it. Follow up: Can you solve it without using ex ...

  4. 原生JS的使用,包括jquery和原生JS获取节点、jquery和原生JS修改属性的比较

    一.前言 相比于JS这条直达终点.满是荆棘的小路,jquery无疑是康庄大道了,足够的简洁.易用给了它辉煌的地位.然而,毕竟是绕着道的插件,当小路走着走着变成大路的时候,曾经的大路也就失去了他自身的优 ...

  5. JavaScript中的一些小技巧

    js 数字操作:1.1 取整:取整有很多方法如: parseInt(a,10); Math.floor(a); a>>0; ~~a; a|0; 前面2种是经常用到的,后面3种算是比较偏的, ...

  6. 669. Trim a Binary Search Tree修剪二叉搜索树

    [抄题]: Given a binary search tree and the lowest and highest boundaries as L and R, trim the tree so ...

  7. fastDFS配置及日志查看 所遇到的问题

    FastDFS的配置文件在/usr/local/webserver/fastdfs/etc目录下,其中包括 client.conf    客户端上传配置文件 storage.conf    文件存储服 ...

  8. 要生成在[min,max]之间的随机整数,

    import java.util.Random; public class RandomTest { public static void main(String[] args) { int max= ...

  9. 面向对象的JavaScript-001

    一. Question是父类,MultipleChoiceQuestion和DragDropQuestion是子类 二. 1. <script> // 面向对象 function Ques ...

  10. 常用的 Python 调试工具,Python开发必读-乾颐堂

    以下是我做调试或分析时用过的工具的一个概览.如果你知道有更好的工具,请在评论中留言,可以不用很完整的介绍. 日志 没错,就是日志.再多强调在你的应用里保留足量的日志的重要性也不为过.你应当对重要的内容 ...