函数使用

生成器

  • 使用场景:

    在使用列表时,很多时候我们都不会一下子使用全部的数据,通常都是一个一个使用,但是数据量较小的时候,对于内存的占用可以不用过于关心;但是当数据量较大时,就会出现内存使用突然增大的情况。为了解决内存占用突然增大的问题,python中引入了生成器的概念

  • 使用方式:

    • 将列表生成式中的[]改为()即可
    lt = (i for i in range(2))
    
    # 转换为列表
    # print(list(lt)) # 一个一个获取,取完后继续使用next会报错
    # print(next(lt)) # 遍历
    for i in lt:
    print(i)

    说明:任意方式的使用生成器,都只能时单次的。

    • 通过在函数中使用关键字yield完成
    def test(n):
    for i in range(1, n+1):
    yield i t = test(5)
    # 生成器对象
    print(t) # 一次一个获取
    # print(next(t))
    # print(next(t))
    # print(next(t)) # 遍历
    # for i in t:
    # print(i) # 转换为列表
    print(list(t))
  • 总结:

    • 生成器保存了生成数据的算法,并不是所有的数据
    • 生成器只能执行一遍
    • 具体操作:转换为列表、next、for-in

迭代器

  • 定义:能够使用for-in进行遍历,并且可以通过next函数依次获取元素的对象

  • 说明:

    • 生成器就是一种特殊的迭代器
    • 判断一个对象是否是迭代器
    from collections import Iterator
    lt = (i for i in range(10))
    print(isinstance(lt, Iterator))
    • 字符串、列表、元组、集合、字典等都不是迭代器,它们都是可迭代对象

可迭代对象

  • 定义:能够使用for-in进行遍历的对象,都是可迭代对象

  • 使用:判断是否是可迭代对象

    from collections import Iterable
    
    print(isinstance(lt, Iterable))
  • 说明:

    • 迭代器一定是可迭代对象
    • 前面学习的列表、元组等都是可迭代对象
  • 将可迭代对象转换为迭代器,使用专门的函数iter

高级函数

  • map

    • 格式:

      map(func, iter)
    • 说明:
      • 接收两个参数:一个函数和一个可迭代对象
      • 返回值:返回一个生成器
      • 生成器内容是将func依次作用域iter每个元素的处理结果
    • 示例:
    lt = [1, 2, 3, 4]
    
    def double(x):
    return x * 2 # 返回一个生成器
    # m = map(double, lt)
    m = map(lambda x: x*x, lt) print(list(m))
    • 练习:

      • 了解字符串处理函数strip
      • 使用map完成:将一个元素全为字符串的列表中的元素全部去掉两边的空白,首字母大写
  • filter

    • 格式:

      filter(func, iter)
    • 说明:
      • 参数是一个函数和一个可迭代对象
      • 返回一个生成器
      • 将func依次作用于iter中的元素,返回值为真的将会保留,为假的将会过滤掉
    • 示例:
    lt = [1, 2, 3, 4, 5]
    
    # 提取偶数
    f = filter(lambda x: x%2==0, lt)
    print(list(f))
    • 练习:提取能被3整除的奇数元素
  • reduce

    • 格式:

      reduce(func, iter)
    • 说明:
      • 接收两个参数,一个函数和一个可迭代对象
      • 首先取前两个元素作为func的参数,计算完的结果与第三个元素继续使用func处理,直至结束
      • 返回处理的最后结果
    • 示例:
    from functools import reduce
    
    lt = [1, 2, 3, 4, 5]
    
    # 求和
    # s = reduce(lambda x,y: x+y, lt)
    # 转换为12345
    s = reduce(lambda x,y: x*10+y, lt)
    print(s)
    • 练习:求列表中所有元素的乘积

random

  • randint:生成指定区间的一个随机整数
  • random:生成0~1之间的随机小数
  • uniform:生成指定范围内的随机浮点数
  • choice:随机提取一个元素
  • sample:随机提取指定个数的元素,返回一个列表
  • choices:sample函数指定提取元素个数为1的情况
  • shuffle:打乱元素顺序

练习:

  • 使用random函数实现randint函数的功能
  • 生成指定长度的随机字符串,参数:长度、类型
  • 将字符串完成如下转换,如:
    IloveYOUmoreTHANiCANsay => I love you more than i can say
  • 将一个列表的元素完成特定的向右移动,参数:列表,移动长度
    • 如:[1, 2, 3, 4, 5],移动2,结果:[4, 5, 1, 2, 3]
  • 传入n,计算
    1!+2!+3!+...+n!
    

    可以使用递归

Python基础—08-函数使用(02)的更多相关文章

  1. python基础——匿名函数

    python基础——匿名函数 当我们在传入函数时,有些时候,不需要显式地定义函数,直接传入匿名函数更方便.  在Python中,对匿名函数提供了有限支持.还是以map()函数为例,计算f(x)=x2时 ...

  2. python基础——返回函数

    python基础——返回函数 函数作为返回值 高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回.  我们来实现一个可变参数的求和.通常情况下,求和的函数是这样定义的: def calc_ ...

  3. python基础——sorted()函数

    python基础——sorted()函数 排序算法 排序也是在程序中经常用到的算法.无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小.如果是数字,我们可以直接比较,但如果是字符串或者两个d ...

  4. python基础——filter函数

    python基础——filter函数 Python内建的filter()函数用于过滤序列. 和map()类似,filter()也接收一个函数和一个序列.和map()不同的是,filter()把传入的函 ...

  5. python基础——匿名函数及递归函数

    python基础--匿名函数及递归函数 1 匿名函数语法 匿名函数lambda x: x * x实际上就是: def f(x): return x * x 关键字lambda表示匿名函数,冒号前面的x ...

  6. 八. Python基础(8)--函数

    八. Python基础(8)--函数 1 ● 函数返回布尔值 注意, 自定义的函数也可以是用来作逻辑判断的, 例如内置的startswith()等函数. def check_len(x):     ' ...

  7. python基础之函数详解

    Python基础之函数详解 目录 Python基础之函数详解 一.函数的定义 二.函数的调用 三.函数返回值 四.函数的参数 4.1 位置参数 4.2 关键字参数 实参:位置实参和关键字参数的混合使用 ...

  8. Python学习笔记(一)python基础与函数

    1.python基础 1.1输入与输出 输出 用print加上字符串,就可以打印指定的文字或数字 >>> print 'hello, world' hello, world > ...

  9. Day3 - Python基础3 函数、递归、内置函数

    Python之路,Day3 - Python基础3   本节内容 1. 函数基本语法及特性 2. 参数与局部变量 3. 返回值 嵌套函数 4.递归 5.匿名函数 6.函数式编程介绍 7.高阶函数 8. ...

  10. Python基础__函数

    本节将进入函数的介绍,函数是Python基础中最精彩的部分之一,接下来将对函数做详细介绍.函数 函数就是对代码进行一个封装.把实现某一功能的代码进行封装到一起.下次需要使用时不需要进行编写代码直接调用 ...

随机推荐

  1. Java线程中断的本质深入理解

    Java的中断是一种协作机制.也就是说调用线程对象的interrupt方法并不一定就中断了正在运行的线程,它只是要求线程自己在合适的时机中断自己. 一.Java中断的现象 首先,看看Thread类里的 ...

  2. Java判断文件、文件夹是否存在

    在完成工作室任务的时候多次遇到这个问题,这是一个常用的知识点,记录如下: 1.判断文件是否存在,不存在则创建文件 File file=new File("C:\\2.jpg"); ...

  3. 04.Path类的学习

    path 是路径的意思. path类是一个静态类,所以path是一个工具类. Path类是专门用来操作路径的. Path的常用方法: namespace _15.Path类的学习 { class Pr ...

  4. Thrift笔记(二)--Thrift框架分层设计

    thrift架构设计使用了分层设计,类似TCP/IP分层,上次使用下层提供的服务.分层设计在计算机中是一个常用的设计,上层和下层定义好接口或者说协议,下层实现可以随意更换,只要实现好定义的接口和协议就 ...

  5. html相对定位绝对定位

    孔子说:“温故而知新,可以为师矣.”这几天参加了一个免费的前端课,每天晚上都有直播,讲解一个独立的案例.在听前端基础的时候,发现自己有不少东西没学会,平时在学校虽说html也写了不少,但有好大一部分都 ...

  6. gsap

    TweenMax借助于css,轻量级的js库 下面是简单的demo <!DOCTYPE html> <html lang="en"> <head> ...

  7. Dubbo架构原理

    1 Dubbo核心功能 Remoting:远程通讯,提供对多种NIO框架抽象封装,包括“同步转异步”和“请求-响应”模式的信息交换方式. Cluster: 服务框架,提供基于接口方法的透明远程过程调用 ...

  8. Tomcat中部署web应用的三种方式

    Tomcat中部署web应用的三种方式(静态部署)       第一种,针对war或解压后的war,最为常用的是直接操作webapp目录,将完整的war包或者web应用直接放到webapp目录下.使用 ...

  9. Oracle:environment variable "PATH" does not exceed the recommended length

    今天重新安装oracle11g,突然在检测时报了以下错误: Environment variable: "PATH" - This test checks whether the ...

  10. percona MySQL 5.7yum安装

    检查是否安装有MySQL Server: rpm -qa | grep mysql rpm -qa | grep mariadb 删除方法: rpm -e mysql #普通删除模式 rpm -e - ...