一.列表:

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. 使用vue-cli创建一个vue项目

    安装vue-cli npm install -g @vue/cli 1, 使用vue创建一个项目 vue create luffy 2, 安装所需的插件 npm install vue-router ...

  2. 编码总结,以及对BOM的理解

    一.前言 在跨平台.跨操作系统或者跨区域之间,经常会涉及到编码的问题,因为前段时间在项目中,遇到了因为编码而产生乱码的问题,以前对编码也是一知半解,所以决定对编码有一个更为深入的了解,因此才有了这篇自 ...

  3. 远程连接MySQL数据库报错:is not allowed to connect to this MYSQL server的解决办法

    1. 改表法. 可能是你的帐号不允许从远程登陆,只能在localhost.这个时候只要在localhost的那台电脑,登入MySQL后,更改 "mysql" 数据库里的 " ...

  4. linux之shell编程初步

    #################适用于CentOS6################## #!/bin/bash ########################################## ...

  5. sql优化 原因

    不使用子查询例: SELECT * FROM t1 WHERE id (SELECT id FROM t2 WHERE name='hechunyang'); 子查询在MySQL5.5版本里,内部执行 ...

  6. JAVA本地调用(JNI- java调用c)

    记录一下工作内容,对术语了解不多,暂且这样记着吧.  java调用c 一.写jni的步骤如下: 1.创建java类,定义接口函数,使用native修饰: 2.将java类编译成class: 3.将cl ...

  7. Part2_lesson4---ARM寻址方式

    所谓寻址方式就是处理器根据指令中给出的信息来找到指令所需操作数的方式. 1.立即数寻址 ADD R0,R0,#0x3f; R0<-R0+0x3f 在以上指令中,第二个源操作数即为立即数,要求以“ ...

  8. 白盒测试实践--Day5

    累计完成任务情况: 阶段内容 参与人 完成个人情况说明并提交作业 全体 汇总作业,查漏补缺,完成代码测试总结 小靳.小龙 完成测试小结 小黄.小尹 完成静态代码检查结果报告 小靳 完成JUnit脚本编 ...

  9. gitlab 安装提速

    因为城墙的问题必须该用国内的taobao源 # 更换源地址gem sources --remove https://rubygems.org/ gem sources -a http://ruby.t ...

  10. 部分类Partial

    Partial告诉编译器,一个类,结构,接口的定义源代码可能要分散到一个或者多个源文件中. 在下面的情况下用Partial类型: (1) 类型特别大,不宜放在一个文件中实现.(2) 一个类型中的一部分 ...