Python全栈工程师(集合、函数)

简介:     ParisGabriel                感谢 大家的支持  你们的阅读评价就是我最好的动力  我会坚持把排版内容以及偶尔的错误做的越来越好                                                    ...

 

 

 

 

 ParisGabriel
 
               感谢 大家的支持  你们的阅读评价就是我最好的动力  我会坚持把排版内容以及偶尔的错误做的越来越好 
 
                                
 
                     



                   每天坚持 一天一篇 点个订阅吧  灰常感谢    当个死粉也阔以

 

                              Python人工智能从入门到精通

 

集合 set:
        集合是可变的容器
        集合内的数据对象都是唯一的(不能重复的)
  集合是无序的储存结构。集合中的数据没有先后顺序关系
  集合内的元素必须是不可变对象
  集合是可迭代对象
  集合相当于只有键没有值得字典(键则是集合的数据)
  (相当于字典和列表的结合 )

创建集合:
  s = set() #空集合
  s = {3.14,True,(1970.1.1),“hello”} #非空

集合的构造函数:
  set()创建一个空集合(不能用{} 否则就是字典了)
  set(iterable)用可迭代对象创建一个新的集合
  创建新集合 内容重复会自动去重

例如:

集合的运算:
  交集、并集、补集,子集、超集
& 生成连个集合的交集
  重复部分
  s1 ={1,2,3}
  s2 ={2,3,4}
  s3 = s1&s2 #s3 = {2,3}


| 生成两个集合的并集
  所有不重复部分
  s1 ={1,2,3}
  s2 ={2,3,4}
  s3 = s1 | s2 #s3 = {1,2,3,4}

- 生成两个集合的补集
  相当于减法
  s1 ={1,2,3}
  s2 ={2,3,4}
  s3 = s1 - s2 #s3 = {1}

^ 生成两个集合的对称补集
  相当于减法相加
  s1 ={1,2,3}
  s2 ={2,3,4}
  s3 = s1 ^ s2 # (s1 - s2 | s2 - s1) #{1, 4}

> 判断一个集合是另一个集合的超集
< 判断一个集合是另一个集合的子集
  s1 ={1,2,3}
  s2 ={2,3}
  s1 > s2 #true s1 为s2的 超集
  s1 < s2 #true s1 为s2的 子集

  (包含关系判断)
== != 集合相同/不同
  s1 ={1,2,3}
  s2 ={3,2,1}
  s1 == s2 # true
  s1 != s2 #false

in / not in :
  等同于字典的运算
  判断某个值是否存在

集合和字典的优点:
  in/not in 运算符速度相对来说快一些

能用于集合的函数:
  len(x)、max(x)、min(x)、sum(x)、any(x)、all(x)

 

Python3中常用的集合方法:
  方法 ;          意义:
  S.add(e)        在集合中添加一个新的元素e;如果元素已经存在,则不添加
  S.remove(e)       从集合中删除一个元素,如果元素不存在于集合中,则会产生一个KeyError错误
  S.discard(e)       从集合S中移除一个元素e,在元素e不存在时什么都不做;
  S.clear()        清空集合内的所有元素
  S.copy()        将集合进行一次浅拷贝
  S.pop()         从集合S中删除一个随机元素;如果此集合为空,则引发KeyError异常
  S.update(s2)        用 S与s2得到的全集更新变量S
  S.difference(s2)      用S - s2 运算,返回存在于在S中,但不在s2中的所有元素的集合
  S.difference_update(s2)      等同于 S = S - s2
  S.intersection(s2)           等同于 S & s2
  S.intersection_update(s2)   等同于S = S & s2
  S.isdisjoint(s2)        如果S与s2交集为空返回True,非空则返回False
  S.issubset(s2)        如果S与s2交集为非空返回True,空则返回False
  S.issuperset(...)     如果S为s2的子集返回True,否则返回False
  S.symmetric_difference(s2)            返回对称补集,等同于 S ^ s2
  S.symmetric_difference_update(s2)    用 S 与 s2 的对称补集更新 S
  S.union(s2)                生成 S 与 s2的全集

 

集合推导式:
  结合推导式是用可迭代对象生成集合的表达式
语法:
  {表达式 for 变量 in 可迭代对象[if 真值表达式]}
  之前说过 [ ] 内的代表可以省略
例如:
  L= [1, 2, 5, 6, 3, 5, 9, 4, 5]
  s = {x for x in L)}
  (推导式嵌套同列表 、 字典一致)

 

固定集合 frozenset:
  是不可变的、无序的、含有唯一元素的集合
  用于固定集合可以作为字典的键,还可以作为集合的值
构造函数:
  frozenset() 创建一个空固定集合
  frozenset(iterable)用可迭代对象创建固定集合
例如:
  f = frozenset()# 空固定集合
  f = frozenset([ 1, 3, 5, 7]) # f = frozenset({1, 3, 5, 7})

固定集合运算:
  & 交集 、 | 并集 、- 补集、^ 对称补集
  >、 >= 、< 、<=、 ==、 !=
  in /not in
  (和集合 set 一致)
固定集合方法:
  集合的方法取掉所有修改方法


                             小结:

数据类型:
  数值类型:
    int、float、complex、bool

  容器类型:
    不可变容器:
      str、tuple、frozenset、bytes(字节串)
    可变容器:
      list、dict、set、bytearray(字节组)
  值:
    None、false、True
运算符:
  算数运算符:
    +、 - 、 * 、 / 、 // 、 % 、 **
  比较运算符:
    < 、 > 、 <= 、 >= 、 == 、 !=
    in / not in 、 is / is not
  布尔运算符:
    not 、 and 、or
    +(正号)、 -(负号)
    &、^ 、| 、 [ ] (索引)
表达式:
  1
  1+2
  max(1,2,3,)
  x if x > y else y (条件表达式)
  三种推导式:
    列表、字典、集合推导式(3种)
语句:
  表达式语句:
    所有的语句都可单独写在一行,形成一个语句
    例如:
      print(“hello world”)
      1 + 2
  赋值语句:
    a = 100
    a = b = c = 100
    x, y = 100, 200
    a[0] = 100
    dict [ "name"] = "tarena"
    del 语句
    while 语句
    for 语句
    break 语句
    continue 语句
    pass 语句
函数:
  内建函数:(系统内置函数
    len(x)
    max(x)
    min(x)
    sum(x)
    any(x)
    all(x)
  构造函数:(用来创建同类型的数据对象)
    bool(x)
    int(x)(进制转换可以添加进制参数 be>=2 and <= 36)
    float(x)
    complex(x)
    list(x)
    tuple(x)
    str(x)
    dict(x)
    set(x)
    abs(x)
    round(x)
    pow(x,y,z = None)
    bin(x)
    oct(x)
    hex(x)
    chr(x)
    ord(x)
    range(star,stop,step)
    input(x)
    print(x)
    help(__builtins__)

之前讲的差不多也就这些了

接下来我们讲函数

ok everyone   在开始之前的我想先说两句 咳咳:

之前比如说101等于5对吧  可能手一哆嗦打成了011

有细心的小伙伴就发发现了  给我评论 

你们如果有什么问题 可以随时评论  我看到后 都会回复的

能解决的我有时间都会去解决

比如说哪里不懂啊 逻辑想不通啊 或者比较迷茫的 都是可以的

前面12课说的都是常用的和偶尔用的一些基础的运算以及语法

很多东西一次测扯出来根本听不懂的 学习要循序渐进对吧

后面的东西 我们会做一个实战项目  边做边学  

有些可能一辈子用不几次的东西就没说  感兴趣的朋友可以 交互模式下help 查看一下帮助

或者官方的api文档 翻译好的api文档都是可以的   第一课之前的那个文章 我在里面加了api文档地址 有兴趣的可以去下载

这个项目的就是学生信息管理系统  昨天的第二题练习 我们已经做了一个开头了对吧 

好了不废话了  进入正题

 

函数: function
  函数是可以重复执行调用的语句块
  作用:
    1.用于封装语句块,提高代码的重用性
    2.定义用户级别的函数
def 创建函数语句:
  def 函数名(形参列表):
    语句块
  说明:
    1. 函数的名字就是语句块的名称
    2. 函数名的命名规则与变量名相同(函数名必须是标识符)
    3. 函数名是一个变量(不要轻易对其赋值)
    4. 函数有自己的空间,在函数外部不可以访问函数内部的变量,但是可以访问外部变量
    5. 函数如果不需要传入参数,形参列表可以为空
    6. 语句部分不能为空,如果为空需要填充pass
return 创建返回值语句:
  用于函数中,结束当前函数的执行返回调用该函数的地方,同时返回一个对象的引用关系
  return[表达式]
  ([ ] 代表可以省略)
  说明:
    1. 函数调用是一个表达式
    2. 如果函数内部没有return语句,函数调用完毕后返回None对象
    3. 如果函数需要返回其它的对象需要用到 return 语句
函数的调用:
  函数名(实际调用传递参数)
  (实际调用传递参数,简称实参)

练习:
1.任意输入一些数字,存于列表L中。当输入负数时结束输入
1) 打印这些数的和
2) 打印这些数有多少种(去重)
3) 除重复的数字后,打印这些剩余数字的和

提示,可以用集合去重

答案:

L = []
while True:
    a = int(input("please input at will ingeger (input '-1' over):"))
    if a < 0:
        break
    L.append(a)
print(sum(L))
s = set(L)
print(len(s))
print(sum(s))

2. 经理有: 曹操,刘备,孙权
技术员有: 曹操,孙权,张飞,关羽
用集合求:
1) 即是经理,也是技术员的有谁?
2) 是经理,但不是技术员的人员都有谁?
3) 是技术员,不是经理的都有谁
4) 张飞是经理吗?
5) 身兼一职的人都有谁?
6) 经理和技术员共有几个人?

答案:

s = {"曹操", "刘备", "孙权"}
s1 = {"曹操", "孙权", "张飞", "关羽"}
if "张飞" in s:
    x = ""
else:
    x = "不是"
print('''
即是经理,也是技术员的有:%s
是经理,但不是技术员的人员有:%s
是技术员,不是经理的有:%s
张飞%s经理
身兼一职的人有:%s
经理和技术员共有:%d个人
''' % (
    s & s1,
    s - s1,
    s1 - s,
    x, s ^ s1,
    len(s | s1)))

 

3. 写一个函数myadd, 此函数中的参数列表里有两个参数x, y
此函数的功能是打印 x + y 的和

def myadd(....):
.... # 注: .... 部是是我们要填写代码的地方

myadd(100, 200) # 300
print("ABC", "123") # ABC123

 

 

4. 写一个函数 mysum, 传入一个参数x代表终止整数,
打印出 1 + 2 + 3 + 4 + ..... + x的和
def mysum(x):
....

mysum(100) # 5050
mysum(4) # 10

答案:

def mysum(x):
    s = 0
    for i in range(1, x + 1):
        s += i
    print(s)
mysum(100)
mysum(4)

5. 写一个函数 mymax, 给函数传递两个参数,返回两个实参中最大的一个
def mymax(a, b):
....

v = mymax(100, 200)
print('v =', v) # v = 200
print(mymax('ABC', 'abc')) # abc

答案:

 

def mymax(a, b):
    if a > b:
        return a
    return b
x = mymax(100, 200)
print(x)

 

6. 写一个函数 input_number
def input_number():
....

此函数用来获取用户循环输入的整数,当用户输入负数时结束输入。将用户输入的数字以列表的形式返回,再用内建函数max, min, sum取出户输入的最大值,最小值及和

L = input_number()
print(L) # 打印此列表
print("用户输入的最大数是:", max(L))
print("用户输入的最小数是:", min(L))
print("用户输入的数的和是:", sum(L))

答案:

def inout_number():
    L = []
    while True:
        number = int(input("please inoput (-1:over):"))
        if number < 0:
            break
        L.append(number)
    return L
L = inout_number()
print("Top1  ", max(L))
print("lower1  ", min(L))
print("sum  ", sum(L))

7. 写一个函数 print_odd, 打印从begin开始,到end结束(不包含end)内的全部的奇数
def print_odd(begin, end):
....

print_odd(1, 10) # 打印 1 3 5 7 9d
ptint_odd(10, 20) # 打印 11 13 15 17 19

答案:

def myodd(begin, end):
    for x in range(begin, end):
        if x % 2 != 0:
            print(x, end = " ")
    print()
myodd(1, 10)
myodd(10, 100)

 

9. 改写之前的学生信息管理程序
改为两个函数:
1. 写一个函数 input_student() 用于返回学生信息的字典的列表(以前格式一样)
2. 写一个函数 output_student(lst)
此函数传入一个列表lst,即字典的列表
此函数把lst的内容以表格形式打印出来
def input_student():
....

def output_student(lst):
...

L = input_student() # 获取学生信息的列表
output_student(L) # 把L 以列表的形式打印

 答案:

# 创建输入函数:input_student开始
def input_student():
    print("--------Student information enty--------")
    L = []
    while True:
        name = input("please input name:")
        if name == "":
            break
        age = input("please input age:")
        score = input("please input score:")
        d = {}
        d = {"name": name, "age": age, "score": score}
        L.append(d)
    return L
# 创建输入函数:input_student完成

# 创建输出函数:output_student开始
def output_student(lst):
    print("-------Student information sheet-------")
    print("+---------------+----------+----------+")
    print("|     name      |    age   |   score  |")
    print("+---------------+----------+----------+")
    for d in lst:
        name = d["name"].center(15)
        age = d["age"].center(10)
        score = d["score"].center(10)
        print('''|%s|%s|%s|''' % (name, age, score))
        print("+---------------+----------+----------+")
# 创建输出函数:output_student完成

output_student(input_student())

 

相关文章
|
1天前
|
开发者 Python
Python入门:8.Python中的函数
### 引言 在编写程序时,函数是一种强大的工具。它们可以将代码逻辑模块化,减少重复代码的编写,并提高程序的可读性和可维护性。无论是初学者还是资深开发者,深入理解函数的使用和设计都是编写高质量代码的基础。本文将从基础概念开始,逐步讲解 Python 中的函数及其高级特性。
Python入门:8.Python中的函数
|
1月前
|
存储 人工智能 Python
[oeasy]python061_如何接收输入_input函数_字符串_str_容器_ 输入输出
本文介绍了Python中如何使用`input()`函数接收用户输入。`input()`函数可以从标准输入流获取字符串,并将其赋值给变量。通过键盘输入的值可以实时赋予变量,实现动态输入。为了更好地理解其用法,文中通过实例演示了如何接收用户输入并存储在变量中,还介绍了`input()`函数的参数`prompt`,用于提供输入提示信息。最后总结了`input()`函数的核心功能及其应用场景。更多内容可参考蓝桥、GitHub和Gitee上的相关教程。
16 0
|
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
|
2月前
|
Python
Python中的函数
Python中的函数
62 8
|
3月前
|
搜索推荐 Python
利用Python内置函数实现的冒泡排序算法
在上述代码中,`bubble_sort` 函数接受一个列表 `arr` 作为输入。通过两层循环,外层循环控制排序的轮数,内层循环用于比较相邻的元素并进行交换。如果前一个元素大于后一个元素,就将它们交换位置。
155 67
|
3月前
|
监控 测试技术 数据库
Python中的装饰器:解锁函数增强的魔法####
本文深入探讨了Python语言中一个既强大又灵活的特性——装饰器(Decorator),它以一种优雅的方式实现了函数功能的扩展与增强。不同于传统的代码复用机制,装饰器通过高阶函数的形式,为开发者提供了在不修改原函数源代码的前提下,动态添加新功能的能力。我们将从装饰器的基本概念入手,逐步解析其工作原理,并通过一系列实例展示如何利用装饰器进行日志记录、性能测试、事务处理等常见任务,最终揭示装饰器在提升代码可读性、维护性和功能性方面的独特价值。 ####
|
3月前
|
中间件 Docker Python
【Azure Function】FTP上传了Python Function文件后,无法在门户页面加载函数的问题
通过FTP上传Python Function至Azure云后,出现函数列表无法加载的问题。经排查,发现是由于`requirements.txt`中的依赖包未被正确安装。解决方法为:在本地安装依赖包到`.python_packages/lib/site-packages`目录,再将该目录内容上传至云上的`wwwroot`目录,并重启应用。最终成功加载函数列表。

热门文章

最新文章

推荐镜像

更多