【Python基础】详解Python基础函数,包教包会(三)

简介: 【Python基础】详解Python基础函数,包教包会(三)

image.png


运行环境


python:3.8.3

jupyter-notebook : 6.4.0

注意:本文案例可以直接在 jupyter-notebook 上运行,但在 PyCharm 上的话需要代码的最后一句加上 print 哦!


元组


tuple()

tuple() 将可迭代对象转换成元组。

tuple([0,1,2]) + tuple(range(3)) + tuple({0,1,2}) + tuple('012')
复制代码
output:(0, 1, 2, 0, 1, 2, 0, 1, 2, '0', '1', '2')
将可迭代对象转换成列表并通过运算符连接。



字典


dict.clear()

clear() 清除字典的所有内容。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.clear()
dic
复制代码
output:{}


dict.fromkeys()

fromkeys() 创建一个新字典,以序列 iterable 中元素做字典的键,value 为字典所有键对应的初始值。

  • iterable: 可迭代对象,新字典的键。
  • value: 可选参数, 设置键序列对应的值,默认为 None
dict.fromkeys(['CSDN', '公众号'],
              'Python新视野')
复制代码
output:{'CSDN': 'Python新视野', '公众号': 'Python新视野'}


dict.get()

get(key, default=None) 根据指定的 key 值查找,如果 key 在字典中,则返回 key 的值,否则为 None


示例 🅰️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.get('CSDN')
复制代码
output:'Dream丶killer'


示例 🅱️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
print(dic.get('微信'))
复制代码
output:None
字典中没有 key 等于 '微信',返回 None,jupyter notebook 对于 None 如果不加 print 默认不输出,所以这里加上print 来打印结果


dict.items()

items() 返回视图对象,是一个可遍历的 key/value 对,可以使用 list() 将其转换为列表。

示例 🅰️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
list(dic.items())
复制代码
output:[('CSDN', 'Dream丶killer'), ('公众号', 'Python新视野')]


示例 🅱️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
for key, value in dic.items():
    print('key: ', key, 'value: ', value)
# key:  CSDN value:  Dream丶killer
# key:  公众号 value:  Python新视野
复制代码


dict.keys()

keys() 返回一个视图对象,值为字典的 key ,可将其转换成列表。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.keys()
复制代码
output:dict_keys(['CSDN', '公众号'])


dict.setdefault()

setdefault(key, default=None) 如果键不在字典中,则插入值为 None 的键。如果键在字典中,则返回键的值。

示例 🅰️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.setdefault('CSDN', 'python-sun')
复制代码
output:'Dream丶killer'
字典中有 CSDN 这个 key 值,返回 CSDN 对应的值,不需要插入


示例 🅱️

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.setdefault('微信', 'python-sun')
dic
复制代码
output:{'CSDN': 'Dream丶killer', '公众号': 'Python新视野', '微信': 'python-sun'}
字典中没有 微信 这个 key 值,返回 None ,执行插入,并根据设置的参数 python-sun 来进行赋值。


dict.update()

dict.update(dict1) 把字典 dict1key/value 对更新到 dict 里,当 dict1key 出现在 dict 中则修改 dict 中的值,如果 key 没有出现在 dict 中,则添加这一对 key/value

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic1 = {'CSDN': 'new_name',
        '微信': 'python-sun'}
dic.update(dic1)
dic
复制代码
output:{'CSDN': 'new_name', '公众号': 'Python新视野', '微信': 'python-sun'}


dict.values()

values() 返回一个视图对象,值为字典的 value ,可将其转换成列表。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.values()
复制代码
output:dict_values(['Dream丶killer', 'Python新视野'])


dict.pop()

pop() 删除指定 keykey/value ,如果 key 没有找到,则报错。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.pop('CSDN')
dic
复制代码
output:{'公众号': 'Python新视野'}


dict.popitem()

popitem() 删除字典中末尾的元素,并返回一个元组的(键,值)对。字典为空则报错。

dic = {'CSDN': 'Dream丶killer',
       '公众号': 'Python新视野'}
dic.popitem()
复制代码
output:('公众号', 'Python新视野')


集合


set.add()

向集合中添加一个元素,但如果该元素已经出现在集合中,则不起作用。

示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.add('python')
set1
复制代码
output:{'Dream丶Killer', 'Python新视野', 'python', 'python-sun'}


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.add('python-sun')
set1
复制代码
output:{'Dream丶Killer', 'Python新视野', 'python-sun'}
添加的元素 python-sun 已经出现在集合中,所以 set1 不发生变化


set.clear()

clear() 移除集合中的所有元素。

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.clear()
set1
复制代码
output:set()


set.difference() & set.difference_update()

1️⃣difference() 返回多个集合的差集,通俗来讲就是返回第一个 set 中哪些元素没有在其他 set 中出现。

示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python', 'Dream丶Killer'}
set3 = {'Python新视野'}
set1.difference(set2, set3)
复制代码
output:{'python-sun'}
set1 中的元素只有 python-sun 没有在 set2set3 中出现过,所以以及集合的形式返回 {'python-sun'}


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python', 'Dream丶Killer'}
set3 = {'Python新视野', 'python-sun'}
set1.difference(set2, set3)
复制代码
output:set()
set1 中的元素都在 set2set3 中出现过,所以返回空集合 set()


2️⃣difference_update() 方法与 difference() 方法的区别在于 difference() 方法返回一个移除相同元素的新集合,而 difference_update() 方法是直接移除原集合中的元素,无返回值。


示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python', 'Dream丶Killer'}
set3 = {'Python新视野'}
set1.difference_update(set2, set3)
set1
复制代码
output:{'python-sun'}
set1 中的元素 Dream丶KillerPython新视野 都有在 set2set3 中出现过,所以从 set1 中移除这些值


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python', 'Dream丶Killer'}
set3 = {'Python新视野', 'python-sun'}
set1.difference_update(set2, set3)
set1
复制代码
output:set()
set1 中的元素都在 set2set3 中出现过,set1 移除所有值后为空集合 set()


set.discard()

discard() 删除集合中指定的元素。如果指定移除的元素不在集合中,则不移除。

示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.discard('Dream丶Killer')
set1
复制代码
output:{'Python新视野', 'python-sun'}
指定的元素存在于 set1 ,将它存 set1 中移除


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.discard('python')
set1
复制代码
output:{'Dream丶Killer', 'Python新视野', 'python-sun'}
指定的元素不在 set1 内,set1 不做改变


set.intersection() & set.intersection_update()

1️⃣intersection() 返回集合的交集。没有交集则返回空集 set()

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python-sun', 'Dream丶Killer'}
set3 = {'Python新视野', 'python-sun'}
set1.intersection(set2, set3)
复制代码
output:{'python-sun'}
返回 set1set2set3 中同时出现的元素


2️⃣intersection_update() 方法与 intersection() 方法的区别在于 intersection() 方法将集合的交集作为新集合返回,而 intersection_update() 方法是直接修改原集合中的元素,只保留交集元素,无返回值。


set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python-sun', 'Dream丶Killer'}
set3 = {'Python新视野', 'python-sun'}
set1.intersection_update(set2, set3)
set1
复制代码
output:{'python-sun'}
set1 中只有 'python-sun 同时在 set2set3 中出现过,因此移除 set1 中其他元素


set.isdisjoint()

isdisjoint() 判断两个集合是否包含相同的元素,有则返回 False,无则返回 True


示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python-sun', 'Dream丶Killer'}
set1.isdisjoint(set2)
复制代码
output:False
set1set2 中有两个相同元素,返回 False


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python'}
set1.isdisjoint(set2)
复制代码
output:True
set1set2 中无相同元素,返回 True


set.issubset()

set2.issubset(set1) 判断集合 set2 是否为 set1 集合的子集。是则返回 True,否则返回 False

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python-sun', 'Dream丶Killer'}
set2.issubset(set1)
复制代码
output:True
set2set1 集合的子集,故返回 True ,使用时需注意 set1set2 的位置顺序。如果写成 set1.issubset(set2) 则会返回 False


set.issuperset()

set1.issuperset(set2) 判断集合 set2 是否为 set1 集合的子集。是则返回 True,否则返回 False。它与 issubset() 用法相同,只有参数的位置相反而已。

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python-sun', 'Dream丶Killer'}
set1.issuperset(set2)
复制代码
output:True


set1.pop()

pop() 移除并返回集合中的任意元素。如果该集合为空集则报错。

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.pop()
复制代码
output:'python-sun'


set.remove()

remove() 从集合中移除指定的元素,如果该元素不在集合中,则发生报错。

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.remove('Dream丶Killer')
set1
复制代码
output:{'Python新视野', 'python-sun'}


set.symmetric_difference()

symmetric_difference() 返回两个集合中不重复的元素集合,即两个集合的补集,与 ^ 的作用相同。


示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python', 'python-sun', 'Dream丶Killer'}
set1.symmetric_difference(set2)
复制代码
output:{'Python新视野', 'python'}


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python',
      'python-sun',
      'Dream丶Killer'}
set1 ^ set2
复制代码
output:{'Python新视野', 'python'}
结果与上面相同


set.symmetric_difference_update()

set1.symmetric_difference_update(set2) 移除 set1 中在 set2 相同的元素,并将 set2 集合中不同的元素插入到 set1 中。简单来说就是把 set1set2 的补集赋值给 set1


示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python',
    'python-sun',
    'Dream丶Killer'}
set1.symmetric_difference_update(set2)
set1
复制代码
output:{'Python新视野', 'python'}


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python',
    'python-sun',
    'Dream丶Killer'}
set1 = set1 ^ set2
set1
复制代码
output:{'Python新视野', 'python'}


set.union()

union() 返回多个集合的并集。与 | 的作用相同。


示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python',
    'python-sun',
    'Dream丶Killer'}
set3 = {'ABC'}
set1.union(set2, set3)
复制代码
output:{'ABC', 'Dream丶Killer', 'Python新视野', 'python', 'python-sun'}


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set2 = {'python',
    'python-sun',
    'Dream丶Killer'}
set3 = {'ABC'}
set1 | set2 | set3
复制代码
output:{'ABC', 'Dream丶Killer', 'Python新视野', 'python', 'python-sun'}


set.update()

update() 使用本身和其他的联合来更新集合。


示例 🅰️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1.update([1,2,3])
set1
复制代码
output:{1, 2, 3, 'Dream丶Killer', 'Python新视野', 'python-sun'}


示例 🅱️

set1 = {'Dream丶Killer',
        'Python新视野',
        'python-sun'}
set1 = set1 | set([1,2,3])
set1
复制代码
output:{1, 2, 3, 'Dream丶Killer', 'Python新视野', 'python-sun'}

使用 | 也可以达到相同的效果。



相关文章
|
1天前
|
开发者 Python
Python入门:8.Python中的函数
### 引言 在编写程序时,函数是一种强大的工具。它们可以将代码逻辑模块化,减少重复代码的编写,并提高程序的可读性和可维护性。无论是初学者还是资深开发者,深入理解函数的使用和设计都是编写高质量代码的基础。本文将从基础概念开始,逐步讲解 Python 中的函数及其高级特性。
Python入门:8.Python中的函数
|
28天前
|
测试技术 Python
【03】做一个精美的打飞机小游戏,规划游戏项目目录-分门别类所有的资源-库-类-逻辑-打包为可玩的exe-练习python打包为可执行exe-优雅草卓伊凡-持续更新-分享源代码和游戏包供游玩-1.0.2版本
【03】做一个精美的打飞机小游戏,规划游戏项目目录-分门别类所有的资源-库-类-逻辑-打包为可玩的exe-练习python打包为可执行exe-优雅草卓伊凡-持续更新-分享源代码和游戏包供游玩-1.0.2版本
106 31
【03】做一个精美的打飞机小游戏,规划游戏项目目录-分门别类所有的资源-库-类-逻辑-打包为可玩的exe-练习python打包为可执行exe-优雅草卓伊凡-持续更新-分享源代码和游戏包供游玩-1.0.2版本
|
1月前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
16 0
|
1月前
|
人工智能 Python
【02】做一个精美的打飞机小游戏,python开发小游戏-鹰击长空—优雅草央千澈-持续更新-分享源代码和游戏包供游玩-记录完整开发过程-用做好的素材来完善鹰击长空1.0.1版本
【02】做一个精美的打飞机小游戏,python开发小游戏-鹰击长空—优雅草央千澈-持续更新-分享源代码和游戏包供游玩-记录完整开发过程-用做好的素材来完善鹰击长空1.0.1版本
56 7
|
1月前
|
存储 人工智能 运维
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
199 48
【01】做一个精美的打飞机小游戏,浅尝阿里云通义灵码python小游戏开发AI编程-之飞机大战小游戏上手实践-优雅草央千澈-用ai开发小游戏尝试-分享源代码和游戏包
|
1月前
|
程序员 Linux Python
python中模板和包的使用
本文介绍了 Python 模块和包的基本概念及使用方法。模块是 Python 程序结构的核心,每个以 `.py` 结尾的源文件都是一个模块,包含可重用的代码。文章详细讲解了模块的导入方式(如 `import` 和 `from...import`),模块的搜索顺序,以及如何创建和发布自己的模块。此外,还介绍了包的概念,包是包含多个模块的特殊目录,并通过 `__init__.py` 文件定义对外提供的模块列表。最后,文章简述了如何使用 `pip` 工具管理第三方模块的安装与卸载。作者:大石头的笔记;来源:稀土掘金。
|
1月前
|
Python
[oeasy]python057_如何删除print函数_dunder_builtins_系统内建模块
本文介绍了如何删除Python中的`print`函数,并探讨了系统内建模块`__builtins__`的作用。主要内容包括: 1. **回忆上次内容**:上次提到使用下划线避免命名冲突。 2. **双下划线变量**:解释了双下划线(如`__name__`、`__doc__`、`__builtins__`)是系统定义的标识符,具有特殊含义。
32 3
|
1月前
|
JSON 监控 安全
深入理解 Python 的 eval() 函数与空全局字典 {}
`eval()` 函数在 Python 中能将字符串解析为代码并执行,但伴随安全风险,尤其在处理不受信任的输入时。传递空全局字典 {} 可限制其访问内置对象,但仍存隐患。建议通过限制函数和变量、使用沙箱环境、避免复杂表达式、验证输入等提高安全性。更推荐使用 `ast.literal_eval()`、自定义解析器或 JSON 解析等替代方案,以确保代码安全性和可靠性。
45 2
|
2月前
|
数据可视化 DataX Python
Seaborn 教程-绘图函数
Seaborn 教程-绘图函数
87 8
|
2月前
|
Python
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
Python中的函数是**一种命名的代码块,用于执行特定任务或计算
64 18

热门文章

最新文章

推荐镜像

更多