一、列表:

为什么要学列表?

因为字符串存在缺点:

1)      只能存储少量的数据。

2)      数据类型无论索引、切片 获取的都是字符串类型,类型过于单一,转化成它原来的类型还需要进一步转换。

列表是Python的基础数据类型之一:list列表。

列表是以中括号组成,每个元素以逗号隔开的,容器型数据类型。

eg:[1,’zhao’,[1,2,3],Ture,{‘name’:’zhaoruofei’},(22,33)]

列表是一个有序的可以存储大量的数据的数据类型。

1、 列表的切片

l1 = ['赵若飞', 100, 'zhao', '日天']
列表的切片、索引
ret=l1[0]
ret1=l1[1]
print(ret1,type(ret1))
print(type(l1[:3]))  #类型为list。

2、 列表的常用操作

l1 = ['赵若飞', '赵若飞', 100, 'zhao', '日天', '你好', 999]

增:append 在尾部追加(只能单个追加)

l1.append('好好好')
l1.append(23)
l1.append([2,3,4])
print(l1)

insert 插入指定位置

l1.insert(1,'男')
print(l1)

extend 迭代着追加,意为拆分开依次追加

l1.extend('zhao')
l1.extend(['帮',555])
print(l1)

删:pop 按照索引删除,会将删除的元素作为返回值返回

ret=l1.pop(0)
print(l1)
print(ret)

remove 按照元素删除,没有返回值

ret = l1.remove('赵若飞')
print(ret)
print(l1)

  clear 清空列表

l1.clear()
print(l1)

del的使用:

    按照索引删除

    按照切片(可以加步长)删除

删除整个列表

del l1[-2]
del l1[1:]
del l1[::2]
del l1
print(l1)

改:改某个元素

切片改

l1[0]='男神'
print(l1)

切片(步长)改,必须与步长一一对应

l1[:3]='abcd' #迭代添加
print(l1)

切片(步长)改,必须与步长一一对应
l1[1:4:2]='a'
l1[1:4:2]='a2'
print(l1)

其他方法:

Len         获取列表的长度(总个数)

Count     计算某个元素出现的次数

Index      通过元素找到索引,找到第一个就返回,找不到就报错

Sort        从小到大排序

Sort(reverse=True)       从大到小排序

Reverse         反转,不排序

3、 列表的嵌套

练习:l1 = [1, 2, 'taibai', [1, 'alex', 3,]]

1, 将l1中的'taibai'变成大写并放回原处。2,给小列表[1,'alex',3,]追加一个元素,'老男孩教育'。3,将列表中的'alex'通过字符串拼接的方式在列表中变成'alexsb'

l1 = [1, 2, 'taibai', [1, 'alex', 3,]]
l1[2]=l1[2].upper()
print(l1)

l1[3].append('老男孩教育')
print(l1)

l1[3][1]=l1[3][1]+'sb'
print(l1)

4、 列表的总结:

Python常用的数据类型,工作中,都是涉及到嵌套的列表居多。增删改查。

5、 何时用列表:

需要大量数据排序的时候。

二、元组(只可以删除整个元组)

是Python中基础数据类型之一,容器型数据类型,存储大量的数据。

()里面的元素以,隔开的数据类型。

元组是不可以进行修改的,只能查询。

元组中存储的都是重要的数据,个人信息等等。

Eg:

tu1=(1,'alex',[1,2,3],True)
#可索引可切片
print(tu1[1])
print(tu1[:3])

元组只能查询,不能更改

索引、切片(步长) 查询 、计算元素出现次数

三、Range(顾头不顾尾)

内置函数,python给你提供的一个功能。

将range视为:可控范围的数字列表。

Eg:

range(1,10)
for I in range(1,10):
print(i)

结果为1 2 3 4 5 6 7 8 9

Range多与for循环配合。

l1 = ['无sir', 'alex', '太白', 100, 5]

for i in l1:
    print(l1.index(i))

for i in range(len(l1)):
    print(i)

练习:

1.如下:

li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]
a = len(li)
print(a)
li.append('seven')
print(li)
li.insert(0, 'Tony')
print(li)
li[1] = 'Kelly'
print(li)
l2 = [1, "a", 3, 4, "heart"]
li.extend(l2)
print(li)
s = "qwert"
li.extend(s)
print(li)
li.remove('ritian')
print(li)
ret = li.pop(1)
print(li, ret)
del li[1:4]
print(li)
li.reverse()
print(li)
print(li.count('alex'))

2.如下:

li = [1, 3, 2, "a", 4, "b", 5, "c"]
l1 = li[0:3]
print(l1)
l2 = li[3:6]
print(l2)
l3 = li[::2]
print(l3)
l4 = li[1:-1:2]
print(l4)
l5 = li[-1]
print(l5)
l6 = li[-3:-8:-2]
print(l6)

3.如下:

lis = [2, 3, "]], 89], "ab", "adv"]
lis[3][2][1][0] = lis[3][2][1][0].upper()
print(lis)
lis[1] = '
lis[3][2][1][1] = '
print(lis)
lis[3][2][1][2]=101
print(lis)

4.请⽤代码实现:

li = ["alex", "wusir", "taibai"] 利⽤下划线将列表的每⼀个元素拼接成字符串"alex_wusir_taibai"
li = ["alex", "wusir", "taibai"]
li='_'.join(li)
print(li[0]+'_'+li[1]+'_'+li[2])
print(li)

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

 li = ["alex", "WuSir", "ritian", "barry", "wenzhou"]

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

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

l = []
for i in range(1, 101):
    if i % 2 == 0:
        l.append(i)
print(l)

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

l = []
for i in range(1, 51):
    if i % 3 == 0:
        l.append(i)
print(l)

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

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

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

l = []
for i in range(100, 9, -1):
    if i % 2 == 0:
        l.append(i)
for a in l:
    if a % 4 != 0:
        l.remove(a)
print(l)

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

l = []
for i in range(1, 31):
    if i % 3 == 0:
        i = '*'
    l.append(i)
print(l)

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

l=[]
li = ["TaiBai ", "alexC", "AbC ", "egon", " riTiAn", "WuSir", "  aqc"]
for i in range(0,len(li)):
    li[i]=li[i].strip()
    if li[i][0]=='A' or li[i][0]=='a':
        if li[i][len(li[i])-1]=='c':
            l.append(li[i])
for i in l:
    print(i)

第二种方法:

l=[]
li = ["TaiBai ", "alexC", "AbC ", "egon", " riTiAn", "WuSir", "  aqc"]
for i in li:
    i=i.strip()
    if i[0]=='a' or i[0]=='A':
        if i[len(i)-1]=='c':
            l.append(i)
for i in l:
    print(i)

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

l = []
li = ["苍老师", "东京热", "武藤兰", "波多野结衣"]
a = input('请输入评论:')
for i in li:
    if i in a:
        a = a.replace(i, '*' * len(i))
l.append(a)
print(l)

19-3-5Python中列表、元组、以及range的更多相关文章

  1. 列表,元组以及range

    列表,元组以及range 一.列表(list) 列表是数据类型之一,它有序,可变,支持索引 作用:存储数据,支持的数据类型很多:字符串,数字,布尔值,列表等 # 定义一个列表 lst = ['alex ...

  2. python中列表 元组 字典 集合的区别

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计 ...

  3. **python中列表 元组 字典 集合

    列表 元组 字典 集合的区别是python面试中最常见的一个问题.这个问题虽然很基础,但确实能反映出面试者的基础水平. 1.列表 列表是以方括号“[]”包围的数据集合,不同成员以“,”分隔. 列表的特 ...

  4. python 中列表 元组 字典 集合的区别

    先看图片解释 (1)列表 什么是列表呢?我觉得列表就是我们日常生活中经常见到的清单.比如,统计过去一周我们买过的东西,把这些东西列出来,就是清单.由于我们买一种东西可能不止一次,所以清单中是允许有重复 ...

  5. 列表 & 元组& join & range

    一:列表(增删改查,列表的嵌套,列表的循环) 1)增加 append    (在列表的尾部增加) insert       (插入)   insert(插入的位置,插入的内容) extend      ...

  6. python中列表 元组 字符串如何互相转换

    python中有三个内建函数:列表,元组和字符串,他们之间的互相转换使用三个函数,str(),tuple()和list(),具体示例如下所示: >>> s = "xxxxx ...

  7. python中列表元组字符串相互转换

    python中有三个内建函数:列表,元组和字符串,他们之间的互相转换使用三个函数,str(),tuple()和list(),具体示例如下所示: >>> s = "xxxxx ...

  8. 巨蟒python全栈开发-第4天 列表&元组&range

    今日内容大纲 1. 什么是列表 定义: 能装对象的对象 在python中使用[]来描述列表, 内部元素用逗号隔开. 对数据类型没有要求 列表存在索引和切片. 和字符串是一样的. 2. 相关的增删改查操 ...

  9. python中的基本数据类型之列表,元组

    一.列表 1.什么是列表. 列表是python的基本数据类型之一,用[]来表示,可以存放各种数据类型(什么都能装,能装对象的对象) 列表相比于字符串,不仅可以存放不同类型的数据,而且可以存放大量的数据 ...

随机推荐

  1. 02_dubbo实例_多版本号

    [多版本作用] 当一个接口实现,出现不兼容升级时,可以用版本号过渡. 版本号不同的服务之间不能引用. [版本迁移方式] 1.在低压时间段,先升级一半Provider为新版本. 2.再将所有消费者升级为 ...

  2. 阿里云更懂你的数据库,免费提供DBA服务

    阿里云更懂你的数据库,免费提供DBA服务   阿里云云数据库(RDS)管理控制台近期将全面升级为云数据库管家.云数据库管家的使命是提供便捷的操作.贴心的服务.专业的处理建议,帮助用户管理好云数据库. ...

  3. 安装busybox玩玩

    到http://www.busybox.net/downloads/binaries/下载放到sdcard然后adb shellsumount -o remount,rw -t yaffs2 /dev ...

  4. anroid之异步不如异步

    executeOnExecutor(AsyncTask.THREAD_POOL_EXECUTOR) 使用自定义的CorePoolSize为7的Executor(Executors.newFixedTh ...

  5. Linux 虚拟机的计划维护

    Azure 定期执行更新,以提高虚拟机的主机基础结构的可靠性.性能及安全性. 此类更新包括修补宿主环境(例如操作系统.虚拟机监控程序以及主机上部署的各种代理)中的软件组件.升级网络组件以及硬件解除授权 ...

  6. 你所不知道的C和C++运行库 标签: vc 2017-05-26 10:33 41人阅读 评论(0) 收藏

    在使用vs2013调用vc2005编译出的dll时出现错误,遂将源程序用vs2013编译出dll,再用vs2013调用错误消失,不解.寻找原因时有人说"VC库版本不一样",故查找C ...

  7. 沉淀,再出发:Git的再次思考

    沉淀,再出发:Git的再次思考 一.前言 使用git也有很久了,后来有一段时间一直没有机会去使用,现在想来总结一下自己学习了这么长时间的一些心得感悟,我写的博客一般都是开了一个轮廓和框架,等到以后有所 ...

  8. selenium+python 数据驱动-csv篇,可封装

    #循环读取csv文件中的数据,可以作为用户名,密码等使用from selenium import webdriverimport csv#获取csv文件中password列with open(r'C: ...

  9. 【深入理解JAVA虚拟机】第二部分.内存自动管理机制.3.垃圾收集器与内存分配策略

    1.学习目的 当需要排查各种内存溢出. 内存泄漏问题时,当垃圾收集成为系统达到更高并发量的瓶颈时,我们就需要对这些“自动化”的技术实施必要的监控和调节. Java内存运行时区域的各个部分,其中程序计数 ...

  10. 在IDE中集成boost

    1. 获得Boost 进入Boost的网站(http://www.boost.org/) 下载boost_1_62_0.zip 2. 解压Boost 解压 boost_1_62_0.zip ,比如解压 ...