第四天python3 python解析式-生成器-迭代器

标准库datetime

datetime模块  对日期、时间、时间戳的处理

  datetime类

    类方法:

      today() 返回本地时区当前时间的datetime对象;

      now(tz=None) 返回当前时间的datetime对象,时间到微秒,如果tz为None,返回和today()一样; 

      utcnow() 没有时区的当前时间

      fromtimestamp(timestamp,tz=None)从一个时间戳返回一个datetime对象

    datetime对象

      timestamp() 返回一个到微秒的时间戳;

        时间戳:格林尼治时间1970年1月1日0点到现在的秒数;

      构造方法:datetime.datetime(2020,06,10,22,00,00,79043)  模块名.类名()

          year/month/day/hour/minute/second/microsecond取datetime对象的年月日时分秒及微秒

      weekday() 返回星期的天,周一0,周日6

      isoweekday() 返回星期的天,周一是1,周日是7;

      date() 返回日志date对象

      time() 返回time对象

      replace() 修改并返回新的时间
      isocalendar() 返回一个三元组(年、周数、周的天)

                     

日期格式化

  类方法 strptime(date_string,format)  返回datetime对象

  对象方法 strftime(format) 返回字符串

  字符串format格式化

      

timedelta对象

  datetime2 = datetime1 + timedelta

  datetime2 = datetime1 - timedelta

  timedelta = datetime1 - datetime2

  构造方法:

    datetime.timedelta(days=0,seconds=0,microseconds=0,milliseconds=0,minutes=0,hours=0,weeks=0)

    year = datetime.timedelta(days = 365)

  total_seconds() 返回时间差的总秒数

  

标准库time

  time.sleep(secs) 将调用线程刮起指定的秒数

    

   时间解析推荐用datetime;

列表解析

  语法:[返回值 for 元素 in 可迭代对象 if 条件]

      使用中括号,内部for循环,if条件语句可选,返回一个新的列表;

  生成一个列表,元素0-9,对每个元素自增1后求平方返回新的列表

  

    用一个for循环,产生新的元素((i+1)**2),组成一个新列表;

  通过for循环的方式和通过列表解析式的方式都可以生成一个新的列表,但是列表解析式的这种方式效率更高;列表解析式会做编译器优化;

  优势:列表解析式是一种语法糖,编译器会优化,不会因为简写而影响效率,反而因优化提高了效率;减少工作量,减少出错,简化了代码,增强可读性;

    示例:获取10以内的偶数,比较执行效率

              

列表解析式进阶

  示例:20以内,既能被2整除,又能被3整除的数; 

          

  示例2:

  

生成器表达式 Generator expression

语法

  (返回值for 元素 in 可迭代对象 if 条件)

  列表解析式的中括号换成小括号即可

  返回一个生成器

和列表解析式的区别

  生成器表达式是按需计算(或称惰性求值、延迟计算),需要的时候才计算值

  列表解析式是立即返回值

        

生成器

  可迭代对象

  迭代器 

      

  可以通过next()来判断是否是迭代器
  

 

生成器表达式和列表的区别 

 

 示例:

  

 

 生成器表达式和列表解析式的对比:

  计算方式:生成器表达式延迟计算,列表解析式立即计算;

  内存占用:单从返回值本身来说,生成器表达式省内存,列表解析式返回新的列表;

    生成器没有数据,内存占用极少,但是使用的时候,虽然一个个返回数据,但是合起来占用内存也差不多;

    列表解析式构造新的列表需要占用内存;

  计算速度:

    单看计算时间,生成器表达式耗时非常短,列表解析式耗时长;

    但是生成器本身并没有返回值,只返回了一个生成器对象;

    列表解析式构造并返回了一个新的列表;

集合解析式

  语法

    {返回值 for 元素 in 可迭代对象 if 条件}

    列表解析式的中括号换成大括号{ }

    立即返回一个集合

            

字典解析式

  语法

    {返回值 for 元素 in 可迭代对象 if 条件}

    列表解析式的中括号换成大括号{ }

    使用key:value形式

    立即返回一个字典

  用法    

    {x:(x,x+1) for x in range(10)}

    {x:[x,x+1] for x in range(10)}

    {(x,):[x,x+1] for x in range(10)}

    {[x]:[x,x+1] for x in range(10)} #错误示范 

    {chr(0x41+x):x**2 for x in range(10)}

    {str(x):y for x in range(3) for y in range(4)}

总结:

  python2 引入列表解析式

  python2.4 引用生成器表达式

  python3 引入集合,字典解析式,并迁移到2.7

      一般来说,应该多应用解析式,简短,高效;

  如果一个解析式非常复杂,难以读懂,要考虑拆解成for循环;

  生成器和迭代器是不同的对象,但都是可迭代对象;生成器可以是迭代器,但是迭代器并不一定是生成器;

posted @ 2020-06-11 00:33  潇湘神剑  阅读(174)  评论(0编辑  收藏  举报