zoukankan      html  css  js  c++  java
  • 模块(一) 模块的引入 collections(Counter计数 deque双向队列FIFO,栈FILO namedtuple命名元组 orderdict有序字典 defaultdict默认值字典 ) #时间模块# #random随机模块#

    模块(一)

    时间模块(自动跳转)

    一.模块的简单认识

      什么是模块. 模块就是我们把装有特定功能的代码进行归类的结果. 从代码编写的单位来看我们的程序, 从小到大的顺序: 一条代码 < 语句块 < 代码块(函数, 类) < 模块. 我们目前写的所有的py文件都是模块

      引入模块的⽅式:

      1. import 模块

      2. from xxx import 模块

      关于这两种写法. 我们后面还要继续介绍. 在之前的学习中, 我们已经用过了一些基本的模块了. 比如, random, os, sys, collections等等. 那我们⽬前用到的所有模块都是python内置的模块.不需要额外安装. 在后面学习⾼级框架的内容的时候. 可能需要我们⾃行安装⼀些第三方提供的模块.

    二.collections模块  

      collections模块主要封装了一些关于集合类的相关操作. 比如, 我们学过Iterable,Iterator等等. 除了这些以外, collections还提供了一些除了基本数据类型以外的数据集合型.Counter,deque,OrderDict, defaultdict以及namedtuple

      1. Counter
    counter是一个计数器. 主要用来计数
    计算一个字符串中每个字符出现的次数:

    from collections import Counter
    
    print(Counter("宝宝今年特别喜欢王宝强")) # 计数
    lst = ["jay",'jay',"jay","宝宝","宝宝", "胡辣汤", "上官婉儿", "上官婉儿"]
    dic = {"a":"哈哈", "b":"哈哈", "c":"车牌"}
    c = Counter(dic.values())
    print(c)
    low:
    s = "alex like pig"
    dic = {}
    for c in s:
    dic[c] = dic.get(c, 0) + 1
    print(dic)
    nb:
    s = "alex like pig"
    print(Counter(s)) # 获取到的结果可以像字典一样进行使用 [key]

      2. deque 双向队列.

    (重点)说双向队列之前我们需要了解两种数据结构.    1. 栈,2. 队列


    1. 栈: FILO.      先进后出 -> 砌墙的砖头, 老师傅做馒头


    2. 队列: FIFO.     先进先出 -> 买火⻋票排队, 所有排队的场景
    由于python没有给出Stack模块. 所以我们自己手动写一个粗略版本(注意, 此版本有严
    重的并发问题)

    栈
    特点: 先进后出
    class StackFullException(Exception):
        pass
    
    class StackEmptyException(Exception):
        pass
    
    class Stack:
    
        def __init__(self, size):
            self.size = size
            self.lst = [] # 存放数据的列表
            self.top = 0 # 栈顶指针
    
        # 入栈
        def push(self, el):
            if self.top >= self.size:
                raise StackFullException("your stack is full!!!!!")
            self.lst.insert(self.top, el) # 放元素
            self.top += 1 # 栈顶指针向上移动一下
    
        # 出栈
        def pop(self):
            if self.top == 0:
                raise StackEmptyException("your stack is empty!!!!!")
            self.top-=1
            el = self.lst[self.top]
            return el
    
    s = Stack(6)
    s.push("宝宝")
    s.push("我还")
    s.push("记得")
    s.push("")
    s.push("刚刚")
    s.push("说的话")
    print(s.pop())
    print(s.pop())
    print(s.pop())
    print(s.pop())
    print(s.pop())
    print(s.pop())

    #说的话
    #刚刚
    #你
    #记得
    #我还
    #宝宝

    队列: python提供了了queue模块. 使用起来非常方便

    import queue
    q = queue.Queue()
    q.put("李嘉诚1")
    q.put("李嘉诚2")
    q.put("李嘉诚3")
    q.put("李嘉诚4")
    q.put("李嘉诚5")
    
    print(q.get())
    print(q.get())
    print(q.get())
    print(q.get())
    print(q.get())

    #李嘉诚1
    #李嘉诚2
    #李嘉诚3
    #李嘉诚4
    #李嘉诚5

    接下来,. 我们来看⼀下deque, 注意, 此队列是collections中的.

    from collections import deque
    
    d = deque() # 创建双向队列
    d.append("宝宝") #  在右侧添加
    d.append("no")
    d.append("way")
    d.append("哈哈")
    d.appendleft("娃哈哈") # 在左边添加
    d.appendleft("爽歪歪")
    d.appendleft("优酸乳")
    
    
    print(d.pop()) # 从右边拿数据
    print(d.pop()) # 从右边拿数据
    print(d.pop()) # 从右边拿数据
    print(d.pop()) # 从右边拿数据
    print(d.popleft()) # 从左边拿数据
    print(d.popleft()) # 从左边拿数据
    print(d.popleft()) # 从左边拿数据
    #哈哈
    #way
    #no
    #宝宝
    #优酸乳
    #爽歪歪
    #娃哈哈

      3. namedtuple 命名元组
      命名元组, 顾名思义. 给元组内的元素进行命名. 比如. 我们说(x, y) 这是一个元组. 同
    时. 我们还可以认为这是⼀个点坐标. 这时, 我们就可以使用namedtuple对元素进行命名

    from collections import namedtuple
    # ⾃己定义了一个元组, 如果灵性够好, 这其实就是创建了一个类
    nt = namedtuple("point", ["x", "y"])
    p = nt(1, 2)
    print(p)
    print(p.x)
    print(p.y)
    from collections import namedtuple
    
    #
    p = namedtuple("Point", ["x", "y","z"])
    # 对象
    p1 = p(10, 20,30)
    print(p1)
    
    print(p1.x)
    print(p1.y)
    
    car = namedtuple("Car", ["pai", "color", "pailiang"])
    c = car("京C-10000", "绿色", "1.8T")
    print(c)
    
    import time
    print(time.localtime())
    
    class Point:
        def __init__(self, x, y):
            self.x = x
            self.y = y
    Point(10,20)

      4. orderdict和defaultdict  默认值字典
    orderdict 顾名思义. 字典的key默认是无序的. 而OrderedDict是有序的

    dic = {'a':'娃哈哈', 'b':'薯条', 'c':'胡辣汤'}
    print(dic)
    from collections import OrderedDict
    od = OrderedDict({'a':'娃哈哈', 'b':'薯条', 'c':'胡辣汤'})
    print(od)

    defaultdict: 可以给字典设置默认值. 当key不存在时. 直接获取默认值:

    from collections import defaultdict
    dd = defaultdict(list) # 默认值list
    print(dd['娃哈哈']) # [] 当key不不存在的时候. 会⾃动执行构造⽅法中传递的内容.
    

     

    from collections import defaultdict
    
    # 默认值字典
    dd = defaultdict(lambda: 0) # callable 可调用的, 字典是空的
    
    print(dd["张无忌"]) # 从字典向外拿数据. 字典是空的. key:callable()
    print(dd["宝宝"]) # 这里的[] 和get()不是一回事儿
    print(dd)
    
    
    from collections import OrderedDict
    
    dic = OrderedDict()  # 有序字典
    dic["b"] = "哈哈"
    dic['a'] = "呵呵"
    print(dic)
    print(dic.get("a"))
    print(dic.values())
    print(dic["a"])
    # OrderedDict([('b', '哈哈'), ('a', '呵呵')])
    # 呵呵
    # odict_values(['哈哈', '呵呵'])
    # 呵呵

    三. time 时间模块(重点)


      时间模块是我们要熟记的. 到后⾯写程序的时候经常能用到. 比如, 如何计算时间差.
    如何按照客户的要求展示时间. 等等.

    import time
    print(time.time()) # 1538927647.483177 系统时间

      此时, 我们已经获取到了系统时间, 但是这个时间....看不懂. 怎么办呢. 需要对时间进
    行格式化. 那这样就引出了另一种时间的格式. 在python中时间分成三种表现形式:
      1. 时间戳(timestamp). 时间戳使用的是从1970年年01⽉月01⽇日 00点00分00秒到现在
    一共经过了多少秒... 使用float来表示


      2. 格式化时间(strftime). 这个时间可以根据我们的需要对时间进行任意的格式化.


      3. 结构化时间(struct_time). 这个时间主要可以把时间进行分类划分. 比如. 1970
    年01⽉月01日 00点00分00秒 这个时间可以被细分为年, 月, 日.....一⼤堆东西.
    时间戳我们已经⻅过了就是time.time(). 一般, 我们不会把这样的时间显示给客户. 那
    就需要对时间进行格式化操作.

     

    s = time.strftime("%Y-%m-%d %H:%M:%S") # 必须记住
    print(s)

    日期格式化的标准:

    %y 两位数的年份表示(00-99%Y 四位数的年份表示(000-9999)
    %m 月份(01-12)
    %d 月内中的⼀天(0-31)
    %H 24小时制小时数(0-23)
    %I 12小时制小时数(01-12%M 分钟数(00=59)
    %S 秒(00-59)
    %a 本地简化星期名称
    %A 本地完整星期名称
    %b 本地简化的月份名称
    %B 本地完整的月份名称
    %c 本地相应的日期表示和时间表示
    %j 年内的一天(001-366%p 本地A.M.或P.M.的等价符
    %U 一年中的星期数(00-53)星期天为星期的开始
    %w 星期(0-6),星期天为星期的开始
    %W 一年年中的星期数(00-53)星期一为星期的开始
    %x 本地相应的日期表示
    %X 本地相应的时间表示
    %Z 当前时区的名称
    %% %号本身

    看一下结构化时间:

    print(time.localtime())
    结果:
    time.struct_time(tm_year=2017, tm_mon=05, tm_mday=8, tm_hour=10, tm_min=24,
    tm_sec=42, tm_wday=0, tm_yday=126, tm_isdst=0)

    时间格式转化

    重点:
    # 数据库里存储一个数字. 把它还原成我们的格式化时间
    a = 0
    # 先把这个时间戳转化成python中的结构化时间
    # t = time.localtime(a) # 本地化的东八区的时间
    t = time.gmtime(a) # 格林尼治时间
    # 把一个结构化时间转化成格式化时间
    s = time.strftime("%Y-%m-%d %H:%M:%S", t)
    print(s)
    
    
    # 让用输入一个时间. 把这个时间转化成时间戳
    user_input = input("请输入一个时间:")
    # 把用户输入的字符串转化成结构化时间
    struct_time = time.strptime(user_input, "%Y-%m-%d %H:%M:%S") # p: parse
    # 转化成时间戳
    num = time.mktime(struct_time)
    print(num)

    计算时间差

    import time
    true_time=time.mktime(time.strptime('2017-09-11 08:30:00','%Y-%m-%d
    %H:%M:%S'))
    time_now=time.mktime(time.strptime('2017-09-12 11:00:00','%Y-%m-%d
    %H:%M:%S'))
    dif_time=time_now-true_time
    struct_time=time.localtime(dif_time)
    print(struct_time)
    print('过去了了%d年年%d⽉月%d天%d⼩小时%d分钟%d秒'%(struct_time.tm_year-1970,
    struct_time.tm_mon-1,struct_time.tm_mday1,struct_time.tm_hour,
    struct_time.tm_min,struct_time.tm_sec))

    四. random模块
    所有关于随机相关的内容都在random模块中.

    import random
    print(random.random()) # 0-1小数
    print(random.uniform(3, 10)) # 3-10小数
    print(random.randint(1, 10)) # 1-10整数 [1, 10]
    print(random.randrange(1, 10, 2)) # 1-10奇数 [1,10)
    print(random.choice([1, '周杰伦', ["盖伦", "胡辣汤"]])) # 1或者23或者[4,5])
    print(random.sample([1, '23', [4, 5]], 2)) # 列表元素任意2个组合
    lst = [1, 2, 3, 4, 5, 6, 7, 8]
    random.shuffle(lst) # 随机打乱顺序
    print(lst)
    import random
    print(random.randint(10,20)) # 随机整数
    print(random.random()) # python中所有随机数的根 随机小数 0-1
    
    print(random.uniform(10,20)) # 10-20的随机小数
    lst = ["宝宝", "宝强", "宝浪", "包拯"]
    random.shuffle(lst)  # 随机打乱顺序
    print(lst)
    
    从列表中随机选择一个
    print(random.choice(["林志玲", "刘一菲", "王昭君", "艾米", "宝宝"]))
    print(random.sample(["林志玲", "刘一菲", "王昭君", "艾米", "宝宝"], 3))
  • 相关阅读:
    Unity3D Shader入门指南(二)
    Unity3D Shader入门指南(一)
    NGUI 减少drawcall规则
    linux系统date命令详解
    使用Installutil安装系统服务方法
    各大视频网站广告屏蔽代码
    C#--无边框窗体实现拖动、最大化、最小化、关闭(转)
    C# 如何在winform窗体自定义一个扁平化控件(转)
    C# winform 界面美化技巧(扁平化设计) (转)
    VC6插件安装--Unable to register this add-in because its DllRegisterServer returns an error (转)
  • 原文地址:https://www.cnblogs.com/H1050676808/p/10182272.html
Copyright © 2011-2022 走看看