python自学成才之路 列表,元组,集合详细用法

2024-06-22 19:18

本文主要是介绍python自学成才之路 列表,元组,集合详细用法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

文章目录

    • 列表简介
    • 列表crud操作
      • 创建列表
      • 访问列表元素
        • 1.通过索引访问列表元素
        • 2.通过for循环遍历列表
        • 3.判断列表中是否存在某个元素
      • 修改列表元素
      • 添加元素
        • 1.通过append向列表末尾添加元素
        • 2.通过insert方法向指定位置添加元素
      • 删除元素
        • 1.使用del删除指定位置元素
        • 2.使用pop删除末尾元素
        • 3.使用pop弹出指定位置的元素
        • 4.根据值使用remove删除元素
    • 列表排序
      • 1.列表永久排序,使用sort默认按照首字母升序排序
      • 2.传递reverse=True参数,按照首字母降序排序
      • 3.使用sorted对列表临时排序
      • 4.反转列表
    • 数值列表
      • 使用range创建数值列表
      • 列表解析
    • 切片
    • 元组
      • 元组打包和解包
    • 集合
      • 差集
      • 并集
      • 交集
      • 并集外的元素

列表简介

python列表使用[]表示,它实际上是一个数组,但是和一般数组不同的地方在于它内部封装了很多很好用的方法(比如append,pop)以及一些特性(比如切片,不可变列表元组),下面来一层层揭开python列表的面纱。

列表crud操作

创建列表

使用[]创建列表并初始化列表

names = ['Jane', 'Peter', 'Bob', 'Tom', 'Kyo']
print(names)
输出:
['Jane', 'Peter', 'Bob', 'Tom', 'Kyo']

访问列表元素

1.通过索引访问列表元素
print(names[0])
print(names[-1])  # 访问最后一个元素
print(names[-2])  # 访问倒数第二个元素
2.通过for循环遍历列表
for name in names:print(name)
3.判断列表中是否存在某个元素
if 'peter' in names:print('yes')

修改列表元素

print(names)
names[0] = 'Mike'
print(names)
输出:
['Jane', 'Peter', 'Bob', 'Tom', 'Kyo']
['Mike', 'Peter', 'Bob', 'Tom', 'Kyo']

添加元素

1.通过append向列表末尾添加元素
names.append('Jimmy')
2.通过insert方法向指定位置添加元素

这种方法会导致该元素后的所有元素向后移动一位

names.insert(3, 'kate')

删除元素

1.使用del删除指定位置元素
del names[0]
2.使用pop删除末尾元素
name = names.pop()
print(name)
3.使用pop弹出指定位置的元素
name = names.pop(3)
print(name)
4.根据值使用remove删除元素

注意根据值删除元素,如果存在多个相同的值,只会删除第一个,如果想要全部删除需要进行遍历。

names.remove('kate')
#遍历删除元素
names = ['peter','jane','Bob','peter','david','jack']
for name in names:if name == 'peter':names.remove(name)
print(names)
输出
['jane', 'Bob', 'david', 'jack']

列表排序

1.列表永久排序,使用sort默认按照首字母升序排序

print(names)
names.sort()
print(names)
输出:
['Peter', 'Bob', 'Kyo']
['Bob', 'Kyo', 'Peter']

2.传递reverse=True参数,按照首字母降序排序

print(names)
names.sort(reverse=True)
print(names)
输出:
['Bob', 'Kyo', 'Peter']
['Peter', 'Kyo', 'Bob']

3.使用sorted对列表临时排序

print(names)
print(sorted(names, reverse=True))
print(names)
输出:
['Peter', 'Kyo', 'Bob']
['Bob', 'Kyo', 'Peter']
['Peter', 'Kyo', 'Bob']

4.反转列表

使用reverse()方法反转列表,这个方法只反转列表,不对列表做排序操作。

print(names)
names.reverse()
print(names)
输出:
['Peter', 'Kyo', 'Bob']
['Bob', 'Kyo', 'Peter']

数值列表

使用range创建数值列表

1.注意使用range函数只包含起始值不包含末尾值

# 创建1~9的数组
data = range(1, 10)

2.创建数值列表时设置步长

# 创建[2,4,6,8]的列表
data = range(0, 10, 2)

3.结合range创建1~10平方数数值列表

squares = []
for value in range(1, 11, 2):squares.append(value**2)

4.max求数值列表最大值

print(max(squares))

5.min求数值列表最小值

print(min(squares))

6.sum求数值列表和

print(sum(squares))

列表解析

使用列表解析实现一行代码创建数值列表

squares = [value ** 2 for value in range(1, 11, 2)]
等价于
squares = []
for value in range(1, 11, 2):squares.append(value**2)

切片

切片,即通过起始和结束索引来截取列表的一部分,使用切片的时候会包含起始值不包含末尾值。
1.输出索引为0,1的两个元素

print(names[0:2])

2.输出第一个到底倒数第三个元素

print(names[0:-2])

3.如果没有指定起始索引,默认从0开始

print(names[:-2])

4.如果没有指定末尾索引,默认切片为起始索引到后面所有元素

print(names[0:])

5.输出倒数第二个元素到最后一个元素

print(names[-2:])

6.通过切片的方式实现复制操作

names2 = names[:]
names2.append('sum')
print(names)
print(names2)
输出:
['Bob', 'Kyo', 'Peter']
['Bob', 'Kyo', 'Peter', 'sum']

元组

元组是不可变的列表,在表现形式上和列表不同,列表使用[]来表示,元组使用()来表示。

tupleTest = (1, 3, 4)

虽然元组不可变,但是元组里面的单个元素却是可变的,比如像下面的这个元组,里面的元素都是列表,可以随意改变其中某个列表中元素的值。

tupleTest = ([1, 2, 3], [4, 5, 6])
print(tupleTest)
tupleTest[0][1] = 3
print(tupleTest)
输出:
([1, 2, 3], [4, 5, 6])
([1, 3, 3], [4, 5, 6])

元组打包和解包

给元组赋值时可以不用加上(),程序自身会自动做打包操作

t = 1, 2, 3
print(t)
输出:
(1, 2, 3)

元组也支持解包操作

x, y, z = t
print("x = " + str(x) + ', y = ' + str(y) + ', z' + str(z))
输出:
x = 1, y = 2, z = 3

集合

集合指的是set集合,他是一种特殊的列表,set集合会对内部的元素做去重处理,也就是set集合不会有重复元素,set集合使用{}表示,为了和字典区分空的set集合只能使用set()来表示。

basket = {'orange', 'apple', 'pear', 'banana', 'kiwi', 'apple', 'banana'}
print(basket)
输出:
{'kiwi', 'banana', 'orange', 'pear', 'apple'}

空的set集合使用set()来表示

basket = set()
basket.add('apple')
basket.add('banana')
basket.add('pear')
basket.add('orange')
basket.add('apple')
basket.add('orange')
print(basket)
输出:
{'banana', 'orange', 'pear', 'apple'}

set集合还支持一些数学上的集合运算

a = set('abracadabra')
print(a)
b = set('alacazam')
print(b)
输出:
{'r', 'd', 'c', 'a', 'b'}
{'m', 'c', 'a', 'z', 'l'}

差集

a - b : 返回a中有b中没有的元素

print(a-b)
输出:
{'b', 'r', 'd'}

并集

a | b : 返回a,b的并集

print(a|b)
输出:
{'r', 'm', 'd', 'c', 'a', 'b', 'z', 'l'}

交集

a & b : 返回a,b的交集

print(a&b)
输出:
{'c', 'a'}

并集外的元素

a^b 返回两个集合并集外的元素

print(a^b)
输出:
{'b', 'r', 'm', 'z', 'd', 'l'}

这篇关于python自学成才之路 列表,元组,集合详细用法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1085177

相关文章

python: 多模块(.py)中全局变量的导入

文章目录 global关键字可变类型和不可变类型数据的内存地址单模块(单个py文件)的全局变量示例总结 多模块(多个py文件)的全局变量from x import x导入全局变量示例 import x导入全局变量示例 总结 global关键字 global 的作用范围是模块(.py)级别: 当你在一个模块(文件)中使用 global 声明变量时,这个变量只在该模块的全局命名空

【Python编程】Linux创建虚拟环境并配置与notebook相连接

1.创建 使用 venv 创建虚拟环境。例如,在当前目录下创建一个名为 myenv 的虚拟环境: python3 -m venv myenv 2.激活 激活虚拟环境使其成为当前终端会话的活动环境。运行: source myenv/bin/activate 3.与notebook连接 在虚拟环境中,使用 pip 安装 Jupyter 和 ipykernel: pip instal

【机器学习】高斯过程的基本概念和应用领域以及在python中的实例

引言 高斯过程(Gaussian Process,简称GP)是一种概率模型,用于描述一组随机变量的联合概率分布,其中任何一个有限维度的子集都具有高斯分布 文章目录 引言一、高斯过程1.1 基本定义1.1.1 随机过程1.1.2 高斯分布 1.2 高斯过程的特性1.2.1 联合高斯性1.2.2 均值函数1.2.3 协方差函数(或核函数) 1.3 核函数1.4 高斯过程回归(Gauss

uva 11178 计算集合模板题

题意: 求三角形行三个角三等分点射线交出的内三角形坐标。 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <

【学习笔记】 陈强-机器学习-Python-Ch15 人工神经网络(1)sklearn

系列文章目录 监督学习:参数方法 【学习笔记】 陈强-机器学习-Python-Ch4 线性回归 【学习笔记】 陈强-机器学习-Python-Ch5 逻辑回归 【课后题练习】 陈强-机器学习-Python-Ch5 逻辑回归(SAheart.csv) 【学习笔记】 陈强-机器学习-Python-Ch6 多项逻辑回归 【学习笔记 及 课后题练习】 陈强-机器学习-Python-Ch7 判别分析 【学

nudepy,一个有趣的 Python 库!

更多资料获取 📚 个人网站:ipengtao.com 大家好,今天为大家分享一个有趣的 Python 库 - nudepy。 Github地址:https://github.com/hhatto/nude.py 在图像处理和计算机视觉应用中,检测图像中的不适当内容(例如裸露图像)是一个重要的任务。nudepy 是一个基于 Python 的库,专门用于检测图像中的不适当内容。该

pip-tools:打造可重复、可控的 Python 开发环境,解决依赖关系,让代码更稳定

在 Python 开发中,管理依赖关系是一项繁琐且容易出错的任务。手动更新依赖版本、处理冲突、确保一致性等等,都可能让开发者感到头疼。而 pip-tools 为开发者提供了一套稳定可靠的解决方案。 什么是 pip-tools? pip-tools 是一组命令行工具,旨在简化 Python 依赖关系的管理,确保项目环境的稳定性和可重复性。它主要包含两个核心工具:pip-compile 和 pip

c++的初始化列表与const成员

初始化列表与const成员 const成员 使用const修饰的类、结构、联合的成员变量,在类对象创建完成前一定要初始化。 不能在构造函数中初始化const成员,因为执行构造函数时,类对象已经创建完成,只有类对象创建完成才能调用成员函数,构造函数虽然特殊但也是成员函数。 在定义const成员时进行初始化,该语法只有在C11语法标准下才支持。 初始化列表 在构造函数小括号后面,主要用于给

bytes.split的用法和注意事项

当然,我很乐意详细介绍 bytes.Split 的用法和注意事项。这个函数是 Go 标准库中 bytes 包的一个重要组成部分,用于分割字节切片。 基本用法 bytes.Split 的函数签名如下: func Split(s, sep []byte) [][]byte s 是要分割的字节切片sep 是用作分隔符的字节切片返回值是一个二维字节切片,包含分割后的结果 基本使用示例: pa

HTML提交表单给python

python 代码 from flask import Flask, request, render_template, redirect, url_forapp = Flask(__name__)@app.route('/')def form():# 渲染表单页面return render_template('./index.html')@app.route('/submit_form',