一、列表list

1、列表的新增元素(三种方法)

>>>第1种方法(append 增加到最后):

li = ['Peter','Henrry','Wode','鸭子','xiaoxin']
li.append('小鸡')
li.append(1)
print(li)

例:新增名单(重复输入名单,当输入Q时停止输入)

li = ['Peter','Henrry','Wode','鸭子','xiaoxin']
while 1:
l1 = input('请输入姓名:')
if l1.upper() == 'Q':
break
li.append(l1)
print(li)

>>>第2种方法(insert 插入到指定位置):

li = ['Peter','Henrry','Wode','鸭子','xiaoxin']
li.insert(4,'小鸡')
print(li)

>>>第3种方法(extend 迭代插入(分解元素插入最后)-->>int不能迭代,列表可以):

li = ['Peter','Henrry','Wode','鸭子','xiaoxin']
li.extend('小王')
li.extend([1,2,3]) #数字列表直接分解到最小元素
print(li)

2、列表的删除元素(四种方法)

>>>第1种方法:(pop 按照索引删除元素,注:pop有返回值,可以看删除了什么元素,不填索引,默认删除最后一个元素)

li = ['Peter','Henrry','Wode','鸭子','xiaoxin']
name = li.pop(4)
name = li.pop() # 默认删除最后一个元素
print(name,li)

>>>第2种方法:(remove 按照元素去删除)

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
li.remove('鸭子')
print(li)

>>>第3种方法:(clear 清空列表,剩下一个空列表)

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
li.clear()
print(li)

>>>第4种方法:(del删除列表)

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
del li
print(li)
#衍生 切片删除
li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
del li[0:3]
print(li)

3、列表的修改(2种方法)

>>>第1种方法:(根据索引进行修改)

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
li[4] = '小凯'
print(li)

>>>第2种方法:(根据切片修改(修改为最小元素))

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
li[0:2] = '小哥哥'
print(li)
衍生(根据列表修改,修改为列表元素)
li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
li[0:2] = ['小鸡','大鹅','']
print(li)

4、查看列表元素

>>>1、利用for循环:

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
for i in li:
print(i)

>>>2、切片查看:

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
print(li[0:2])

>>>3、公共方法

1、查看元素数量

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
l = len(li)
print(l)

2、查看元素出现次数

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
num = li.count('鸭子')
print(num)

3、查看元素索引--->index,查无报错

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
print(li.index('鸭子'))

5、列表的排序

li = [2,1,4,6,7,8,9,]
li.sort() #默认从小到大
print(li)
li.sort(reverse=True) #从大到小
print(li)
li.reverse() #元素翻转
print(li)

6、列表的嵌套

li = ['liming','大王','萧山水','鸭子',['peter','alex',88],23]
print(li[1][1]) #找到山
s = li[0].capitalize() #找到第一个元素,首字母变大写
li[0] = s
print(li)
li[3]=li[3].replace('子','哥哥') #找到鸭子的子改成哥哥
print(li)
li[4][0] =li[4][0].upper() #找到peter进行大写之后放回原处
print(li)
s = li[4][2] + 12 #找到88变成100,放回去(方法1)
li[4][2] = s
print(li)
li[4][2] = 100 #找到88变成100,放回去(方法2)
print(li)

二、元组-->只读列表,可循环查询,可切片(元组元素不能改,元素列表可能可以改)

tu = [1,2,3,[1,2,3,'xiaomao'],'鸭子','peter']
print(tu[2]) #可读
print(tu[2:4]) #可切片
for i in tu: #可循环
print(i)
tu[3][3] = tu[3][3].upper() #可改元祖中列表的元素
print(tu)
tu[3].append('小鸡') #元祖中列表增加元素
print(tu)

1、可迭代 join

s = 'peter'
s1 = '~'.join(s) #可迭代(p~e~t~e~r),int 跟bool 值不可作为迭代元素
print(s1)

2、列表---> 字符串

li = ['Peter', 'Henrry', 'Wode', '鸭子', 'xiaoxin']
s = '/'.join(li)
print(s)

3、range 数字列表

for i in range(2,101):   #自定义数字顺序长度
print(i)
for i in range(10): #自定义数字长度
print(i)
for i in range(1,10,2): #自定义数字、步长
print(i)
for i in range(10,0,-1): #逆序
print(i)
for i in range(0,10,-1): #不报错不输出
print(i)

三、作业题

1、输出列表各个元素,遇到子列表照样照样输出子列表元素

#方法1:

li =[1,2,3,[1,2,3,'xiaomao'],'鸭子','peter']
for i in li:
if type(i) == list:
for k in i:
print(k)
else:
print(i)

#方法2:

li =[1,2,3,[1,2,3,'xiaomao'],'鸭子','peter']
for i in range(len(li)):
if type(li[i]) == list:
for j in li[i]:
print(j)
else:print(li[i])

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

#方法1:
li = ['taibai ','alexC','AbC ','egon',' Ritian',' Wusir','  aqc']
b=[]
for i in li:
s=i.strip()
if (s.startswith("A")or s.startswith("a"))and s.endswith("c"):
b.append(s)
for x in b:
print(x)
#方法2
li = ['taibai ','alexC','AbC ','egon',' Ritian',' Wusir','  aqc']
b=[]
for i in li:
s=i.strip()
if s[0].upper() == 'A' and s[-1] == 'c':
b.append(s)
for x in b:
print(x)

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

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

# 则将用户输入的内容中的敏感词汇替换成***,并添加到一个列表中;

# 如果用户输入的内容没有敏感词汇,则直接添加到上述的列表中。

li=["苍老师","东京热","武藤兰","波多野结衣"]
new_li= []
info = input("评论") # 苍老师,东京热 法律框架第三
for i in li:
if i in info:
l = len(i)
info=info.replace(i,'*'*l)
new_li.append(info)
print(new_li)

04、python的基础-->列表跟元组的更多相关文章

  1. Python数据基础--列表、元组、字典、函数

    一.数据结构 列表(List)和元组 序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推. Python有6个序列的内 ...

  2. Python基础------列表,元组的调用方法

    Python基础------列表,元组的调用方法@@@ 一. 列表 Python中的列表和歌曲列表类似,也是由一系列的按特定顺序排列的元素组成的,在内容上,可以将整数,实数,字符串,列表,元组等任何类 ...

  3. Python基础-列表、元组、字典、字符串

    Python基础-列表.元组.字典.字符串   多维数组 nums1 = [1,2,3] #一维数组 nums2 = [1,2,3,[4,56]] #二维数组 nums3 = [1,2,3,4,['a ...

  4. python 变量、列表、元组、字典

    python 变量.列表.元组.字典 1.python 变量赋值 2.ptython  列表 3.python 元组 4.python  字典 1.  Python变量赋值     1.1变量的命名规 ...

  5. Python 学习笔记(1)Python容器:列表、元组、字典与集合

    Python容器:列表.元组.字典与集合 列表: 1.列表 的创建 使用[ ] 或者 list()创建列表:empty_list = [ ] 或者 empty_list= list() 使用list( ...

  6. Python基础-列表_元组_字典_集合

    本节内容 列表.元组操作 字符串操作 字典操作 集合操作 文件操作 字符编码与转码 1. 列表.元组操作 列表是我们最以后最常用的数据类型之一,通过列表可以对数据实现最方便的存储.修改等操作 定义列表 ...

  7. Python自动化 【第二篇】:Python基础-列表、元组、字典

    本节内容 模块初识 .pyc简介 数据类型初识 数据运算 列表.元组操作 字符串操作 字典操作 集合操作 字符编码与转码 一.模块初识 Python的强大之处在于他有非常丰富和强大的标准库和第三方库, ...

  8. Python基础--列表、元组

    一.什么是列表.元组 序列是Python中最基本的数据结构.序列中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0,第二个索引是1,依此类推. Python有6个序列的内置类型,但最常见 ...

  9. Python基础——列表、元组操作

    列表.元组操作 列表: 列表是Python中最基本的数据结构,列表是最常用的Python数据类型,列表的数据项不需要具有相同的类型.列表中的每个元素都分配一个数字 - 它的位置,或索引,第一个索引是0 ...

随机推荐

  1. django-5-使用数据库

    修改默认数据库 django默认数据库为 SQLite3,若需要修改,比如改成mysql,则需要修改与settings.py文件同路径的__init__.py文件,添加如下内容: import pym ...

  2. 【设计模式】FactoryPattern工厂模式

    Factory Pattern 简单工厂模式 将变化的部分封装起来 //简单工厂 class SimpleProductFactory{ Product createProduct(String ty ...

  3. XGBoost的推导和说明

    一.简介 XGBoost是“Extreme Gradient Boosting”的缩写,其中“Gradient Boosting”一词在论文Greedy Function Approximation: ...

  4. 洛谷 P1346 电车——dijstra

    上一波题目 https://www.luogu.org/problem/P1346 是道水题 路口一开始对着的那条路权值为0 其余路权值为1 然后跑一遍最短路就好了 qwq #include<c ...

  5. luoguP1540 机器翻译 题解(NOIP2010)

    P1540 机器翻译  题目 #include<iostream> #include<cstdlib> #include<cstdio> #include<c ...

  6. WEBRTC三种类型(Mesh、MCU 和 SFU)的多方通信架构

    WebRTC 本身提供的是 1 对 1 的通信模型,在 STUN/TURN 的辅助下,如果能实现 NAT 穿越,那么两个浏览器是可以直接进行媒体数据交换的:如果不能实现 NAT 穿越,那么只能通过 T ...

  7. 42.Flatten Binary Tree to Linked List

    Level:   Medium 题目描述: Given a binary tree, flatten it to a linked list in-place. For example, given ...

  8. BUUCTF 梅花香自苦寒来

    梅花香自苦寒来 打开图片可以看到,在jpg后面有大量的数据,将它保存出来,可以看出是十六进制,将它转为ascii,写脚本 with open('hex.txt','r') as h: h=h.read ...

  9. mysql数据库的水平分表与垂直分表实例讲解

    mysql语句的优化有局限性,mysql语句的优化都是围绕着索引去优化的,那么如果mysql中的索引也解决不了海量数据查询慢的状况,那么有了水平分表与垂直分表的出现(我就是记录一下自己的理解) 水平分 ...

  10. Nginx Web 基础入门

    目录 Nginx Web 基础入门 Nginx快速安装 两种方式部署Nginx 如何升级nginx或者添加功能 使用systemd管理nginx nginx相关配置文件 nginx的配置文件详解 虚拟 ...